• AUC的两种计算方式


    1.什么是AUC?

    推荐 搜索场景下的auc理解_凝眸伏笔的博客-CSDN博客_搜索auc

    随机抽出一对样本(一个正样本,一个负样本),然后用训练得到的分类器来对这两个样本进行预测,预测得到正样本的概率大于负样本概率的概率。

    • TPRate的意义是所有真实类别为1的样本中,预测类别为1的比例。:真正率
    • FPRate的意义是所有真实类别为0的样本中,预测类别为1的比例。:假正率

     AUC的优势:

    AUC的计算方法同时考虑了分类器对于正例和负例的分类能力,在样本不平衡的情况下,依然能够对分类器作出合理的评价。

    2.AUC对均匀正负样本采样不敏感

    正由于AUC对分值本身不敏感,故常见的正负样本采样,并不会导致auc的变化。比如在点击率预估中,处于计算资源的考虑,有时候会对负样本做负采样,但由于采样完后并不影响正负样本的顺序分布。

    3.AUC值本身有何意义

    我们在实际业务中,常常会发现点击率模型的auc要低于购买转化率模型的auc。正如前文所提,AUC代表模型预估样本之间的排序关系,即正负样本之间预测的gap越大,auc越大.

    4.如何计算AUC?

    计算AUC时,推荐2个方法。

    方法一:

    在有M个正样本,N个负样本的数据集里。一共有M*N对样本(一对样本即,一个正样本与一个负样本)。统计这M*N对样本里,正样本的预测概率大于负样本的预测概率的个数。

     举一个例子:

    IDlabelpro
    A00.1
    B00.4
    C10.35
    D10.8

    假设有4条样本。2个正样本,2个负样本,那么M*N=4。即总共有4个样本对。分别是:
    (D,B),(D,A),(C,B),(C,A)。在(D,B)样本对中,正样本D预测的概率大于负样本B预测的概率(也就是D的得分比B高),记为1,同理,对于(C,B)。正样本C预测的概率小于负样本C预测的概率,记为0.最后可以算得,总共有3个符合正样本得分高于负样本得分,故最后的AUC为(1+1+1+0)/4 = 0.75

    在这个案例里,没有出现得分一致的情况,假如出现得分一致的时候,例如:

    IDlabelpro
    A00.1
    B00.4
    C10.4
    D10.8


    同样本是4个样本对,对于样本对(C,B)其I值为0.5。

    最后的AUC为 (1+1+1+0.5)/4 = 0.875

    方法二:

    另外一个方法就是利用下面的公式:

     

     例子:

    IDlabelpro
    A00.1
    B00.4
    C10.35
    D10.8

     将这个例子排序。按概率排序后得到:

    IDlabelprorank
    A00.11
    C10.352
    B00.43
    D10.84

    按照上面的公式,只把正样本的序号加起来也就是只把样本C,D的rank值加起来后减去一个常数项:M(M+1)/2 =[ (4+2) -2*(2+1)/2]/2*2=0.75

    这个时候,我们有个问题,假如出现得分一致的情况怎么办?下面举一个例子说明:

    IDlabelpro
    A10.8
    B10.7
    C00.5
    D00.5
    E10.5
    F10.5
    G00.3

    在这个例子中,我们有4个取值概率为0.5,而且既有正样本也有负样本的情况。计算的时候,其实原则就是相等得分的rank取平均值。具体来说如下:

    先排序:

    IDlabelprorank
    G00.31
    F10.52
    E10.53
    D00.54
    C00.55
    B10.76
    A10.87

    这里需要注意的是:相等概率得分的样本,无论正负,谁在前,谁在后无所谓。

    由于只考虑正样本的rank值:
    对于正样本A,其rank值为7
    对于正样本B,其rank值为6
    对于正样本E,其rank值为(5+4+3+2)/4
    对于正样本F,其rank值为(5+4+3+2)/4
    最后我们得到:

    [ (7 + 6 + )  + (5+4+3+2)/4 + (5+4+3+2)/4 - 4(4+1)/2] / 4*3 = 10/12=5/6

    其python的代码:

    1. import numpy as np
    2. from sklearn.metrics import roc_auc_score
    3. y_true = np.array([1,1,0,0,1,1,0])
    4. y_scores = np.array([0.8,0.7,0.5,0.5,0.5,0.5,0.3])
    5. print "y_true is ",y_true
    6. print "y_scores is ",y_scores
    7. print "AUC is",roc_auc_score(y_true, y_scores)
    8. y_true = np.array([0, 0, 1, 1])
    9. y_scores = np.array([0.1, 0.4, 0.35, 0.8])
    10. print "y_true is ",y_true
    11. print "y_scores is ",y_scores
    12. print "AUC is ",roc_auc_score(y_true, y_scores)

    其他:

    1.为什么auc和logloss比accuracy更常用?

    答:模型分类问题预测得到的是概率,如果需要计算accuracy,则需要对这个概率设置一个阈值,而这个阈值极大的影响了accuracy的计算。使用auc和logloss避免把概率准换为类别。可以直接使用预测得到的概率来计算。

    除此之外,虽然准确率可以判断总的正确率,但是在样本不平衡的情况下,并不能作为很好的指标来衡量结果。由于样本不平衡的问题,导致了得到的高准确率结果含有很大的水分。即如果样本不平衡,准确率就会失效。

    2.精准率

    精准率(Precision)又叫查准率,它是针对预测结果而言的,它的含义是在所有被预测为正的样本中实际为正的样本的概率,意思就是在预测为正样本的结果中,我们有多少把握可以预测正确,其公式如下:

    3. 召回率

    召回率(Recall)又叫查全率,它是针对原样本而言的,它的含义是在实际为正的样本中被预测为正样本的概率,其公式如下:

     

    召回率的应用场景:比如拿网贷违约率为例,相对好用户,我们更关心坏用户,不能错放过任何一个坏用户。因为如果我们过多的将坏用户当成好用户,这样后续可能发生的违约金额会远超过好用户偿还的借贷利息金额,造成严重偿失。召回率越高,代表实际坏用户被预测出来的概率越高,它的含义类似:宁可错杀一千,绝不放过一个。

    参考:
    1. AUC的计算方法_kingsam_的博客-CSDN博客_auc计算公式

    2.如何理解机器学习和统计中的AUC? - 知乎

  • 相关阅读:
    1043 输出PATest
    06. Nginx进阶-Nginx代理服务
    老男孩教育 | 销售转行做网安,完美逆袭,进入国企!
    为什么 Python 代码在函数中运行得更快?
    Github 2024-04-18 开源项目日报 Top10
    【LeetCode热题100】--347.前K个高频元素
    linux指令之netstat命令使用总结
    计算机视觉40例之案例05物体计数
    Jmeter——结合Allure展示测试报告
    HIVE内置函数hash() -- 源码解析
  • 原文地址:https://blog.csdn.net/pearl8899/article/details/126129148