- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 scikit 学习管道来缩放数字特征和编码分类特征。在我尝试实现 RandomUnderSampler 之前,它运行良好。来自 imblearn。我的目标是实现欠采样步骤,因为我的数据集非常不平衡 1:1000。
我确保使用 imblearn 的 Pipeline 方法而不是 sklearn。下面是我试过的代码。
代码数据在没有欠采样器方法的情况下工作(使用 sklearn 管道)。
from sklearn.pipeline import Pipeline, FeatureUnion
from sklearn.preprocessing import OneHotEncoder, StandardScaler
from imblearn.pipeline import make_pipeline as make_pipeline_imb
from imblearn.pipeline import Pipeline as Pipeline_imb
from sklearn.base import BaseEstimator, TransformerMixin
class TypeSelector(BaseEstimator, TransformerMixin):
def __init__(self, dtype):
self.dtype = dtype
def fit(self, X, y=None):
return self
def transform(self, X):
assert isinstance(X, pd.DataFrame)
return X.select_dtypes(include=[self.dtype])
transformer = Pipeline([
# Union numeric, categoricals and boolean
('features', FeatureUnion(n_jobs=1, transformer_list=[
# Select bolean features
('boolean', Pipeline([
('selector', TypeSelector('bool')),
])),
# Select and scale numericals
('numericals', Pipeline([
('selector', TypeSelector(np.number)),
('scaler', StandardScaler()),
])),
# Select and encode categoricals
('categoricals', Pipeline([
('selector', TypeSelector('category')),
('encoder', OneHotEncoder(handle_unknown='ignore')),
]))
])),
])
pipe = Pipeline([('prep', transformer),
('clf', RandomForestClassifier(n_estimators=500, class_weight='balanced'))
])
from sklearn.pipeline import Pipeline, FeatureUnion
from sklearn.preprocessing import OneHotEncoder, StandardScaler
from imblearn.pipeline import make_pipeline as make_pipeline_imb
from imblearn.pipeline import Pipeline as Pipeline_imb
from sklearn.base import BaseEstimator, TransformerMixin
class TypeSelector(BaseEstimator, TransformerMixin):
def __init__(self, dtype):
self.dtype = dtype
def fit(self, X, y=None):
return self
def transform(self, X):
assert isinstance(X, pd.DataFrame)
return X.select_dtypes(include=[self.dtype])
transformer = Pipeline_imb([
# Union numeric, categoricals and boolean
('features', FeatureUnion(n_jobs=1, transformer_list=[
# Select bolean features
('boolean', Pipeline_imb([
('selector', TypeSelector('bool')),
])),
# Select and scale numericals
('numericals', Pipeline_imb([
('selector', TypeSelector(np.number)),
('scaler', StandardScaler()),
])),
# Select and encode categoricals
('categoricals', Pipeline_imb([
('selector', TypeSelector('category')),
('encoder', OneHotEncoder(handle_unknown='ignore')),
]))
])),
])
pipe = Pipeline_imb([
('sampler', RandomUnderSampler(0.1)),
('prep', transformer),
('clf', RandomForestClassifier(n_estimators=500, class_weight='balanced'))
])
/usr/local/lib/python3.6/dist-packages/sklearn/pipeline.py in __init__(self, steps, memory, verbose)
133 def __init__(self, steps, memory=None, verbose=False):
134 self.steps = steps
--> 135 self._validate_steps()
136 self.memory = memory
137 self.verbose = verbose
/usr/local/lib/python3.6/dist-packages/imblearn/pipeline.py in _validate_steps(self)
144 if isinstance(t, pipeline.Pipeline):
145 raise TypeError(
--> 146 "All intermediate steps of the chain should not be"
147 " Pipelines")
148
TypeError: All intermediate steps of the chain should not be Pipelines
最佳答案
如果您在文件 imblearn/pipeline.py
中探索 imblean 的代码here , 在函数下 _validate_steps
, 他们会检查 transformers
中的每一项是否存在作为 scikit 管道实例的转换器 ( isinstance(t, pipeline.Pipeline)
)。
从您的代码中,transformers
是
RandomUnderSampler
transformer
Pipeline_imb
使用
Pipeline_imb
时继承了 scikit 的流水线在您的代码中是多余的。
transformer = FeatureUnion(n_jobs=1, transformer_list=[
# Select bolean features
('selector1', TypeSelector('bool'),
# Select and scale numericals
('selector2', TypeSelector(np.number)),
('scaler', StandardScaler()),
# Select and encode categoricals
('selector3', TypeSelector('category')),
('encoder', OneHotEncoder(handle_unknown='ignore'))
])
pipe = Pipeline_imb([
('sampler', RandomUnderSampler(0.1)),
('prep', transformer),
('clf', RandomForestClassifier(n_estimators=500, class_weight='balanced'))
])
关于python - 如何在 scikit 学习管道中实现 RandomUnderSampler?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57193413/
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
介绍篇 什么是MiniApis? MiniApis的特点和优势 MiniApis的应用场景 环境搭建 系统要求 安装MiniApis 配置开发环境 基础概念 MiniApis架构概述
我正在从“JavaScript 圣经”一书中学习 javascript,但我遇到了一些困难。我试图理解这段代码: function checkIt(evt) { evt = (evt) ? e
package com.fastone.www.javademo.stringintern; /** * * String.intern()是一个Native方法, * 它的作用是:如果字
您会推荐哪些资源来学习 AppleScript。我使用具有 Objective-C 背景的传统 C/C++。 我也在寻找有关如何更好地开发和从脚本编辑器获取更快文档的技巧。示例提示是“查找要编写脚本的
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
关闭。这个问题不符合 Stack Overflow guidelines 。它目前不接受答案。 想改善这个问题吗?更新问题,以便堆栈溢出为 on-topic。 6年前关闭。 Improve this
我是塞内加尔的阿里。我今年60岁(也许这是我真正的问题-笑脸!!!)。 我正在学习Flutter和Dart。今天,我想使用给定数据模型的列表(它的名称是Mortalite,请参见下面的代码)。 我尝试
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 9年前关闭。 Improve this que
学习 Cappuccino 的最佳来源是什么?我从事“传统”网络开发,但我对这个新框架非常感兴趣。请注意,我对 Objective-C 毫无了解。 最佳答案 如上所述,该网站是一个好地方,但还有一些其
我正在学习如何使用 hashMap,有人可以检查我编写的这段代码并告诉我它是否正确吗?这个想法是有一个在公司工作的员工列表,我想从 hashMap 添加和删除员工。 public class Staf
我正在尝试将 jQuery 与 CoffeScript 一起使用。我按照博客中的说明操作,指示使用 $ -> 或 jQuery -> 而不是 .ready() 。我玩了一下代码,但我似乎无法理解我出错
还在学习,还有很多问题,所以这里有一些。我正在进行 javascript -> PHP 转换,并希望确保这些做法是正确的。是$dailyparams->$calories = $calories;一条
我目前正在学习 SQL,以便从我们的 Magento 数据库制作一个简单的 RFM 报告,我目前可以通过导出两个查询并将它们粘贴到 Excel 模板中来完成此操作,我想摆脱 Excel 模板。 我认为
我知道我很可能会因为这个问题而受到抨击,但没有人问,我求助于你。这是否是一个正确的 javascript > php 转换 - 在我开始不良做法之前,我想知道这是否是解决此问题的正确方法。 JavaS
除了 Ruby-Doc 之外,哪些来源最适合获取一些示例和教程,尤其是关于 Ruby 中的 Tk/Tile?我发现自己更正常了 http://www.tutorialspoint.com/ruby/r
我只在第一次收到警告。这正常吗? >>> cv=LassoCV(cv=10).fit(x,y) C:\Python27\lib\site-packages\scikit_learn-0.14.1-py
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
As it currently stands, this question is not a good fit for our Q&A format. We expect answers to be
我是一名优秀的程序员,十分优秀!