怎么样调整分类的阈值

news2024/10/5 13:00:09

调整分类模型的阈值是改变模型对正负类的预测标准的一种方法,常用于提高精确率、召回率或者其他性能指标。以下是如何调整分类阈值的步骤和方法:

PS:阈值是针对预测概率(表示样本属于某个特定类别的可能性来说的

调整分类的阈值步骤和方法:

  1. 理解阈值的作用

    • 分类模型通常输出一个概率值(0到1之间),表示样本属于正类的可能性。
    • 默认阈值通常设为0.5,即如果概率值大于0.5,预测为正类;否则预测为负类。
    • 调整阈值可以改变模型对正负类的预测标准,从而影响假阳性和假阴性率。
  2. 增大阈值精确率增加,召回率减少

    • 减少假阳性(False Positive, FP)

      • 定义:假阳性是指模型预测为正类,但实际为负类的情况。
      • 解释增大阈值意味着模型要求更高的置信度才会将样本预测为正类。因此,一些原本在默认阈值下被预测为正类(但实际为负类)的样本,在更高的阈值下会被重新预测为负类,从而减少假阳性的数量。
    • 增加假阴性(False Negative, FN)

      • 定义:假阴性是指模型预测为负类,但实际为正类的情况。
      • 解释增大阈值意味着一些原本在默认阈值下被正确预测为正类的样本在更高的阈值下可能会被预测为负类。因此,模型会错过一些实际为正类的样本,从而增加假阴性的数量。
    • 举例说明

      假设我们有一个模型的输出概率如下(数值为示例):

      样本实际标签预测概率预测
      A正类0.8正类真阳性
      B负类0.6正类假阳性(减少假阳)
      C正类0.4负类假阴性
      D负类0.3负类真阴性
      E正类0.7正类真阳性(增加假阴)

      默认阈值为 0.5 时:

      • 样本 A、B、E 被预测为正类。
      • 样本 C、D 被预测为负类。
      • 此时,假阳性为 1(样本 B),假阴性为 1(样本 C)。

        如果我们将阈值增大到 0.7:

        • 样本 A、E 被预测为正类。
        • 样本 B、C、D 被预测为负类。
        • 此时,假阳性减少到 0(样本 B 不再是假阳性),但假阴性增加到 2(样本 C 和 E)。

  3. 减小阈值:精确率减少,召回率增加

    • 增加真阳性率(Recall)

      • 定义:真阳性率是指模型正确识别正类样本的比例。
      • 解释:降低阈值会使模型更容易将样本预测为正类,因此能够捕捉更多的真正类(正类)样本,从而提高真阳性率。
    • 增加假阳性率(False Positive Rate)

      • 定义:假阳性率是指模型错误地将负类样本预测为正类的比例。
      • 解释:降低阈值会导致模型将一些本应为负类的样本错误地预测为正类,因此会增加假阳性率。
    • 降低精确率(Precision)

      • 定义:精确率是指模型预测为正类的样本中实际为正类的比例
      • 解释:降低阈值会增加将样本预测为正类的数量,但其中一部分样本可能是假阳性,因此会降低精确率。
    • 影响模型的决策边界

      • 解释:阈值决定了模型在将样本分类为正类或负类时所依据的概率界限。降低阈值会放宽模型对于正类的判定标准,使得更多的样本被预测为正类。
    • 示例说明

      假设我们有一个分类模型,对于一些样本的预测概率如下:

      样本实际标签预测概率预测标签(阈值=0.5)预测标签(阈值=0.3)
      A正类0.8正类正类
      B负类0.3负类正类
      C正类0.6正类正类
      D负类0.2负类正类
      E正类0.7正类正类

      通过降低阈值(例如从0.5降至0.3):

      • 样本 B 和 D 被重新预测为正类,因为它们的预测概率超过了0.3。
      • 这样做会增加真阳性率(Recall),但可能也会增加假阳性率(False Positive Rate),因为更多的负类样本被错误地预测为正类。同时,精确率(Precision)可能会下降,因为模型更容易将样本预测为正类,导致一些预测为正类的样本实际上是假阳性。
  4. 选择最佳阈值

    • 使用ROC曲线(Receiver Operating Characteristic Curve)和AUC(Area Under the Curve):
      • ROC曲线绘制了不同阈值下的真阳性率(召回率)与假阳性率的关系。
      • AUC值越大,模型性能越好。
    • 使用精确率-召回率曲线P-R(Precision-Recall Curve):
      • 绘制了不同阈值下的精确率与召回率的关系。
      • 在平衡精确率和召回率时,这条曲线非常有用。

实际操作示例

假设我们使用Python和Scikit-learn库来调整分类阈值:

import numpy as np
from sklearn.metrics import precision_recall_curve, roc_curve

# 假设 y_true 是真实标签,y_scores 是模型输出的概率值
y_true = np.array([0, 1, 1, 0, 1, 0, 1, 1, 0, 0])
y_scores = np.array([0.1, 0.4, 0.35, 0.8, 0.65, 0.7, 0.2, 0.9, 0.55, 0.3])

# 计算不同阈值下的精确率和召回率
precision, recall, thresholds = precision_recall_curve(y_true, y_scores)

# 计算不同阈值下的假阳性率和真阳性率(用于绘制ROC曲线)
fpr, tpr, roc_thresholds = roc_curve(y_true, y_scores)

# 选择一个新的阈值,例如0.5
new_threshold = 0.5
y_pred = (y_scores >= new_threshold).astype(int)

# 计算新的精确率和召回率
new_precision = np.sum((y_pred == 1) & (y_true == 1)) / np.sum(y_pred == 1)
new_recall = np.sum((y_pred == 1) & (y_true == 1)) / np.sum(y_true == 1)

print(f"New Precision: {new_precision}")
print(f"New Recall: {new_recall}")

小结

通过调整分类阈值,可以在精确率和召回率之间进行权衡,以满足不同的应用需求。实际操作中,可以使用精确率-召回率曲线和ROC曲线来帮助选择最佳的阈值,从而优化模型的性能。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

阿里云OSS文件上传不配置环境变量使用显式AccessKey验证

问题背景 在中阿里云官方文档中介绍文件上传时,推荐配置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。这里用简单的方法,直接在Demo.java中显式指定accessKeyId和accessKeySecret,同时修改OSSClientBuilder()的入参。 解决方法 首先…

秒杀圣经:10Wqps高并发秒杀,16大架构杀招,帮你秒变架构师

高并发下,如何设计秒杀系统?这是一个高频面试题。 在40岁老架构师 尼恩的读者交流群(50)中,最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、shein 希音、shopee、百度、网易的面试资格,遇到很多很重要的面试题…

如何选择TikTok菲律宾直播网络?

为了满足用户对于实时互动的需求,TikTok推出了直播功能,让用户能够与粉丝即时交流。本文将探讨如何选择适合的TikTok菲律宾直播网络,并分析OgLive是否是值得信赖的选择。 TikTok菲律宾直播网络面临的挑战 作为全球领先的短视频平台&#xff…

Redis 中 Set 和 Zset 类型

目录 1.Set类型 1.1 Set集合 1.2 普通命令 1.3 集合操作 1.4 内部编码 1.5 使用场景 2.Zset类型 2.1 Zset有序集合 2.2 普通命令 2.3 集合间操作 2.4 内部编码 2.5 使用场景 1.Set类型 1.1 Set集合 集合类型也是保存多个字符串类型的元素,但是和列表类型不同的是&…

【Android】自定义换肤框架01之皮肤包制作

前言 目前为止,市面上主流的安卓换肤方案,其实原理都是差不多的 虽然大多都号称一行代码集成,但其实想要做到完全适配,并不简单 这个系列,就是让大家从零开始,完全掌握这方面知识,这样才能对…

理解MySQL核心技术:存储过程与函数的强大功能

在大型应用程序和复杂的数据库操作中,存储过程与函数扮演着至关重要的角色。它们不仅可以提高代码的可维护性,还能加强数据库的安全性和性能。本篇文章将深入探讨MySQL存储过程与函数的基础知识、创建、管理及其在实际应用中的优势。 什么是存储过程和函…

数据结构+算法-实现一个计算器

在学习栈的数据结构的时候讲到可以用栈来实现一个计算器的功能,那么这个功能是如何实现的呢? 采用栈模拟得方式来实现一个计算器 要实现如下的功能: 字符串如何转为整数 2.处理加减法 如何处理加减法呢? 5-128 给第一个数字前面放一个号…

Java基础-接口与实现

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 Java 接口 什么是接口? 声明接口 实现接口 继承接口 接口的多继承 标记接口 Java 接口 …

代理模式的实现

1. 引言 1.1 背景 代理模式(Proxy Pattern)是一种常用的设计模式,它允许通过一个代理对象来控制对另一个对象的访问。在面向对象编程的框架中,代理模式被广泛应用,尤其在Spring框架的AOP(面向切面编程&am…

优雅谈大模型:揭开计算机视觉任务神秘面纱

人工智能在第四次工业革命发挥着至关重要的作用,它广泛的融入日常生活,例如Google助手、Siri、智能手机摄像头、社交媒体过滤器、自动标记、医疗成像、导航等,所有这些技术都切实的改进和增强日常活动的便利性和习惯。 大模型技术发展到现在…

基于Java技术的篮球论坛系统

你好呀,我是计算机学姐码农小野!如果有相关需求,可以私信联系我。 开发语言 Java 数据库 MySQL 技术 B/S模式、Java技术 工具 Visual Studio、MySQL数据库开发工具 系统展示 首页 用户注册界面 篮球论坛界面 个人中心界面 摘要 本…

AI助手崛起:开发者的新伙伴还是未来替代者?

你好,我是三桥君。 自从 ChatGPT 问市以来,AI 将取代开发者的声音不绝于耳,至今还是互联网异常火热的问题。 在软件开发领域,生成式人工智能(AIGC)正在改变开发者的工作方式。无论是代码生成、错误检测还是…

【mybatis】mybatisX插件概述

一、主要功能 智能补全与提示 MyBatisX 可以智能地提示和补全 SQL 语句中的关键字、表名、列名等信息,从而显著提高开发效率。代码生成器 虽然 MyBatisX 本身可能不直接提供一个完整的、独立的代码生成器,但它可能集成了或支持与其他代码生成工具&#…

C语言_练习题

求最小公倍数 思路:假设两个数,5和7,那么最小至少也要7吧,所以先假定最小公倍数是两个数之间较大的,然后看7能不能同时整除5和7,不能就加1继续除 int GetLCM(int _num1, int _num2) {int max _num1>_n…

异步主从复制

主从复制的概念 主从复制是一种在数据库系统中常用的数据备份和读取扩展技术,通过将一个数据库服务器(主服务器)上的数据变更自动同步到一个或多个数据库服务器(从服务器)上,以此来实现数据的冗余备份、读…

【CUDA】 扫描 Scan

Scan Scan操作是许多应用程序中常见的操作。扫描操作采用一个二元运算符⊕和一个输入数组并计算输出数组如下: [x0,(x0⊕x1),…,( x0⊕x1⊕…..⊕xn-1)] 分层扫描和多种Scan算法介绍 Kogge-Stones Algorithm Kogge-Stones Algorithm最初是为设计快速加法电路而发…

Android Graphics 显示系统 - 监测、计算FPS的工具及设计分析

“ 在Android图像显示相关的开发、调试、测试过程中,如何能有效地评估画面的流畅度及监测、计算图层渲染显示的实时FPS呢?本篇文章将会提供一种实用、灵巧的思路。” 01 设计初衷 面对开发测试中遇到的卡顿掉帧问题,如何在复现卡顿的过程中持…

黑马的ES课程中的不足

在我自己做项目使用ES的时候,发现了黑马没教的方法,以及一些它项目的小问题 搜索时的匹配方法 这个boolQuery().should 我的项目是通过文章的标题title和内容content来进行搜索 但是黑马它的项目只用了must 如果我们的title和content都用must&#x…

QCustomPlot+ vs2022+ qt

零、printSupport 步骤一:下载QCustomPlot 访问QCustomPlot的官网 QCustomPlot 下载最新版本的源代码。 步骤二:配置项目 创建新的Qt项目: 打开VS2022,创建一个新的Qt Widgets Application项目。 将QCustomPlot源代码添加到项目…

C语言编程与进阶

1.0 C语言关键字 1-1C语言关键字-CSDN博客文章浏览阅读831次,点赞13次,收藏24次。define使用define定义常量return 0;使用define定义宏// define 定义宏,名字是ADD(x,y),x y 是宏的参数int a 10;int b 20;return 0;宏定义的本质是替换&am…