分类准确率分数是指所有分类正确的百分比。分类准确率这一衡量分类器的标准比较容易理解,但是它不能告诉你响应值的潜在分布,并且它也不能告诉你分类器犯错的类型。
sklearn.metrics.accuracy_score(y_true, y_pred, normalize=True, sample_weight=None)
normalize:默认值为True,返回正确分类的比例;如果为False,返回正确分类的样本数
>>>import numpy as np
>>>from sklearn.metrics import accuracy_score
>>>y_pred = [0, 2, 1, 3]
>>>y_true = [0, 1, 2, 3]
>>>accuracy_score(y_true, y_pred)
0.5
>>>accuracy_score(y_true, y_pred, normalize=False)
2
召回率 =提取出的正确信息条数 /样本中的信息条数。通俗地说,就是所有准确的条目有多少被检索出来了。
klearn.metrics.recall_score(y_true, y_pred, labels=None, pos_label=1,average='binary', sample_weight=None)
将一个二分类matrics
拓展到多分类或多标签问题时,我们可以将数据看成多个二分类问题的集合,每个类都是一个二分类。接着,我们可以通过跨多个分类计算每个二分类metrics
得分的均值,这在一些情况下很有用。你可以使用average
参数来指定。
macro:计算二分类metrics
的均值,为每个类给出相同权重的分值。当小类很重要时会出问题,因为该macro-averging
方法是对性能的平均。另一方面,该方法假设所有分类都是一样重要的,因此macro-averaging
方法会对小类的性能影响很大。
weighted:对于不均衡数量的类来说,计算二分类metrics
的平均,通过在每个类的score
上进行加权实现。
micro:给出了每个样本类以及它对整个metrics
的贡献的pair(sample-weight)
,而非对整个类的metrics
求和,它会每个类的metrics
上的权重及因子进行求和,来计算整个份额。Micro-averaging
方法在多标签(multilabel
)问题中设置,包含多分类,此时,大类将被忽略。
samples:应用在multilabel
问题上。它不会计算每个类,相反,它会在评估数据中,通过计算真实类和预测类的差异的metrics
,来求平均(sample_weight-weighted
)
average:average=None
将返回一个数组,它包含了每个类的得分。
>>>from sklearn.metrics import recall_score
>>>y_true = [0, 1, 2, 0, 1, 2]
>>>y_pred = [0, 2, 1, 0, 0, 1]
>>>recall_score(y_true, y_pred, average='macro')
0.33...
>>>recall_score(y_true, y_pred, average='micro')
0.33...
>>>recall_score(y_true, y_pred, average='weighted')
0.33...
>>>recall_score(y_true, y_pred, average=None)
array([1., 0., 0.])
ROC
曲线指受试者工作特征曲线/接收器操作特性(receiver operating characteristic,ROC
)曲线,是反映灵敏性和特效性连续变量的综合指标,是用构图法揭示敏感性和特异性的相互关系,它通过将连续变量设定出多个不同的临界值,从而计算出一系列敏感性和特异性。ROC
曲线是根据一系列不同的二分类方式(分界值或决定阈),以真正例率(也就是灵敏度)(True Positive Rate,TPR
)为纵坐标,假正例率(1-特效性)(False Positive Rate,FPR
)为横坐标绘制的曲线。
ROC
观察模型正确地识别正例的比例与模型错误地把负例数据识别成正例的比例之间的权衡。TPR
的增加以FPR
的增加为代价。ROC
曲线下的面积是模型准确率的度量,AUC(Area under roccurve)
。
纵坐标:真正率(True Positive Rate , TPR
)或灵敏度(sensitivity
)
TPR = TP /(TP + FN)
(正样本预测结果数 / 正样本实际数)
横坐标:假正率(False Positive Rate , FPR
)
FPR = FP /(FP + TN)
(被预测为正的负样本结果数 /负样本实际数)
sklearn.metrics.roc_curve(y_true,y_score, pos_label=None, sample_weight=None, drop_intermediate=True)
该函数返回这三个变量:fpr,tpr
,和阈值thresholds
这里理解thresholds
:
分类器的一个重要功能“概率输出”,即表示分类器认为某个样本具有多大的概率属于正样本(或负样本)。
“Score
”表示每个测试样本属于正样本的概率。
接下来,我们从高到低,依次将“Score
”值作为阈值threshold
,当测试样本属于正样本的概率大于或等于这个threshold
时,我们认为它为正样本,否则为负样本。每次选取一个不同的threshold,我们就可以得到一组FPR
和TPR
,即ROC
曲线上的一点。当我们将threshold
设置为1和0时,分别可以得到ROC
曲线上的(0,0)和(1,1)两个点。将这些(FPR,TPR
)对连接起来,就得到了ROC
曲线。当threshold
取值越多,ROC
曲线越平滑。其实,我们并不一定要得到每个测试样本是正样本的概率值,只要得到这个分类器对该测试样本的“评分值”即可(评分值并不一定在(0,1)区间)。评分越高,表示分类器越肯定地认为这个测试样本是正样本,而且同时使用各个评分值作为threshold
。我认为将评分值转化为概率更易于理解一些。
>>>import numpy as np
>>>from sklearn import metrics
>>>y = np.array([1, 1, 2, 2])
>>>scores = np.array([0.1, 0.4, 0.35, 0.8])
>>>fpr, tpr, thresholds = metrics.roc_curve(y, scores, pos_label=2)
>>>fpr
array([0. , 0.5, 0.5, 1. ])
>>>tpr
array([0.5, 0.5, 1. , 1. ])
>>>thresholds
array([0.8 , 0.4 , 0.35, 0.1 ])
>>>from sklearn.metrics import auc
>>>metrics.auc(fpr, tpr)
0.75
计算AUC
值,其中x,y分别为数组形式,根据(xi,yi)
在坐标上的点,生成的曲线,然后计算AUC
值。
sklearn.metrics.auc(x, y, reorder=False)
直接根据真实值(必须是二值)、预测值(可以是0/1,也可以是proba
值)计算出auc
值,中间过程的roc
计算省略。
sklearn.metrics.roc_auc_score(y_true, y_score, average='macro', sample_weight=None)
参数:
average
: string, [None, ‘micro’, ‘macro’(default), ‘samples’, ‘weighted’]
实例:
>>>import numpy as np
>>>from sklearn.metrics import roc_auc_score
>>>y_true = np.array([0, 0, 1, 1])
>>>y_scores = np.array([0.1, 0.4, 0.35, 0.8])
>>>roc_auc_score(y_true, y_scores)
0.75
用一个例子来理解混淆矩阵:
假设有一个用来对猫(cats)、狗(dogs)、兔子(rabbits)进行分类的系统,混淆矩阵就是为了进一步分析性能而对该算法测试结果做出的总结。假设总共有 27 只动物:8只猫, 6条狗, 13只兔子。结果的混淆矩阵如下图:
在这个混淆矩阵中,实际有 8只猫,但是系统将其中3只预测成了狗;对于 6条狗,其中有 1条被预测成了兔子,2条被预测成了猫。从混淆矩阵中我们可以看出系统对于区分猫和狗存在一些问题,但是区分兔子和其他动物的效果还是不错的。所有正确的预测结果都在对角线上,所以从混淆矩阵中可以很方便直观的看出哪里有错误,因为他们呈现在对角线外面。