我一直在使用带有 RBF SVM(二进制分类器)的 Gridsearchcv 来获得验证准确度热图。我使用的代码几乎直接来自 SKlearn 的网站。有没有办法从中找到敏感性和特异性?至于 Gridsearchcv 使用的参数值的范围?
问问题
4629 次
1 回答
3
如果您的问题是二元或多类分类,那么混淆矩阵可能就是您要寻找的。
from sklearn.metrics import confusion_matrix
y_true = [2, 0, 2, 2, 0, 1]
y_pred = [0, 0, 2, 2, 0, 2]
confusion_matrix(y_true, y_pred)
array([[2, 0, 0],
[0, 0, 1],
[1, 0, 2]])
解释如下:
对于属于第 0 类的示例,估计器正确地预测了其中的 100% (2/2)。
对于属于第 1 类的示例,估计器 100% 错误,因为它预测了第 2 类的唯一示例。
对于属于第 2 类的示例,估计器正确率为 66% (2/3),因为它预测了 2 个示例2 和 1 到 0 级。
对于二进制分类:
y_true = [1, 0, 1, 0, 0, 1]
y_pred = [1, 0, 1, 1, 0, 1]
cm = confusion_matrix(y_true, y_pred)
print cm
tp = float(cm[0][0])/np.sum(cm[0])
tn = float(cm[1][1])/np.sum(cm[1])
print tp
print tn
[[2 1]
[0 3]]
0.666666666667
1.0
关于GridSearchCV中使用的参数,您可以在grid_scores_属性中找到它们。
于 2016-03-27T19:32:41.983 回答