一文弄懂什么是Precision,Recall,F1score,以及accuracy[通俗易懂]

一文弄懂什么是Precision,Recall,F1score,以及accuracy[通俗易懂]近期在做实验的时候一直出现Precision,Recall,F1score,以及accuracy这几个概念,为了防止混淆,在这里写下学习笔记,方便以后复习。以一个二分类问题为例,样本有正负两个类别。那么模型预测的结果和真实标签的组合就有4种:TP,FP,FN,TN,如下图所示。TP实际为正样本你预测为正样本,FN实际为正样本你预测为负样本,FP实际为负样本你预测为正样本,TN实际为负样本…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

近期在做实验的时候一直出现Precision,Recall,F1score,以及accuracy这几个概念,为了防止混淆,在这里写下学习笔记,方便以后复习。

以一个二分类问题为例,样本有正负两个类别。
那么模型预测的结果和真实标签的组合就有4种:TP,FP,FN,TN,如下图所示。
在这里插入图片描述
TP实际为正样本你预测为正样本,FN实际为正样本你预测为负样本,
FP实际为负样本你预测为正样本,TN实际为负样本你预测为负样本

首先我们来谈一个好理解的概念:
Accuracy(准确率)

这个概念的理解就是你预测对的样本数占样本总数的比例,那什么是预测对的样本?什么是总样本? 看上面的图,我们能知道预测正确的样本数是TP,TN;总体的样本数就是四个加起来:TP+FN+FP+TN。 所以根据定义,可以得到Acc的计算公式:




A c c u r a c y = T P + T N / ( T P + T N + F P + F N ) Accuracy = TP+TN / (TP +TN+FP+FN) Accuracy=TP+TN/(TP+TN+FP+FN)

紧接着我们来看什么是Precision(精确率)
很多人容易把accuracy和precision弄混,无论是叫法还是定义。实际上很简单,区别也很明显。

精确率是针对我们预测结果而言的,它表示的是预测为正的样本中有多少是真正的正样本。那么预测为正就有两种可能了,一种就是把正类预测为正类(TP),另一种就是把负类预测为正类(FP)




P r e c i s i o n = T P / ( T P + F P ) Precision = TP / (TP + FP) Precision=TP/(TP+FP)

随后是召回率(Recall):

召回率是针对我们原来的样本而言的,它表示的是样本中的正例有多少被预测正确了。那也有两种可能,一种是把原来的正类预测成正类(TP),另一种就是把原来的正类预测为负类(FN)。


R e c a l l = T P / ( T P + F N ) Recall = TP / (TP + FN) Recall=TP/(TP+FN)

一般情况下,召回率和精确率是针对某一个类别说的,比如正类别的Recall,负类别的Recall等。如果你是10分类,那么可以有1这个类别的Precision,2这个类别的Precision,3这个类别的Recall等。而没有类似全部数据集的Recall或Precision这种说法。 通常对于二分类,我们说正类的recall和precision。

补充:
在信息检索领域,精确率和召回率又被称为查准率和查全率,

查准率=检索出的相关信息量 / 检索出的信息总量
查全率=检索出的相关信息量 / 系统中的相关信息总量

F1-score 是基于召回率和精确率计算的:

F 1 s c o r e = 2 ∗ P r e c i s i o n ∗ R e c a l l / ( P r e c i s i o n + R e c a l l ) F1score = 2*Precision*Recall / (Precision+Recall) F1score=2PrecisionRecall/(Precision+Recall)

参考:https://blog.csdn.net/u014380165/article/details/77493978

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182038.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月14日 下午4:16
下一篇 2022年10月14日 下午4:36


相关推荐

  • Java变量命名规范

    Java变量命名规范一 变量名命名的一些规定 1 必须以字母 下划线 或者美元符开头 以美元符开头命名的变量虽然能够编译通过但是不建议使用 中文也可以作为命名开头且编译也能通过 但是不建议使用 2 除开头外后面的部分可以有字母 下划线 美元符 以及数字组成 3 虽然变量名不限制长度 但能表达清楚命名的含义即可 4 变量名不可以和 java 的关键字冲突 下面列出具体的关键字 用于定义访问权限修饰符的关键字 private protected public 用于定义类 函数 变量修饰符的关键字 abstra

    2026年3月26日
    1
  • 最新!2025年国产大模型清单!你pick哪个?

    最新!2025年国产大模型清单!你pick哪个?

    2026年3月12日
    2
  • OpenClaw实战:一键部署OpenClaw,告别3小时部署折磨,5分钟拥有专属AI助手

    OpenClaw实战:一键部署OpenClaw,告别3小时部署折磨,5分钟拥有专属AI助手

    2026年3月12日
    3
  • 运算放大器加法器设计学习笔记

    运算放大器加法器设计学习笔记运算放大器构成加法器可以分为同相加法器和反相加法器第一种 同相加法器举个栗子 Vin1 0 4 Sin wt 也就是一个正弦信号 Vin2 1V 那么要实现两个信号的叠加而且相位不发生变化 也就是 Vout 1 0 4Sin wt 那么就可以使用同相加法器 也就是需要实现如下过程 图片极其丑陋 请略过 笑哭原理图如下图所示 借用网上的图 那么怎么计算这些电阻的取值呢 首先这里的输入端是相当于有两个电压源 那么为了确定每一个源在 V

    2025年10月31日
    6
  • 常见泰勒公式展开式

    常见泰勒公式展开式nbsp

    2026年3月19日
    2
  • 浅谈CICD持续集成、持续部署的流程

    浅谈CICD持续集成、持续部署的流程Jenkins是一个比较流行的持续集成工具GitLab是存储镜像的镜像仓库由客户端将代码push推送到git仓库,gitlab上配置了一个webHook的东西可以触发Jenkins的构建。进入到Jenkins虚线范围内,它所做的事情非常多,从mvn构建代码,对代码进行静态分析,做单元测试,测试通过之后就可以build镜像,镜像构建成功后就把镜像push推送到Harbor镜像仓库中,镜像push…

    2022年6月11日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号