【机器学习】AUC计算(Python实现)

目录

1、sklearn中计算AUC值的方法

2、编写函数实现 auc_calculate


AUC理论请看 【机器学习】POC & AUC

1、sklearn中计算AUC值的方法

from sklearn.metrics import roc_auc_score
auc_score = roc_auc_score(y_truth,y_pred)

y_pred即可以是类别,也可以是概率。

roc_auc_score直接根据真实值和预测值计算auc值,省略计算roc的过程。

import numpy as np
from sklearn.metrics import roc_auc_score

y = np.array([0, 0, 1, 1])  # 真实值
y_pred1 = np.array([0.3, 0.2, 0.25, 0.7])  # 预测值
y_pred2 = np.array([0, 0, 1, 0])  # 预测值

# 预测值是概率
auc_score1 = roc_auc_score(y, y_pred1)
print(auc_score1) # 0.75

# 预测值是类别
auc_score2 = roc_auc_score(y, y_pred2)
print(auc_score2) # 0.75

2、编写函数实现 auc_calculate

import numpy as np
from sklearn.metrics import roc_curve
from sklearn.metrics import auc

#---自己按照公式实现
def auc_calculate(labels,preds,n_bins=100):
    postive_len = sum(labels)
    negative_len = len(labels) - postive_len
    total_case = postive_len * negative_len
    pos_histogram = [0 for _ in range(n_bins)]
    neg_histogram = [0 for _ in range(n_bins)]
    bin_width = 1.0 / n_bins
    for i in range(len(labels)):
        nth_bin = int(preds[i]/bin_width)
        if labels[i]==1:
            pos_histogram[nth_bin] += 1
        else:
            neg_histogram[nth_bin] += 1
    accumulated_neg = 0
    satisfied_pair = 0
    for i in range(n_bins):
        satisfied_pair += (pos_histogram[i]*accumulated_neg + pos_histogram[i]*neg_histogram[i]*0.5)
        accumulated_neg += neg_histogram[i]

    return satisfied_pair / float(total_case)

if __name__ == '__main__':

    y = np.array([1,0,0,0,1,0,1,0,])
    pred = np.array([0.9, 0.8, 0.3, 0.1,0.4,0.9,0.66,0.7])


    fpr, tpr, thresholds = roc_curve(y, pred, pos_label=1)
    print("-----sklearn:",auc(fpr, tpr))
    print("-----py脚本:",auc_calculate(y,pred))

 

我觉得写代码的时候用sklearn自带的就好,方便快捷。理解理论的时候看看自己编写(他人编写)的代码比较好。~

参考:

AUC详解与python实现

  • 18
    点赞
  • 84
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python中,可以使用不同的方法来计算AUC(Area Under Curve)。以下是两种常用的方法: 方法一:使用sklearn库中的metrics模块 可以使用sklearn库中的metrics模块来计算AUC。首先,需要导入numpy和sklearn.metrics模块。然后,可以使用metrics.roc_curve函数计算真实标签值和模型预测得分的ROC曲线。最后,使用metrics.auc函数计算ROC曲线下的面积,即AUC值。 以下是一个示例代码: ```python import numpy as np from sklearn import metrics def compute_auc(y_true, y_score): fpr, tpr, _ = metrics.roc_curve(y_true, y_score) auc_value = metrics.auc(fpr, tpr) return auc_value ``` 在这个示例代码中,compute_auc函数接受真实标签值y_true和模型预测得分y_score作为输入,并返回计算得到的AUC值。 方法二:使用sklearn库中的roc_auc_score函数 另一种计算AUC的方法是使用sklearn库中的roc_auc_score函数。首先,需要导入sklearn.metrics模块。然后,可以使用roc_auc_score函数计算AUC值。 以下是一个示例代码: ```python from sklearn.metrics import roc_auc_score def calculate_auc(AUC_out, AUC_labels): row, col = AUC_labels.shape temp = \[\] ROC = 0 for i in range(col): try: ROC = roc_auc_score(AUC_out\[:, i\], AUC_labels\[:, i\], average='micro', sample_weight=None) except ValueError: pass temp.append(ROC) for i in range(col): ROC += float(temp\[i\]) return ROC / (col + 1) ``` 在这个示例代码中,calculate_auc函数接受网络输出AUC_out和监督标签AUC_labels作为输入,并返回计算得到的AUC值。 无论使用哪种方法,都需要确保已经安装了sklearn库。可以使用pip install sklearn命令来安装sklearn库。 #### 引用[.reference_title] - *1* [Python编程:实现AUC计算(含完整代码)](https://blog.csdn.net/ai52learn/article/details/130304627)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [python计算AUC值](https://blog.csdn.net/weixin_45653050/article/details/116768291)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【机器学习AUC计算Python实现)](https://blog.csdn.net/weixin_31866177/article/details/109157494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值