当前位置:网站首页>【笔记】混淆矩阵和ROC曲线
【笔记】混淆矩阵和ROC曲线
2022-08-03 03:05:00 【Sprite.Nym】
一、混淆矩阵
预测为真 | 预测为假 | |
---|---|---|
真实为真 | TP (True Positive) | FN (False Negative) |
真实为假 | FP (False Positive) | TN (True Negative) |
案例:
真实值:0 1 1 0 1 1 0 0 1 0 1 0 1 0 0
预测值:1 1 1 1 1 0 0 0 0 0 1 1 1 0 1
二、重要指标
(1)精确率(precision、positive predictive value、ppv):
TP / (TP + FP)
即鉴定为阳性的所有数据中,确实为阳性的数据所占比。衡量算法的精确度。
(2)召回率(recall、sensitivity(敏感度)、True Positive Rate(真阳性率/TPR)):
TP / (TP + FN)
即所有确实为阳性的数据中被鉴定出来的比率。
(3)特异度(specificity、True Negative Rate(真阴性率/TNR)):
TN / (TN + FP)
即所有确实为阴性的数据中被鉴定出来的比率。
(4)假阳性率(False Positive Rate(FPR)):
FP / (FP + TN)
即所有确实为阴性的数据中被鉴定成阳性的比率。
(5)F1值:精确率和召回率的调和平均数。F1值越接近1,模型输出越好。
2 1 p r e c i s i o n + 1 r e c a l l \Large \frac 2 {\frac 1 {precision} + \frac 1 {recall}} precision1+recall12
三、ROC曲线
在已经通过算法计算得到预测概率的前提下,每确定一个概率阈值,都可以产生一组新的预测值,每组新的预测值都可以和测试集中的真实值计算出一个新的混淆矩阵和对应的TPR、FPR。改变阈值,得到很多对不同的TPR、FPR后,以FPR为X坐标,TPR为Y坐标绘制成折线图,即得到ROC曲线。ROC曲线和X轴与X=1这两条线围成的图形面积叫AUC值,Area Under Curve。
在sklearn中绘制ROC曲线(数据事先准备):
# 导入metrics
from sklearn import metrics
# 定义一个绘图函数
def show_roc(y_test, scores, pos_label):
# 得到FPR、TPR和阈值
fpr, tpr, threshold = metrics.roc_curve(y_test, scores, pos_label=pos_label)
plt.plot(fpr, tpr, color='green')
# 绘制对角线
plt.plot(np.linspace(0,1,10),np.linspace(0,1,10),color='red',ls='--')
# 加X轴Y轴标签
plt.xlabel('FPR')
plt.ylabel('TPR')
# 加名字
plt.title('ROC space')
plt.show()
# 调用函数
show_roc(y_test, scores, 1)
边栏推荐
猜你喜欢
MySQL-如何分库分表?一看就懂
Task Scheduler 计划定时任务,修改时报错: One or more of the specified arguments are not valid
iScroll系列之下拉刷新 + 上拉加载更多
PyTorch installation - error when building a virtual environment in conda before installing PyTorch
Jenkins2.328+sonarqube7.9 实现代码自动化检测
PyTorch安装——安装PyTorch前在conda搭建虚拟环境的报错
QT添加资源文件、样式表、qss文件使用
【原创】Auto.js get和post 案例
单元测试是什么?怎么写?主要测试什么?
基于 Cyclone IV 在 Quartus 中配置 IP 核中的 PLL、RAM 与 FIFO 的详细步骤及仿真验证
随机推荐
leetcode:140. 单词拆分 II
leetcode:172. 阶乘后的零
stdio.h(本机代码)
C语言实验十三 指针(三)
Auto.js Pro 计算脚本运行时间
# RACE32——高级断点的设置和应用
SqlSession [[email protected]]
利用索引机制进行绕过
els 结束判断
软件测试技术之如何编写测试用例(2)
QCheckBox、margin、border、pandding、QHoxLayout、QSplitter、QSpacerItem
IDEA如何创建同级工程
云原生(三十一) | Kubernetes篇之平台基本预装资源
mysql-installer安装教程(详细图文)
How to write test cases in software testing technology (2)
JWT入门学习
Senior ClickHouse -
【云原生】服务行业案例-不可预测的并发场景解决方案
vant-field中colon属性为true报错
Redshift贴logo的方法