GridSearchCV中的scoring
说明
scoring参数输入形式
包括字符串、可调用对象或评分函数。以下是常用的评分规则示例:
-
使用预定义的字符串指定评分规则:
- 'accuracy':准确率(分类问题)
- 'precision':精确率(分类问题)
- 'recall':召回率(分类问题)
- 'f1':F1分数(分类问题)
- 'r2':R2分数(回归问题)
- 'neg_mean_squared_error':均方误差(回归问题)【为什么要使用负均方误差?这是因为在网格搜索过程中,Scikit-learn默认使用了负均方误差(negative mean squared error)作为评分指标。在网格搜索的目标是寻找最大化评分的最佳模型,而均方误差的计算结果越小越好。为了与最大化评分的目标一致,Scikit-learn将均方误差的值取负数,这样最大化负均方误差的结果就等价于最小化均方误差。所以,当使用 scoring='neg_mean_squared_error' 时,输出的评分值越接近于0,表示模型的性能越好。】
- 'neg_root_mean_squared_error'均方根误差(回归问题)【其实neg_root_mean_squared_error和neg_mean_squared_error使用的都是
metrics.mean_squared_error
函数实现的,只是参数squared
, default=True;If True returns MSE value, if False returns RMSE value.】 - 还有很多指标详见3.3.1. The scoring parameter: defining model evaluation rules
-
使用自定义的评分函数:
可以自定义一个评分函数,该函数接受真实标签和预测标签作为输入,并返回一个评分值。 -
使用可调用对象:
可以传递一个实现了scoring接口的可调用对象作为评分规则。这个可调用对象接受真实标签和预测标签作为输入,并返回一个评分值。
GridSearchCV默认的scoring
- GridSearchCV 默认的评估指标取决于所使用的模型。
- 对于许多机器学习模型,如回归和分类,评估指标可以通过指定 scoring 参数来进行选择或修改。
- 对于一些模型,默认的评估指标可以在文档中查找,例如 SVM 模型的默认评估指标是 accuracy。
- 如果没有指定 scoring 参数,GridSearchCV 将默认使用模型的默认评估指标。
- 在 sklearn 中,不同模型的默认评估指标可以在相应的文档中查找。
一些模型的默认评估指标:
- 对于分类问题,SVC 模型的默认评估指标是 accuracy(准确率),即正确分类的样本占总样本数的比例。
例子
scoring 参数可以使用多种形式指定,包括字符串(使用内置指标),可调用函数(自定义指标),或一个字典(指定不同的指标)。下面是一些示例:
- 使用内置指标:可以使用字符串指定内置指标,例如:
#这里指定使用 accuracy 作为评估指标。
from sklearn.model_selection import GridSearchCV
from sklearn.linear_model import LogisticRegression
param_grid = {'C': [0.1, 1, 10], 'penalty': ['l1', 'l2']}
clf = LogisticRegression(max_iter=1000)
grid_search = GridSearchCV(clf, param_grid, scoring='accuracy')
- 自定义指标:可以使用一个可调用函数指定自定义指标,例如:
#这里使用 make_scorer() 函数将 f1_score 转换为一个可调用的评估函数,并使用其作为评估指标。
from sklearn.metrics import make_scorer, f1_score
def custom_scorer(y_true, y_pred):
return f1_score(y_true, y_pred, average='macro')
param_grid = {'C': [0.1, 1, 10], 'penalty': ['l1', 'l2']}
clf = LogisticRegression(max_iter=1000)
grid_search = GridSearchCV(clf, param_grid, scoring=make_scorer(custom_scorer))
- 多个指标:可以使用一个字典来指定多个指标,例如:
"""
这里指定了两个指标:accuracy 和 recall,并使用 refit 参数指定在搜索过程结束后使用哪个指标来重新拟合模型。
refit这里使用 accuracy 来重新拟合模型。
"""
from sklearn.metrics import accuracy_score, recall_score, make_scorer
scoring = {'accuracy': make_scorer(accuracy_score),
'recall': make_scorer(recall_score)}
param_grid = {'C': [0.1, 1, 10], 'penalty': ['l1', 'l2']}
clf = LogisticRegression(max_iter=1000)
grid_search = GridSearchCV(clf, param_grid, scoring=scoring, refit='accuracy')
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)