当前位置:网站首页>【笔记】混淆矩阵和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)

边栏推荐
猜你喜欢

基于 Cyclone IV 在 Quartus 中配置 IP 核中的 PLL、RAM 与 FIFO 的详细步骤及仿真验证

ROS计算图——rqt_graph

用 SQL 做数据分析的十大常用功能,附面试原题解答!!

radio button、qss文件环境配置

Task Scheduler 计划定时任务,修改时报错: One or more of the specified arguments are not valid

leetcode:152. 乘积最大子数组

vant-field中colon属性为true报错

ROS2自学笔记:机器视觉基础

IDEA如何创建同级工程

Pro_07丨波动率因子3.0与斜率因子
随机推荐
记录学习--Navicat使用自定义数据库列表
工作两年成跳槽高峰期,程序员会在一家公司待多久?
Senior ClickHouse -
一次偶然的钓鱼文件分析
任意版本JLink驱动官方下载指引
Nacos入门学习
2022-08-02 顾宇佳 学习笔记 多线程
【数据分析】基于MATLAB实现SVDD决策边界可视化
els 消除行
C语言——-动态内存开辟与管理(malloc,free,calloc,realloc)+柔性数组
基于 Cyclone IV 在 Quartus 中配置 IP 核中的 PLL、RAM 与 FIFO 的详细步骤及仿真验证
豆瓣评分9.3的好书,文末给大家抽奖送几本!
# RACE32——高级断点的设置和应用
【GraphQL】使用Hot Chocolate和.NET 6构建GraphQL应用
Dynamically modify the title of the navigation bar in uniapp
iScroll系列之下拉刷新 + 上拉加载更多
在VScode里调试ROS程序
MySQL-如何分库分表?一看就懂
如何画一张架构图(内含知识图谱)
Auto.js Pro 编写第一个脚本hello world