WA、UAR、F1和sklearn自带的函数

2024-03-11 11:30
文章标签 函数 自带 f1 sklearn wa uar

本文主要是介绍WA、UAR、F1和sklearn自带的函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

多分类问题中常用的评价指标。

目录

1.WA(weighted accuracy)加权准确率

2.UAR(unweighted average recall)未加权平均召回率

3.F1分数

4.使用sklearn进行计算

5.适用场景

6.其他


1.WA(weighted accuracy)加权准确率

在多分类问题中,加权准确率(Weighted Accuracy)是一种考虑每个类别样本数量的准确率计算方式。对于样本不均衡的情况,该方式比较适用。其计算方式是将每个类别的准确率乘以该类别在总样本中的比例(权重),然后求和。

其实就是我们日常跑代码出来的acc

计算公式如下:

WA = \frac{\sum (TP_i) }{\sum (TP_i + FP_i + FN_i)}

其中,TP_i 是第 i 类的真正例数量,FP_i 是第 i 类的假正例数量,FN_i 是第 i 类的假反例数量。Σ 表示对所有类别求和。

2.UAR(unweighted average recall)未加权平均召回率

是一种性能评估指标,主要用于多分类问题。它表示各类别的平均召回率(Recall),在计算时,不对各类别进行加权。对于每个类别,召回率是该类别中真正被正确预测的样本数与该类别中所有样本数的比值。

UAR在评估一个分类器时,对每个类别都给予相同的重要性,而不考虑各类别的样本数量。这使得UAR在处理不平衡数据集时具有一定的优势,因为它不会受到数量较多的类别的影响。

计算公式如下:

UAR = \frac{1}{N}* \sum (Recall_i)

其中,Recall_i 是第 i 类的召回率,N 是类别的总数。

3.F1分数

F1分数是精确率(Precision)和召回率(Recall)的调和平均值。在多分类问题中,通常会计算每个类别的F1分数,然后取平均值作为总体的F1分数。平均方法可以是简单的算术平均(Macro-F1)(常用),也可以是根据每个类别的样本数量进行加权的平均(Weighted-F1)。

计算公式如下:

F1 = \frac{2 * Precision * Recall }{(Precision + Recall)}

4.使用sklearn进行计算

from sklearn.metrics import classification_report

使用👆导入的包,模型输出预测值y_pred和真实值y_test得到report如下:

report = classification_report(y_test, y_pred)
              precision    recall  f1-score   support0       0.89      0.80      0.84        101       0.60      0.75      0.67         82       0.92      0.85      0.88        13accuracy                           0.81        31macro avg       0.80      0.80      0.80        31
weighted avg       0.83      0.81      0.82        31

"macro avg"行表示,对于精度(precision),召回率(recall)和F1分数(f1-score),它们的未加权平均值分别是0.80、0.80和0.80。

"weighted avg"行表示,对于精度(precision),召回率(recall)和F1分数(f1-score),它们的加权平均值分别是0.83、0.81和0.82。加权平均是根据每个类别的样本数进行加权的,所以在这个案例中,类别2(有13个样本)的影响力大于类别0(10个样本)和类别1(8个样本)。

accuracy,可以视作每个类别的权重都一样的加权准确率。

5.适用场景

在类别不平衡的情况下,UAR 和 F1 分数通常比准确率更能反映模型的性能。

6.其他

精确率(Precision)和准确率(Accuracy)都是评价模型性能的重要指标,但是他们衡量的角度不同。

准确率(Accuracy):是所有预测正确的样本(真正例TP和真负例TN)占总样本数(TP+TN+FP+FN)的比例。它适用于正负样本比例相当的情况。在正负样本极度不均衡的情况下,准确率就没有太大的意义。

   Accuracy = (TP+TN) / (TP+TN+FP+FN)

精确率(Precision):是预测为正且预测正确的样本(真正例TP)占所有预测为正的样本数(TP+FP)的比例。它适用于关注假正例(FP,即将负例错误预测为正例)的情况。

   Precision = TP / (TP+FP)

举个例子,假设有100个邮件,其中95个是垃圾邮件,5个是正常邮件。如果模型预测所有邮件都是垃圾邮件,那么准确率是95%(因为正确预测了95个垃圾邮件),但是精确率就是0%(因为没有预测出任何正常邮件)。所以在不同的场景和需求下,我们需要根据实际情况选择合适的评价指标。

这篇关于WA、UAR、F1和sklearn自带的函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/797679

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五