混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等)

这篇具有很好参考价值的文章主要介绍了混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

a = [200, 2  , 20 , 1  , 9  , 000, 000, 1  ]
b = [6  , 50 , 10 , 2  , 20 , 000, 4  , 6  ]
c = [12 , 6  , 300, 5  , 5  , 000, 000, 11 ]
d = [1  , 1  , 3  , 50 , 9  , 000, 000, 18 ]
e = [4  , 2  , 6  , 2  , 300, 7  , 1  , 22 ]
f = [000, 1  , 2  , 1  , 30 , 80 , 2  , 9  ]
g = [1  , 5  , 3  , 2  , 10 , 10 , 24 , 4  ]
h = [1  , 3  , 15 , 5  , 30 , 5  , 2  , 300]

Confusion_Matrix = [
    a, b, c, d, e, f, g, h
]

import copy

def OA(Confusion_Matrix):
    CM = Confusion_Matrix
    xia_list = []
    for i in range(len(CM)):
        xia_list.append(sum(CM[i]))
    xia = sum(xia_list)
    shang_list = []
    for i in range(len(CM)):
        shang_list.append(CM[i][i])
    shang = sum(shang_list)
    OA = shang / xia
    return OA

def KP(Overall_Accuracy, Confusion_Matrix):
    CM = Confusion_Matrix
    p0 = Overall_Accuracy
    pe_xia_list = []
    for i in range(len(CM)):
        pe_xia_list.append(sum(CM[i]))
    pe_xia = sum(pe_xia_list) ** 2
    CMT = list(map(list, zip(*CM))) # 转置
    pe_shang_list = []
    for i in range(len(CM)):
        pe_shang_list.append(sum(CM[i]) * sum(CMT[i]))
    pe_shang = sum(pe_shang_list)
    pe = pe_shang / pe_xia
    KP = (p0 - pe) / (1 - pe)
    return KP

def CE(Class, Confusion_Matrix):
    CM = Confusion_Matrix
    Class_list = CM[Class]
    Commission_list = copy.deepcopy(Class_list)
    del Commission_list[Class]
    CE = sum(Commission_list) / sum(Class_list)
    return CE

def OE(Class, Confusion_Matrix):
    CM = Confusion_Matrix
    CMT = list(map(list, zip(*CM))) # 转置
    Class_list = CMT[Class]
    Ommission_list = copy.deepcopy(Class_list)
    del Ommission_list[Class]
    OE = sum(Ommission_list) / sum(Class_list)
    return OE

# 总体精度
Overall_Accuracy = OA(Confusion_Matrix)
print("总体精度:",Overall_Accuracy)
# 卡帕系数
Kappa = KP(Overall_Accuracy, Confusion_Matrix)
print("卡帕系数:",Kappa)

# 针对某一类
# 错分误差
Commission_Error = CE(0, Confusion_Matrix) # 第一个参数位写第几类,0是第一类,1是第二类
print("错分误差:",Commission_Error)
# 漏分误差
Omission_Error = OE(0, Confusion_Matrix) # 第一个参数位写第几类,0是第一类,1是第二类
print("漏分误差:",Omission_Error)
# 用户精度
Users_Accuracy = 1 - Commission_Error
print("用户精度:",Users_Accuracy)
# 生产者精度/制图精度
Producers_Accuracy = 1 - Omission_Error
print("生产者精度/制图精度:",Producers_Accuracy)

用户精度 (User’s Accuracy):
假设分类结果的某类别的用户精度为 80%,则用户拿到分类结果后,10个像元中有8个是对的,2个是错的;

生产者精度 (Producer’s Accuracy):
假设分类结果的某类别的生产者精度为 80%,那么如果该类别有10个像素的话,则有2个没有分到该类别(丢失了)。

混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等),Coffee,python,学习

混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等),Coffee,python,学习

混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等),Coffee,python,学习

有一个很好的例子:
图像分类中混淆矩阵精度验证法中的几个指标说明 - GIS知乎-新一代GIS问答社区 (geoscene.cn)文章来源地址https://www.toymoban.com/news/detail-846558.html

到了这里,关于混淆矩阵计算遥感分类精度(总体精度、Kappa系数、用户精度、生产者精度等)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【超详细】机器学习sklearn之分类模型评估 混淆矩阵、ROC曲线、召回率与精度、F1分数

    机器学习之分类模型的评估 学习分类模型评估的方法: 1、混淆矩阵 2、分类结果汇总 3、ROC曲线 4、召回率与精度 5、F1分数 一、评估分类器性能的度量 1、真正(true positive, TP)或f++,对应的是被分类模型正确预测的正样本数。 2、假负(false negative, FN)或f±对应的是被分类模型错

    2023年04月08日
    浏览(89)
  • 【学习笔记】遥感影像分类相关精度指标

    混淆矩阵是分类精度的评定指标。是一个用于表示分为某一类别的像元个数与地面检验为该类别数的比较阵列。 对检核分类精度的样区内所有的像元,统计其分类图中的类别与实际类别之间的混淆程度。 混淆矩阵中,对角线上元素为被正确分类的样本数目,非对角线上的元

    2024年01月22日
    浏览(61)
  • ArcGIS 基于混淆矩阵的精度验证

    问题:之前在使用ArcGIS生成混淆矩阵时,遇到了一定的困难,使用ArcMap中的【计算混淆矩阵】模块不够灵活,经过一定的尝试后,整理出了一个可以完全在ArcMap上进行操作的精度验证方法。 文章主要内容为,使用ArcGIS对分类或其他数据结果,基于混淆矩阵进行精度验证。 1)

    2024年02月12日
    浏览(28)
  • python:多分类-计算混淆矩阵confusion_matrix、precision、recall、f1-score分数

    多分类,计算混淆矩阵confusion_matrix,以及accuracy、precision、recall、f1-score分数。 1)使用sklearn计算并画出 混淆矩阵(confusion_matrix) ; 2)使用sklearn计算 accuracy(accuracy_score) ; 3)使用sklearn计算多分类的 precision、recall、f1-score分数 。以及计算每个类别的precision、recall、f1-

    2024年02月06日
    浏览(40)
  • Python遥感图像处理应用篇(二十四):Python绘制遥感图像各波段热力图(相关系数矩阵)

    给多光谱遥感图像各个波段绘制热力图,首先需要计算波段之间的相关系数矩阵,而计算遥感图像波段相关系数矩阵有不同的方法,常用的我们可以采用遥感图像处理软件计算,比如ENVI软件就可以计算相关系数矩阵,使用工具箱中的Statistics工具即可进行多种统计运算。 我们

    2023年04月09日
    浏览(44)
  • Python遥感图像处理应用篇(二十七):Python绘制遥感图像各波段热力图(相关系数矩阵)(续)

    续-https://soderayer.blog.csdn.net/article/details/125757807 上一篇中使用csv文件计算的相关系数热力图,本篇我们直接使用遥感图像来计算图像波段之间的相关系数。 实际上,目前已有的软件,如ENVI就可以直接计算图像波段之间的相关系数,该工具计算的是合成波段之间的相关系数。如

    2023年04月17日
    浏览(45)
  • Python计算分类问题的评价指标(准确率、精确度、召回率和F1值,Kappa指标)

    机器学习的分类问题常用评论指标有:准确率、精确度、召回率和F1值,还有kappa指标 。 每次调包去找他们的计算代码很麻烦,所以这里一次性定义一个函数,直接计算所有的评价指标。 每次输入预测值和真实值就可以得到上面的指标值,很方便。 下面是这些指标的计算公

    2024年01月21日
    浏览(53)
  • 分类模型之混淆矩阵(Confusion Matrix)

    混淆矩阵是ROC曲线绘制的基础,同时它也是衡量分类型模型准确度中最基本,最直观,计算最简单的方法。 可以简单理解为:将一个分类模型的预测结果与正确结果做对比,将预测正确的统计量和预测错误的统计量分别写入一张矩阵图中,得到的这张图就是混淆矩阵了。 混

    2024年02月03日
    浏览(44)
  • 详细讲解分类模型评价指标(混淆矩阵)python示例

    对于回归模型的评估方法,通常会采用平均绝对误差(MAE)、均方误差(MSE)、平均绝对百分比误差(MAPE)等方法。 对于聚类模型的评估方法,较为常见的一种方法为轮廓系数(Silhouette Coefficient ),该方法从内聚度和分离度两个方面入手,用以评价相同数据基础上不同聚类

    2024年02月06日
    浏览(55)
  • 分类模型评估:混淆矩阵、准确率、召回率、ROC

    在二分类问题中,混淆矩阵被用来度量模型的准确率。因为在二分类问题中单一样本的预测结果只有Yes or No,即:真或者假两种结果,所以全体样本经二分类模型处理后,处理结果不外乎四种情况,每种情况都有一个专门称谓,如果用一个2行2列表格描述,得到的就是“混淆

    2024年02月06日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包