- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我必须训练一个用于垃圾邮件检测的分类器。
我拥有的数据集。
我手头有一个带有 [text, class]
标签的电子邮件数据集。而且我还有很多没有类别标签的电子邮件。
我想做的事。
我想使用gridsearchcv()
函数来估计我的模型的最佳超参数。其中一个参数与字典创建相关(例如 1-gram 或 2-gram、最小频率等)。我想要 gridsearchcv() 函数做的是在我的管道中使用整个电子邮件数据集(带标签的电子邮件 + 不带标签的电子邮件)来创建字典。但我希望它仅在带标签的电子邮件上测试结果。因此,基本上我想使用整个数据集来创建字典,并且我想仅在标记数据集上使用交叉验证来估计参数。
任何帮助将不胜感激:)
更新:
重要提示:针对 @AndreasMueller 的回答:结果会有所不同,因为我还调整了 CountVectorizer 的参数并且使用了逆文档频率。因此,我正在寻找一种方法,通过包含未标记的数据来使我的分类器更加通用。
这就是我现在所拥有的:
pipeline = Pipeline([
('features', FeatureUnion([
('words', Pipeline([
('vect', CountVectorizer()),
('frequency_transform', TfidfTransformer())
])),
('url_feature', Contains_URL_Transformer()),
('html_feature', Contains_HTML_Transformer()),
('length_feature', Text_Length_Transformer()),
('response_feature', Contains_Re_Transformer())
])),
('clf', SVC())
])
parameters = {
'features__words__vect__min_df': (1, 3, 5),
'features__words__vect__token_pattern': (r"\b[^\W\d_]+\b",),
'features__words__vect__binary': (False,),
'features__words__frequency_transform__use_idf' : (True,),
#'vect__max_features': (None, 5000, 10000, 50000),
'features__words__vect__ngram_range': ((1, 1), (1, 2)), # unigrams or bigrams
'clf__C': (1, 5, 10),
'clf__kernel': ('linear', 'rbf')
#'tfidf__use_idf': (True, False)
#'tfidf__norm': ('l1', 'l2'),
#'clf__alpha': (0.00001, 0.000001),
#'clf__penalty': ('l2', 'elasticnet'),
#'clf__n_iter': (10, 50, 80),
}
grid_search = GridSearchCV(pipeline, parameters, n_jobs=-1, verbose=1)
data_column = numpy.asarray(data['text'])
data_column = numpy.append(data_column, ['test'])
grid_search.fit(data_column, numpy.asarray(data['class']))
best_parameters = grid_search.best_estimator_.get_params()
for param_name in sorted(parameters.keys()):
print("\t%s: %r" % (param_name, best_parameters[param_name]))
但我还有unlabeld_data['text']
。如何将 data['text']
和 unlabeld_data['text']
混合添加到管道中,以便创建字典(并估计参数)混合但要在标记数据上进行测试。问题是,当我执行 grid_search.fit()
时,它使用提供的数据集来创建字典,但我看不出有什么办法可以将所有电子邮件放在那里。
最佳答案
一个简单的解决方案强制拟合数据保持不变,而不管交叉验证数据如何:
X_all = full dataset
class MyVectorizer(sklearn.feature_extraction.text.TfidfVectorizer):
def fit(self, X, y=None):
return super(MyVectorizer, self).fit(X_all)
def fit_transform(self, X, y=None):
return super(MyVectorizer, self).fit(X_all).transform(X)
使用它代替上面的'words'
子管道。
一个可以说不那么麻烦但更复杂的解决方案是:
-1
Transformer
)。 (也许从 SVC 扩展更简单,有点像上面的 MyVectorizer
所做的那样,但不使用全局数据 hack。)这种方法的一个优点是,无论 GridSearchCV
输入如何,它都适用(而不是通过全局变量注入(inject)完整数据的黑客)。
示例代码:
def semisupervised_stratified_kfold(y, *args, **kwargs):
labeled_idx = np.flatnonzero(y != -1)
unlabeled_idx = np.flatnonzero(y == -1)
for train, test in StratifiedKFold(y[labelled_idx], *args, **kwargs):
train = np.concatenate([unlabeled_idx, labeled_idx.take(train)])
test = labeled_idx.take(test)
yield train, test
from sklearn.utils.metaestimators import if_delegate_has_method
class StripUnlabelled(sklearn.base.BaseEstimator):
def __init__(self, estimator):
self.estimator = sklearn.base.clone(estimator)
def fit(self, X, y, **kwargs):
return self.estimator.fit()
@if_delegate_has_method(delegate='estimator')
def predict(self, X):
return self.estimator.predict(X)
# and similar for decision_function, predict_proba, score, etc.
然后将 GridSearchCV
的 cv
参数设置为自定义生成器,将 StripUnlabeled
包裹在 SVC
实例周围,并在 SVC 参数名称前加上 estimator__
这实际上不会在所有数据上构建 TFIDF 模型,而是使用所有未标记数据加上标记数据的所有训练折叠。
此外,请注意,使用 Pipeline
的所有类似解决方案都将非常低效,因为在下游更改参数时不会缓存重复的工作,尽管已经提出了用于缓存部分的通用解决方案管道。
关于python - 使用不同文本集的参数网格搜索,用于字典创建和交叉验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28625456/
我想使用单个(交叉)编译器来编译不同 ARM 调用约定的代码:因为我总是想使用浮点和 NEON 指令,所以我只想选择硬浮点调用约定或软浮点(softfp)调用约定。 我的编译器默认为硬浮点,但它支持我
假设我正在构建一个依赖于两个库的 java 应用程序:A 和 B。A 和 B 都依赖于库 C。管理 A 和 B 使用相同版本的最佳方法是什么所以他们不冲突?我正在使用 Gradle。 最佳答案 从 G
我想在按钮的文本上添加图像。如果我将图像添加为按钮的背景,它就会添加到文本下方。预期结果作为图像添加。请帮忙 更新:我需要以编程方式执行此操作。 最佳答案 在 XML 中, * 在代码中
我已经开始使用 CSS3 制作动画了。 我尝试创建一个动画汉堡菜单,但结果有点难看。顶部和底部的条向右平移一点。所以旋转动画不是很流畅和正确。 这是结果 => 这是我的代码: /* HTML */
给定一个具有2条相交曲线的图像,如下图所示,我如何使用opencv或python检测和区分2条曲线? (所以我需要2条单独的曲线) 最佳答案 您可以扫描每一列,并从连接的零件中识别出簇。 伪算法: l
我正在尝试在 redhat 集群(x86_64 主机)上设置 cross-mingw。我没有 root 访问权限,并且可用的 mingw 二进制文件不起作用(坏 glibc 版本等)。我正在阅读本教程
我正在尝试在javaFX中开发一个游戏,当两个图像相交时,分数将被更新,并且障碍物将不可见。但不幸的是,在游戏中分数不断更新。 我想我无法在游戏中正确地使图像不可见。 以下是相关类的完整代码: pac
pikastar dot com 是网站,当向下滚动它然后在导航菜单展开固定位置时它 > 将穿过主 div。我该如何修复它。 #topNav.sticky { box-shadow: 0 10
我正在使用 Eclipse为 ARM 处理器交叉编译 g++ 项目。我在 Windows 环境中使用 yagarto 工具链。我对 C 项目没有问题,但是对于 C++,我一直收到错误: libc.a(
我想从两个哈希数组中获取并集/交集/差集,例如: array1 = [{:name =>'Guy1', :age => 45},{:name =>'Guy2', :age => 45}] array2
有没有办法在调用任何 Controller 操作之前执行一些代码? 我需要根据 get 参数的值设置 session 变量,而不考虑调用哪个 Controller 。 当然,一旦这个处理完成,请求需要
我刚开始使用 3D 网格,面向用于有限元分析。我想在立方体状矩阵中模拟 Material 的夹杂物(任何形状,但主要对球体和椭圆体感兴趣)。这些夹杂物不应彼此重合。 所以我想为python使用某种包,
我想知道以跨平台方式操作应用程序设置的最佳解决方案是什么。 在 iOS 中,我们可以在设置屏幕中更改应用程序外部的设置,但在 windows phone 和 android 中我们没有。 所以,我的想
var barcodeNum = ko.observable(""); VelocityMeetings.scan = function (params) { var errorMessage = k
这个问题在这里已经有了答案: Transforming data.frame in R (2 个答案) 关闭10 年前。 过去我问过一个关于如何create cross tables from a
我有两个共享同一个工厂的 Controller 。其中一个 Controller 正在更新工厂变量。其他人应该注意该变化并稍后显示。 我是这样尝试的: http://plnkr.co/edit/q1N
标题不好,但这是我发现的将我的问题与简单的表格交叉区分开来的方式,因为我之前的研究总是让我接触到这类主题。 我有几个表 - 为了简化起见,我们只用 3 个表来命名它们:A、B、C。我想将它们全部放在一
我需要做这样的事情(在 MySQL 中),我使用 UNION 的尝试直到现在才奏效。 理论上: SELECT * FROM tableA A JOIN tableB B ON A.tableAId =
注意:使用SDL 2.0,Cross header class问题 我在类之间进行交叉引用,主要是我的类初始化渲染器和我的纹理类引用渲染初始化。现在,我已经能够运行该程序,直到我开始放入纹理类,代码也
我有一个这样的字母数组 var letters = ["Y", "X", "A", "Y", "O", "H", "A", "O", "O"]; 我创建了一个循环来
我是一名优秀的程序员,十分优秀!