评估指标:精确率(Precision)、召回率(Recall)、F1分数(F1 Score)

评估指标:精确率(Precision)、召回率(Recall)、F1分数(F1 Score)

  • 前言
  • 相关介绍
      • 1. 准确率(Accuracy)
      • 2. 精确率(Precision)
      • 3. 召回率(Recall)
      • 4. F1分数 (F1 Score)
      • 5. ROC曲线和AUC(Area Under the Curve)
      • 6. PR曲线(Precision-Recall Curve)
  • F1分数 (F1 Score)
      • F1分数的计算
      • F1分数的优点
      • F1分数的缺点
    • 计算实例
      • 示例数据
      • 计算精确率(Precision)
      • 计算召回率(Recall)
      • 计算F1分数 (F1 Score)

在这里插入图片描述

前言

  • 由于本人水平有限,难免出现错漏,敬请批评改正。
  • 更多精彩内容,可点击进入人工智能知识点专栏、Python日常小操作专栏、OpenCV-Python小应用专栏、YOLO系列专栏、自然语言处理专栏或我的个人主页查看
  • 基于DETR的人脸伪装检测
  • YOLOv7训练自己的数据集(口罩检测)
  • YOLOv8训练自己的数据集(足球检测)
  • YOLOv5:TensorRT加速YOLOv5模型推理
  • YOLOv5:IoU、GIoU、DIoU、CIoU、EIoU
  • 玩转Jetson Nano(五):TensorRT加速YOLOv5目标检测
  • YOLOv5:添加SE、CBAM、CoordAtt、ECA注意力机制
  • YOLOv5:yolov5s.yaml配置文件解读、增加小目标检测层
  • Python将COCO格式实例分割数据集转换为YOLO格式实例分割数据集
  • YOLOv5:使用7.0版本训练自己的实例分割模型(车辆、行人、路标、车道线等实例分割)
  • 使用Kaggle GPU资源免费体验Stable Diffusion开源项目

相关介绍

在人工智能领域,特别是在监督学习的任务中,评估模型性能是非常关键的步骤。

评估指标是衡量模型或系统性能的关键参数,不同的应用场景会采用不同的评估指标。它们将抽象的评估目标转化为具体可量化的数值,帮助我们了解模型在特定任务上的表现。

以下是一些常用的评估指标,包括它们的定义、计算公式以及优缺点:

1. 准确率(Accuracy)

定义:模型正确分类的样本数占总样本数的比例。
公式 A c c u r a c y = TP + TN TP + FN + FP + TN Accuracy = \frac{\text{TP} + \text{TN}}{\text{TP} + \text{FN} + \text{FP} + \text{TN}} Accuracy=TP+FN+FP+TNTP+TN
其中,TP(True Positive)是真的正类被正确预测的数量,TN(True Negative)是真的负类被正确预测的数量,FP(False Positive)是假的正类预测,FN(False Negative)是假的负类预测。

优点:简单直观,容易理解。
缺点:在数据类别不平衡的情况下,准确率可能产生误导,因为模型可能只是简单地预测多数类而忽略了少数类的表现。

2. 精确率(Precision)

定义:预测为正类中真正是正类的比例。
公式 P r e c i s i o n = TP TP + FP Precision = \frac{\text{TP}}{\text{TP} + \text{FP}} Precision=TP+FPTP

优点:关注预测为正例的准确性,适用于错误的正面预测成本较高的场景。
缺点:不考虑真负例,因此在负例很多且预测很少时,精确率可能很高,但模型可能错过许多正例。

3. 召回率(Recall)

定义:真正是正类的样本中被正确预测为正类的比例。
公式 R e c a l l = TP TP + FN Recall = \frac{\text{TP}}{\text{TP} + \text{FN}} Recall=TP+FNTP

优点:强调对正类的识别能力,适用于不能遗漏正例的场景。
缺点:可能会忽视假阳性预测的影响,即预测为正类但实际上为负类的情况。

4. F1分数 (F1 Score)

定义:精确率和召回率的调和平均值,旨在同时考虑精确率和召回率。
公式 F 1 = 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 F1 = 2 \times \frac{Precision \times Recall}{Precision + Recall} F1=2×Precision+RecallPrecision×Recall

优点:在单一指标中平衡了精确率和召回率,适用于两者都重要的情况。
缺点:当精确率和召回率中有一个非常低时,F1分数可能无法准确反映模型性能。
在这里插入图片描述

5. ROC曲线和AUC(Area Under the Curve)

定义:ROC曲线通过改变分类阈值,展示真正率(TPR)与假正率(FPR)的关系。AUC是ROC曲线下的面积。
优点:提供了一个整体评估模型分类能力的方法,不受单一阈值影响,AUC接近1表示分类器优秀。
缺点:对于多分类问题,需要计算多个二分类ROC曲线,或使用多分类的ROC曲线变体。

6. PR曲线(Precision-Recall Curve)

定义:同样通过改变分类阈值,显示精确率和召回率之间的权衡关系。
优点:在类别不平衡的数据集中更为有用,能更清晰地看到不同阈值下的性能变化。
缺点:不像AUC那样有统一的标准解释,比较不同模型时可能需要直接对比曲线形状。

选择合适的评估指标时,应考虑具体应用场景的需求,比如是否重视查准还是查全,或者数据集是否平衡等。
在这里插入图片描述

F1分数 (F1 Score)

F1分数(F1 Score)是一种广泛应用于二分类和多分类问题中的性能评价指标,特别是对于类别不平衡的数据集而言,它能提供比单一的精确率或召回率更为全面的性能评估。下面是F1分数的详细解析,包括其计算方法、优势和局限性:

F1分数的计算

F1分数是精确率(Precision)和召回率(Recall)的调和平均数,旨在综合这两个指标,以反映模型在分类任务中的平衡表现。其计算公式为:

F 1 = 2 × Precision × Recall Precision + Recall F1 = 2 \times \frac{\text{Precision} \times \text{Recall}}{\text{Precision} + \text{Recall}} F1=2×Precision+RecallPrecision×Recall

  • 精确率(Precision) 表示模型预测为正类别的样本中,真正为正类别的比例,计算公式为 (\frac{\text{真正例(TP)}}{\text{真正例(TP)} + \text{假正例(FP)}})。
  • 召回率(Recall) 表示所有实际为正类别的样本中,被模型正确识别的比例,计算公式为 (\frac{\text{真正例(TP)}}{\text{真正例(TP)} + \text{假阴例(FN)}})。

F1分数的优点

  1. 平衡精确率和召回率:F1分数同时考虑了模型预测的精确性和完整性,对于需要两者都达到较高水平的应用非常适用。
  2. 类别不平衡数据集:在正负样本数量差距较大的情况下,F1分数能够给出更为公平的性能评估,相比单独使用精确率或召回率更能反映出模型的整体效能。
  3. 单一指标:作为一个单一的数值指标,F1分数简化了模型性能的比较,便于理解和沟通。

F1分数的缺点

  1. 权重固定:F1分数对精确率和召回率给予相同的权重(即1:1),但在某些应用场景下,根据具体需求,可能需要对二者赋予不同的重要性(例如,某些情况下召回率可能比精确率更重要)。
  2. 忽视真负例(TN):F1分数完全依赖于正例的预测情况,忽略了模型正确预测为负例的能力,因此在某些场景下可能不足以全面评估模型性能,尤其是当错误地分类负例成本也很高时。
  3. 极端情况:当精确率和召回率中有一个为0时,F1分数也会变为0,即使另一个指标非常高,这可能在某些情况下显得过于苛刻。

综上所述,F1分数是衡量分类模型性能的有效工具,尤其适合评估那些需要均衡考虑精确率和召回率的应用场景。然而,在选择评估指标时,应考虑具体任务的需求,有时可能需要结合其他指标如AUC-ROC、Precision-Recall曲线等进行综合分析。

计算实例

F1分数是一种统计度量,用于评估二分类(或多标签分类中的每一个类别)模型的性能,它是精确率(Precision)和召回率(Recall)的调和平均值。下面通过一个简单的例子来说明如何计算F1分数:

示例数据

假设我们有一个二分类问题,模型预测的结果和实际标签如下:

  • 真实正例(TP,True Positives): 25个
  • 假正例(FP,False Positives): 5个
  • 真实负例(TN,True Negatives): 70个
  • 假负例(FN,False Negatives): 10个

计算精确率(Precision)

精确率是指模型预测为正例中实际确实是正例的比例。
Precision = TP TP + FP = 25 25 + 5 = 25 30 = 0.8333 \text{Precision} = \frac{\text{TP}}{\text{TP} + \text{FP}} = \frac{25}{25 + 5} = \frac{25}{30} = 0.8333 Precision=TP+FPTP=25+525=3025=0.8333

计算召回率(Recall)

召回率是指实际正例中被模型正确识别出来的比例。
Recall = TP TP + FN = 25 25 + 10 = 25 35 = 0.7143 \text{Recall} = \frac{\text{TP}}{\text{TP} + \text{FN}} = \frac{25}{25 + 10} = \frac{25}{35} = 0.7143 Recall=TP+FNTP=25+1025=3525=0.7143

计算F1分数 (F1 Score)

F1分数结合了精确率和召回率,公式如下:
F1 Score = 2 × Precision × Recall Precision + Recall \text{F1 Score} = 2 \times \frac{\text{Precision} \times \text{Recall}}{\text{Precision} + \text{Recall}} F1 Score=2×Precision+RecallPrecision×Recall
将上面计算的精确率和召回率代入公式中:
F1 Score = 2 × 0.8333 × 0.7143 0.8333 + 0.7143 ≈ 2 × 0.5972 1.5476 ≈ 2 × 0.3864 = 0.7728 \text{F1 Score} = 2 \times \frac{0.8333 \times 0.7143}{0.8333 + 0.7143} \approx 2 \times \frac{0.5972}{1.5476} \approx 2 \times 0.3864 = 0.7728 F1 Score=2×0.8333+0.71430.8333×0.71432×1.54760.59722×0.3864=0.7728

因此,基于这个示例,模型的F1分数大约为0.7728。F1分数越接近1,表明模型在精确率和召回率方面的综合性能越好。

  • 由于本人水平有限,难免出现错漏,敬请批评改正。
  • 更多精彩内容,可点击进入人工智能知识点专栏、Python日常小操作专栏、OpenCV-Python小应用专栏、YOLO系列专栏、自然语言处理专栏或我的个人主页查看
  • 基于DETR的人脸伪装检测
  • YOLOv7训练自己的数据集(口罩检测)
  • YOLOv8训练自己的数据集(足球检测)
  • YOLOv5:TensorRT加速YOLOv5模型推理
  • YOLOv5:IoU、GIoU、DIoU、CIoU、EIoU
  • 玩转Jetson Nano(五):TensorRT加速YOLOv5目标检测
  • YOLOv5:添加SE、CBAM、CoordAtt、ECA注意力机制
  • YOLOv5:yolov5s.yaml配置文件解读、增加小目标检测层
  • Python将COCO格式实例分割数据集转换为YOLO格式实例分割数据集
  • YOLOv5:使用7.0版本训练自己的实例分割模型(车辆、行人、路标、车道线等实例分割)
  • 使用Kaggle GPU资源免费体验Stable Diffusion开源项目

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/793577.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

君子签电子合同推动企业人事管理变革,降本提效

在日益复杂的人力资源管理领域,合同签署与管理成为HR面临的一大挑战。面对庞大的合同量、繁琐的审批流程、频繁的岗位变动以及离职时的合同管理难题,传统方式已难以满足高效、安全、合规的需求。 君子签针对HR面临的挑战和需求,打造智能合同…

Alertmanager告警配置

1、告警概述及说明 告警能力在Prometheus的架构中被划分成两个独立的部分。 通过在Prometheus中定义AlertRule(告警规则),Prometheus会周期性的对告警规则进行计算,如果满足告警触发条件就会向Alertmanager发送告警信息。 当Alertmanager接收到 Promethe…

java项目如何配置不同环境变量 以及 原理

如何配置不同的profile 首先,一个java项目,需要有不同的环境配置,打包时,自动使用对应的配置。那么,如何实现呢? 在你的Spring Boot项目的src/main/resources目录下创建或添加一个application.yml文件。这…

2024前端面试题之Vue3

2024前端面试题之Vue3 在面试具有五年经验的前端工程师时,对于 Vue 3 的掌握程度是一个重要的考核点。本文将提供一系列针对这一级别工程师的 Vue 3 面试题,并附上详细的解析,帮助面试官全面评估候选人的技术实力和项目经验。 一、Vue 3 基础…

科普文:微服务之服务网格Service Mesh

一、ServiceMesh概念 背景 随着业务的发展,传统单体应用的问题越来越严重: 单体应用代码库庞大,不易于理解和修改持续部署困难,由于单体应用各组件间依赖性强,只要其中任何一个组件发生更改,将重新部署整…

shell脚本之if/case语句

一、条件测试 1、1 返回码 $? $? :返回码,用来判断命令或者脚本是否执行成功。 0 :表示true ,成功;非0 则表示flase ,失败。 1、2 test命令 可以进行条件测试,然后根据返回值来判断条件是否成立 -e…

第2关 Python 基础知识

第2关 Python 基础知识 前言Python实现wordcountSSH远程连接开发机Bug记录 前言 本文是由上海人工智能实验室主办的第三期书生大模型实战营的笔记,仅供个人和助教批改作业参考,教程原文链接。 报名请在微信搜索“第三期书生大模型实战营”。 本笔记是在…

BatchNorm LayerNorm

0. Abstract 很早以前就遇到了 BatchNorm 和 LayerNorm, 当时只是粗略地知道它们是对数据进行了标准化: x x − μ σ \bm{x} \frac{\bm{x} - \bm{\mu}}{\bm{\sigma}} xσx−μ​ 这当然很简单, 但实际的数据是比较复杂的. 对于 CV 任务的数据 image 而言, 一个 batch 的数…

linux系统操作/基本命令/vim/权限修改/用户建立

Linux的目录结构: 一:在Linux系统中,路径之间的层级关系,使用:/来表示 注意:1、开头的/表示根目录 2、后面的/表示层级关系 二:在windows系统中,路径之间的层级关系,使用:\来表示 注意:1、D:表示…

【技术追踪】HiDiff:医学图像分割的混合扩散框架(TMI-2024)

传统分割方法与扩散分割方法结合,做大做强~ HiDiff:一种用于医学图像分割的新型混合扩散框架,它可以协同现有判别分割模型和新型生成扩散模型的优势,在腹部器官、脑肿瘤、息肉和视网膜血管分割数据集上性能表现 SOTA !…

【eNSP模拟实验】三层交换机实现VLAN通信

实验需求 让PC1和PC2能够互相通讯&#xff0c;其中PC1在vlan10中&#xff0c;PC2在vlan20中。 实验操作 首先把PC1和PC2都配置好ip&#xff0c;配置好之后&#xff0c;点击右下角的应用 然后&#xff0c;在S2交换机&#xff08;S3700&#xff09;上做如下配置 #进入系统 <…

Java基础-组件及事件处理(下)

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;请留下您的足迹&#xff09; 目录 面板组件 说明 常见组件 JScrollPane常用构造方法 JScrollPane设置面板滚动策略的方法 JScrollPane滚…

进程调度篇

在操作系统的广阔领域中&#xff0c;进程调度是其中一个至关重要的环节。它如同操作系统的“交通警察”&#xff0c;负责在多个等待CPU执行的进程间进行高效、公平的分配。本文将带您了解进程调度的基本概念、重要性、常用算法…… 1. 进程调度的基本概念 1.1 进程调度的定义 …

HTAP 数据库在国有大行反洗钱场景的应用

导读 在金融领域&#xff0c;随着数字化服务的深入和监管要求的提高&#xff0c;反洗钱工作变得尤为关键。洗钱活动不仅威胁金融安全&#xff0c;也对社会秩序构成挑战。本文深入探讨了国产 HTAP 分布式数据库 TiDB 在某国有大行反洗钱系统中的应用实践。 依托 TiDB 构建的新…

c++初阶知识——类和对象(1)

目录 1.类和对象 1.1 类的定义 1.2 访问限定符 1.3 类域 2.实例化 2.1 实例化概念 2.2 对象大小 内存对齐规则 3.this指针 1.类和对象 1.1 类的定义 &#xff08;1&#xff09;class为定义类的关键字&#xff0c;Stack为类的名字&#xff0c;{}中为类的主体&#xf…

python怎么调用cmd命令

关于python调用cmd命令&#xff1a; 1、python的OS模块 OS模块调用CMD命令有两种方式&#xff1a;os.popen()、os.system()都是用当前进程来调用。 OS.system是无法获取返回值的。当运行结束后接着往下面执行程序。用法如&#xff1a;OS.system("ipconfig"). OS.…

前台线程和后台线程(了解篇)

在多线程编程中&#xff0c;理解线程的不同类型对于编写高效、稳定的程序至关重要。特别地&#xff0c;前台线程&#xff08;Foreground Threads&#xff09;与后台线程&#xff08;Background Threads&#xff09;在行为上有着根本的区别&#xff0c;这些区别直接影响到程序的…

【Linux 线程】线程的基本概念、LWP的理解

文章目录 一、ps -L 指令&#x1f34e;二、线程控制 一、ps -L 指令&#x1f34e; &#x1f427; 使用 ps -L 命令查看轻量级进程信息&#xff1b;&#x1f427; pthread_self() 用于获取用户态线程的 tid&#xff0c;而并非轻量级进程ID&#xff1b;&#x1f427; getpid() 用…

(CVPR-2024)SwiftBrush:具有变分分数蒸馏的单步文本到图像扩散模型

SwiftBrush&#xff1a;具有变分分数蒸馏的单步文本到图像扩散模型 Paper Title&#xff1a;SwiftBrush: One-Step Text-to-Image Diffusion Model with Variational Score Distillation Paper 是 VinAI Research 发表在 CVPR 24 的工作 Paper地址 Code:地址 Abstract 尽管文本…

前端工程化(01):10款自动化构建工具初识。

前端工程化自动化构建工具是用于简化前端开发流程、提高开发效率和优化项目质量的工具。市面上的工具多种多样&#xff0c;贝格前端工场先介绍一下什么是前端工程化&#xff0c;为什么要前端工程化&#xff0c;以及常用工具&#xff0c;后面会对各种工具逐一介绍。 一、什么是…