前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pyplot做PR-curve

pyplot做PR-curve

作者头像
生信编程日常
发布2020-10-10 10:35:59
9180
发布2020-10-10 10:35:59
举报

我们可以用sklearn.metrics中的precision_recall_curve()和auc()计算出PR-AUC,然后用matplotlib.pyplot画出PR-curve:

代码语言:javascript
复制
from sklearn.metrics import precision_recall_curve, auc

clf = LogisticRegression()
clf.fit(X_train, y_train)
y_pred_proba = clf.predict_proba(X_test)[::,1]

clf.fit(X_train_e, y_train_e)
y_pred_proba_e = clf.predict_proba(X_test_e)[::,1]

precision, recall, thresholds = precision_recall_curve(y_test,  y_pred_proba)
precision_e, recall_e, thresholds_e = precision_recall_curve(y_test_e,  y_pred_proba_e)

pr_auc = auc(recall, precision)
pr_auc_e = auc(recall_e, precision_e)

plt.plot(recall,precision, color = 'blue')
plt.plot(recall_e,precision_e, color = 'red')
plt.title('Precision/Recall Curve')
plt.xlabel('Recall')
plt.ylabel('Precision')
plt.legend(loc="upper right", labels = ['Full model {}'.format(round(pr_auc, 2)), 'Expression only model {}'.format(round(pr_auc_e, 2))])
plt.show()

值得注意的是,对于特别不平衡的样本,虽然ROC-AUC可能会很好看,但是PR-AUC多半很一般,甚至很不好,上采样和下采样是非常有必要的,另外不要被ROC_AUC所蒙蔽。

欢迎关注!

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档