详解计算miou的代码以及混淆矩阵的意义

miou的定义

  1. '''
  2. Mean Intersection over Union(MIoU,均交并比):为语义分割的标准度量。其计算两个集合的交集和并集之比.
  3. 在语义分割的问题中,这两个集合为真实值(ground truth)和预测值(predicted segmentation)。
  4. 这个比例可以变形为正真数(intersection)比上真正、假负、假正(并集)之和。在每个类上计算IoU,之后平均。
  5. 对于21个类别,分别求IOU:
  6. 例如,对于类别1的IOU定义如下:
  7. (1)统计在ground truth中属于类别1的像素数
  8. (2)统计在预测结果中每个类别1的像素数
  9. (1) + (2)就是二者的并集像素数(类比于两块区域的面积加和, 注:二者交集部分的面积加重复了)
  10. 再减去二者的交集(既在ground truth集合中又在预测结果集合中的像素),得到的就是二者的并集(所有跟类别1有关系的像素:包括TP,FP,FN)
  11. 扩展提示:
  12. TP(真正): 预测正确, 预测结果是正类, 真实是正类
  13. FP(假正): 预测错误, 预测结果是正类, 真实是负类
  14. FN(假负): 预测错误, 预测结果是负类, 真实是正类
  15. TN(真负): 预测正确, 预测结果是负类, 真实是负类 #跟类别1无关,所以不包含在并集中
  16. (本例中, 正类:是类别1, 负类:不是类别1)
  17. mIoU:
  18. 对于每个类别计算出的IoU求和取平均
  19. '''
  20. ————————————————
  21. 版权声明:本文为CSDN博主「你吃过卤汁牛肉吗」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
  22. 原文链接:https://blog.csdn.net/u012370185/article/details/94409933
  1. class mIOU:
  2. def __init__(self, num_classes):
  3. self.num_classes = num_classes
  4. self.hist = np.zeros((num_classes, num_classes))
  5. # 返回的是混淆矩阵
  6. def _fast_hist(self, label_pred, label_true):
  7. # 去除背景
  8. # ground truth中所有正确(值在[0, classe_num])的像素label的mask
  9. mask = (label_true >= 0) & (label_true < self.num_classes)
  10. # 计算出每一类(0-n**2-1)中对应的数(0-n**2-1)出现的次数,返回值为(n,n)
  11. # confusion_matrix是一个[num_classes, num_classes]的矩阵,
  12. # confusion_matrix矩阵中(x, y)位置的元素代表该张图片中真实类别为x, 被预测为y的像素个数
  13. '''
  14. 关于下面的混淆矩阵如何计算出来的可能会有些初学者不大理解,笔者根据自己的想法对下面的代码有一定的见解,
  15. 可能有一定错误,欢迎指出
  16. 我们之前得到的是两张由0-num_class-1的数字组成的label,分别对应我们的类别总数
  17. self.num_classes * label_true[mask].astype(int),这段代码通过将label_true[mask]乘以num_class
  18. 第0类还是0,第一类的数字变成num_class(注意这是在原来的图上操作),以此类推,
  19. +label_pred[mask],对于这一步我举个栗子,比如groundtrue是第一类,num_class=21,在之前操作已经将该像素块
  20. 变成21了,如果我预测的还是第一类,则这一像素块变成了22,在bincount函数中,使得数字22的次数增加了1,在后面的reshape中
  21. 数字22对于的就是第二行第第二列,也就是对角线上的(因为混淆矩阵的定义就是对角线上的就是预测正确的,即TP),所以得到了
  22. hist就是混淆矩阵
  23. '''
  24. hist = np.bincount(
  25. self.num_classes * label_true[mask].astype(int) +
  26. label_pred[mask], minlength=self.num_classes ** 2).reshape(self.num_classes, self.num_classes)
  27. return hist
  28. def add_batch(self, predictions, gts):
  29. for lp, lt in zip(predictions, gts):
  30. self.hist += self._fast_hist(lp.flatten(), lt.flatten())
  31. def evaluate(self):
  32. '''
  33. miou = TP / (TP+FN+TN)
  34. 因此下面的式子显然是计算miou的
  35. :return:
  36. '''
  37. iu = np.diag(self.hist) / (self.hist.sum(axis=1) + self.hist.sum(axis=0) - np.diag(self.hist))
  38. return np.nanmean(iu[1:])

详解计算miou的代码以及混淆矩阵的意义的更多相关文章

  1. 训练技巧详解【含有部分代码】Bag of Tricks for Image Classification with Convolutional Neural Networks

    训练技巧详解[含有部分代码]Bag of Tricks for Image Classification with Convolutional Neural Networks 置顶 2018-12-1 ...

  2. SENet详解及Keras复现代码

    转: SENet详解及Keras复现代码 论文地址:https://arxiv.org/pdf/1709.01507.pdf 代码地址:https://github.com/hujie-frank/S ...

  3. rabbitmq五种模式详解(含实现代码)

    一.五种模式详解 1.简单模式(Queue模式) 当生产端发送消息到交换机,交换机根据消息属性发送到队列,消费者监听绑定队列实现消息的接收和消费逻辑编写.简单模式下,强调的一个队列queue只被一个消 ...

  4. Console命令详解,让调试js代码变得更简单

    Firebug是网页开发的利器,能够极大地提升工作效率. 但是,它不太容易上手.我曾经翻译过一篇<Firebug入门指南>,介绍了一些基本用法.今天,继续介绍它的高级用法. ======= ...

  5. [转] Console命令详解,让调试js代码变得更简单

    http://www.cnblogs.com/see7di/archive/2011/11/21/2257442.html Firebug是网页开发的利器,能够极大地提升工作效率. 但是,它不太容易上 ...

  6. Bullet核心类介绍(Bullet 2.82 HelloWorld程序及其详解,附程序代码)

    实验平台:win7,VS2010 先上结果截图: 文章最后附有生成该图的程序. 1. 刚体模拟原理 Bullet作为一个物理引擎,其任务就是刚体模拟(还有可变形体模拟).刚体模拟,就是要计算预测物体的 ...

  7. jquery轮播图详解,40行代码即可简单解决。

    我在两个月以前没有接触过html,css,jquery,javascript.今天我却在这里分享一篇技术贴,可能在技术大牛面前我的文章漏洞百出,也请斧正. 可以看出来,无论是div+css布局还是jq ...

  8. 利用jquery对ajax操作,详解原理(附代码)

    1. jQuery load() 方法 jQuery load() 方法是简单但强大的 AJAX 方法. load() 方法从服务器加载数据,并把返回的数据放入被选元素中. 语法: $(selecto ...

  9. 通俗易懂详解Java代理及代码实战

    一.概述 代理模式是Java常用的设计模式之一,实现代理模式要求代理类和委托类(被代理的类)具有相同的方法(提供相同的服务),代理类对象自身并不实现真正的核心逻辑,而是通过调用委托类对象的相关方法来处 ...

随机推荐

  1. Python包装器

    def func(): print("func body") def f1(arg): print("f1:",arg) def wrapper(b): pri ...

  2. Zookeeper 下 Server 工作状态?

    服务器具有四种状态,分别是 LOOKING.FOLLOWING.LEADING.OBSERVING. 1.LOOKING:寻找 Leader 状态.当服务器处于该状态时,它会认为当前集群中没有 Lea ...

  3. Redis 是单进程单线程的?

    Redis 是单进程单线程的,redis 利用队列技术将并发访问变为串行访问,消 除了传统数据库串行控制的开销.

  4. Leetcode26——删除有序数组中的重复项(双指针法)

    Leetcode26--删除有序数组中的重复项(双指针法) 1. 题目简述 给你一个升序排列的数组 nums ,请你原地 删除重复出现的元素,使每个元素只出现一次 ,返回删除后数组的新长度.元素的相对 ...

  5. 关于个人开源项目(vue app)的一些总结

    关于个人开源项目(vue app)的一些总结 项目地址 https://github.com/BYChoo/record 项目简介 此项目名叫:Record.是以Vue全家桶(vue,vue-rout ...

  6. 记一个ios滚动穿透问题

    直接上代码 <body style="overflow: hidden;-webkit-overflow-scrolling: touch;"> <div id= ...

  7. 安卓性能测试之Lint测试

    pre { direction: ltr; color: rgba(0, 0, 10, 1); text-align: left } pre.western { font-family: " ...

  8. Servlet 3.0以上版本使用@WebServlet注解配置映射

    以前的Servlet都是在web.xml中进行配置,导致web.xml中各个Servlet的映射非常杂乱无章,后期也很难维护 本篇文章将详细阐述如何使用Servlet 3.0的新特性使用@WebSer ...

  9. android的布局xml文件如何添加注释?

    xml布局文件如图添加注释后报错,错误内容如下: 上网查阅xml添加注释的语法规则: XML 中的注释 在 XML 中编写注释的语法与 HTML 的语法很相似: <!--This is a co ...

  10. 学习Java必用的9个网站,最后一个最好用!

    Java语言已经成为IT编程界中一种持久的语言,从主要开放源码网站中统计的每月编程语言排名来看,Java一直位居榜首.因此,我们的程序员不能放弃学习Java呀!今日小编为大家整理了几个关于Java学习 ...