一、分类评估指标

  1. 准确率(最直白的指标)
    缺点:受采样影响极大,比如100个样本中有99个为正例,所以即使模型很无脑地预测全部样本为正例,依然有99%的正确率
    适用范围:二分类(准确率);二分类、多分类(平均准确率)

    from sklearn.metrics import accuracy_score
    y_pred = [0, 2, 1, 3]
    y_true = [0, 1, 2, 3]
    accuracy_score(y_true, y_pred)
    0.5
    accuracy_score(y_true, y_pred, normalize=False)
    2
    from sklearn.metrics import balanced_accuracy_score
    y_true = [0, 1, 0, 0, 1, 0]
    y_pred = [0, 1, 0, 0, 0, 1]
    balanced_accuracy_score(y_true, y_pred)
    0.625
  2. 混淆矩阵
    适用范围:所有分类模型,包括二分类、多分类
    介绍:实质是一张交叉表,纵轴为真实值,横轴为预测值
    API介绍:

    Example1:多分类任务,类别已经转换为整数类型,分别为0,1,2三个类别

    from sklearn.metrics import confusion_matrix
    y_true = [2, 0, 2, 2, 0, 1]
    y_pred = [0, 0, 2, 2, 0, 2]
    confusion_matrix(y_true, y_pred)
    array([[2, 0, 0],
    [0, 0, 1],
    [1, 0, 2]])

    可以推导出混淆矩阵如下所示

    Example2:多分类任务,类别没有转换为整型数值,而是作为字符串直接传入

    from sklearn.metrics import confusion_matrix
    y_true = ["cat", "ant", "cat", "cat", "ant", "bird"]
    y_pred = ["ant", "ant", "cat", "cat", "ant", "cat"]
    confusion_matrix(y_true, y_pred, labels=["ant", "bird", "cat"])
    array([[2, 0, 0],
    [0, 0, 1],
    [1, 0, 2]])

    证明该API可以直接传入类别型字符串,混淆矩阵如下所示

    Example3:二分类任务

    from sklearn.metrics import confusion_matrix
    
    confusion_matrix([0, 1, 0, 1], [1, 1, 1, 0])
    array([[0, 2],
    [1, 1]], dtype=int64) tn, fp, fn, tp = confusion_matrix([0, 1, 0, 1], [1, 1, 1, 0]).ravel()
    (tn, fp, fn, tp)
    (0, 2, 1, 1)


    此处“1”为正例,“0”为反例

  3. Roc曲线及auc值
    适用范围:二分类
    介绍:roc曲线为二维平面的一条曲线,横坐标为fpr,纵坐标为tpr,auc(area under the curve)顾名思义,即为曲线与横轴围成的曲线下的面积
    API:
    sklearn中有三个关于roc计算相关的接口,分别为

     metrics.roc_auc_score()
    metrics.roc_curve()
    metrics.auc()

    1)直接计算auc的值

    from sklearn import metrics
    import numpy as np
    y_true = np.array([0, 0, 1, 1])
    y_scores = np.array([0.1, 0.4, 0.35, 0.8])
    metrics.roc_auc_score(y_true, y_scores)
    0.75

    2)先计算fpr,tpr以及threshold(阈值),再通过fpr和tpr求auc

    from sklearn import metrics
    import numpy as np y_true = np.array([0, 0, 1, 1])
    y_scores = np.array([0.1, 0.4, 0.35, 0.8])
    fpr, tpr, threshold = metrics.roc_curve(y_true, y_scores)
    (fpr, tpr, threshold)
    (array([0. , 0.5, 0.5, 1. ]),
    array([0.5, 0.5, 1. , 1. ]),
    array([0.8 , 0.4 , 0.35, 0.1 ]))
    metrics.auc(fpr, tpr)
    0.75

    注意接口接收的参数为类别的真实标签以及模型输出的概率(得分)值,而非模型预测的标签(标签需要通过概率+阈值来得到)

  4. PR曲线及F1-score
    PR曲线为二维平面曲线,横轴为Recall(召回率),纵轴为Precision(精确率),F1-score为recall和precision的调和平均数
    适用范围:二分类
    API:
    sklearn中有五个常用的与PR相关的接口
     metrics.precision_recall_curve()
    metrics.precision_recall_fscore_support()
    metrics.precision_score()
    metrics.recall_score()
    metrics.fbeta_score()

    1)计算pr曲线
    接口接收两个参数,其一为样本的真实值,另一个为样本的预测概率(得分),示例如下:

    import numpy as np
    from sklearn.metrics import precision_recall_curve y_true = np.array([0, 0, 1, 1])
    y_scores = np.array([0.1, 0.4, 0.35, 0.8])
    precision, recall, thresholds = precision_recall_curve(y_true, y_scores)
    precision, recall, thresholds
    (array([0.66666667, 0.5 , 1. , 1. ]),
    array([1. , 0.5, 0.5, 0. ]),
    array([0.35, 0.4 , 0.8 ]))

    2)计算当预测值已经通过阈值转化为类别后的具体某一阈值下的PR及F-score值

    from sklearn import metrics
    
    #该函数可直接求出precision、recall和f-score
    precision,recall,fbeta_score,support = metrics.precision_recall_fscore_support()
    #以下三个函数可分别求出precision、recall和f-score 
    precision = metrics.precision_score() 
    recall = metrics.recall_score() 
    f-score = metrics.fbeta_score()
  5. ks曲线及ks值
    适用范围:二分类
    ks曲线的横坐标为阈值的分位数,纵坐标分别为tpr,fpr,ks值(tpr-fpr),所以可用2中与ROC相关的接口计算得出
  6. kappa系数、汉明损失、铰链损失、杰卡德相关系数
    适用范围:多分类
     metrics.cohen_kappa_score()
    metrics.hamming_loss()
    metrics.hinge_loss()
    metrics.jaccard_score()
    metrics.log_loss()
  7. 马修斯相关系数(MCC)
    适用范围:二分类
    from sklearn.metrics import matthews_corrcoef
    
    y_true = [+1, +1, +1, -1]
    y_pred = [+1, -1, +1, +1]
    matthews_corrcoef(y_true, y_pred)
    -0.33333333

二、回归评估指标

  1. R2
  2. MSE
  3. MAE
    睡了。。。明天再修改

基于sklearn的metrics库的常用有监督模型评估指标学习的更多相关文章

  1. Python机器学习笔记:常用评估指标的用法

    在机器学习中,性能指标(Metrics)是衡量一个模型好坏的关键,通过衡量模型输出y_predict和y_true之间的某种“距离”得出的. 对学习器的泛化性能进行评估,不仅需要有效可行的试验估计方法 ...

  2. Spark ML机器学习库评估指标示例

    本文主要对 Spark ML库下模型评估指标的讲解,以下代码均以Jupyter Notebook进行讲解,Spark版本为2.4.5.模型评估指标位于包org.apache.spark.ml.eval ...

  3. 数据挖掘入门系列教程(九)之基于sklearn的SVM使用

    目录 介绍 基于SVM对MINIST数据集进行分类 使用SVM SVM分析垃圾邮件 加载数据集 分词 构建词云 构建数据集 进行训练 交叉验证 炼丹术 总结 参考 介绍 在上一篇博客:数据挖掘入门系列 ...

  4. 基于sklearn和keras的数据切分与交叉验证

    在训练深度学习模型的时候,通常将数据集切分为训练集和验证集.Keras提供了两种评估模型性能的方法: 使用自动切分的验证集 使用手动切分的验证集 一.自动切分 在Keras中,可以从数据集中切分出一部 ...

  5. 基于sklearn的分类器实战

    已迁移到我新博客,阅读体验更佳基于sklearn的分类器实战 完整代码实现见github:click me 一.实验说明 1.1 任务描述 1.2 数据说明 一共有十个数据集,数据集中的数据属性有全部 ...

  6. 机器学习--PCA算法代码实现(基于Sklearn的PCA代码实现)

    一.基于Sklearn的PCA代码实现 import numpy as np import matplotlib.pyplot as plt from sklearn import datasets ...

  7. Element没更新了?Element没更新,基于El的扩展库更新

    think-vuele 基于Vue和ElementUI框架进行整合二次开发的一个框架.提供一些elementUI没有的或当时没有的控件.优化了或简化了便于2B软件开发的一些控件 demo:http:/ ...

  8. 基于Qt的第三方库和控件

    ====================== 基于Qt的第三方库和控件 ======================     libQxt --------   http://dev.libqxt.o ...

  9. Boost正则表达式库regex常用search和match示例 - 编程语言 - 开发者第2241727个问答

    Boost正则表达式库regex常用search和match示例 - 编程语言 - 开发者第2241727个问答 Boost正则表达式库regex常用search和match示例 发表回复   Boo ...

随机推荐

  1. maven中 pom 文件各个标签的作用

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  2. JDK5.0 Annotation学习笔记(一)

    背景知识:         从JDK5开始提供名为Annotation(注释)的功能,它被定义为JSR-175规范.注释是以"@注释名"在代码中存在的,还可以添加一些参数值,例如: ...

  3. Struts2加载自定义库注意事项

    新建Struts2项目,添加Struts2的jar包时,往往通过导入自定义库的方式,导入自定义库时,有个地方必须要设置,否则项目无法正常执行,如图所示: 必须要按照上述方式对自定义库进行加载!

  4. 关于使用MyEclipse自动生成Hibernate和Struts出现的jar不兼容的问题(antlr.collections.AST.getLine()I)

    今天做Hibernate和Struts2结合的练习,使用MyEclipse自动创建Hibernate和Struts的相关配置文件和jar包,写完一个查询方法后,准备测试一下结果,简单的查询那种,很诡异 ...

  5. ccpc20190823

    04 http://acm.hdu.edu.cn/showproblem.php?pid=6705 分析:先把每条边以 形式放进堆,堆按路径权值从小到大排序,然后每次取出堆顶,用v的出边扩展 新的路径 ...

  6. spring和mybatis整合报错:org.springframework.beans.MethodInvocationException: Property 'dataSource' threw exception; nested exception is java.lang.NoClassDefFoundError

    Exception in thread "main" org.springframework.beans.factory.UnsatisfiedDependencyExceptio ...

  7. java基础之异常 · fossi

    在开发中,异常处理是一个不可绕开的话题,我们对于异常的处理已经非常熟练了,对于异常本身的概念.用法等不再赘述了,直接结合面试问题来加深对异常的理解吧. Throwable 可以用来表示任何可以作为异常 ...

  8. [LC] 168. Excel Sheet Column Title

    Given a positive integer, return its corresponding column title as appear in an Excel sheet. For exa ...

  9. UFT安装目录简单介绍

    1.在安装的help目录下可查看UFT相关的文档 2.在samples/filght/app目录下可看到UFT自带的用作测试的软件

  10. shell-变量学习-01

    1.变量   1.1 变量赋值 > variable_zhou="hello world!" #等号两边不能有空格   1.2 使用变量 > echo $variabl ...