python机器学习 二分类 混淆矩阵_二分类问题中混淆矩阵、PR以及AP评估指标

本文探讨机器学习中的二分类问题,重点关注混淆矩阵、PR曲线及AP评估指标。通过实例解释了如何计算精度(Precision)和召回率(Recall),以及如何构建PR曲线和计算平均 precision (AP)。AP值越大,模型性能越好。
摘要由CSDN通过智能技术生成

仿照上篇博文对于混淆矩阵、ROC和AUC指标的探讨,本文简要讨论机器学习二分类问题中的混淆矩阵、PR以及AP评估指标;实际上,(ROC,AUC)与(PR,AP)指标对具有某种相似性。

按照循序渐进的原则,依次讨论混淆矩阵、PR和AP:

设定一个机器学习问题情境:给定一些肿瘤患者样本,构建一个分类模型来预测肿瘤是良性还是恶性,显然这是一个二分类问题。

本文中,将良性肿瘤视为正类标签(可能在具体实践中更为关注恶性肿瘤,不过这并不影响技术上的操作)。

当分类模型选定以后,将其在测试数据集上进行评估,分别可以得到以下评估指标:

混淆矩阵

9e6dde6fd90d0be4f88feb85425e90a8.png

TP表示预测为良性,真实情况是良性的样例数;

FN表示预测为恶性,真实情况是良性的样例数;

FP表示预测为良性,真实情况是恶性的样例数;

TN表示预测为恶性,真实情况是恶性的样例数;

以上四类数据构成混淆矩阵。

PR

在混淆矩阵的基础上,进一步地定义两个指标。

按照下式定义precision(P)指标

cb60b420f340bfe043d14de88535e8a7.png

precision表示,预测为正的样本中有多少是真正的正样本;精准率强调对某类样本识别的准确性。

按照下式定义recall(R)指标

beda6451b1a7cd0b704af5851ecc6ce1.png

recall表示,样本中的正例有多少被预测正确了;召回率强调对某类样本识别的全面性。

precision,recall分别反映分类器对某一类样本鉴别能力的两个方面;通常,这两个指标呈现互斥关系,即一个指标高了往往会致使另一指标降低。

由上,一个混淆矩阵对应一对(precision,recall)

需要明确的是,P和R是建立在类别明确的预测结果之上的,即分类模型明确地指出待预测样本的类别。

然而,在二分类问题(0,1)中,一般模型最后的输出是一个概率值,表示结果是1的概率。此时需要确定一个阈值,若模型的输出概率超过阈值,则归类为1;若模型的输出概率低于阈值,则归类为0。

不同的阈值会导致分类的结果不同,也就是混淆矩阵有差,P和R也就不同。

当阈值从0开始慢慢移动到1的过程,就会形成很多对(precision,recall)的值,将它们画在坐标系上,就是所谓的PR曲线了。

AP

得到PR曲线后,就可以计算曲线下方的面积,计算出来的面积就是AP值。

一般而言,AP越大,模型的性能越好。

示例

a30adeb89aef6b8ba8a76abe8b18e44b.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值