手写IoU(u音标手写怎么写)

IoU(IntersectionoverUnion)矩形框的IoU计算:矩阵T的左下角坐标,右上角坐标;矩阵G的左下角坐标,右上角坐标;在确定坐标的情况下,与是可知的常量,所以,我们只需要求解即可。这里我们先来看一下水平方向上的情况:从上述的三种情况中我们可以看出:当有重叠或者是内含的情况时,我们可以通过计算得到重叠部分的长度….

大家好,又见面了,我是你们的朋友全栈君。

IoU(Intersection over Union)

矩形框的IoU计算:

        手写IoU(u音标手写怎么写)

矩阵T的左下角坐标(X_{0},Y_{0}),右上角坐标(X_{1},Y_{1})

矩阵G的左下角坐标(A_{0},B_{0}),右上角坐标(A_{1},B_{1})

IoU = \frac{area(ROI_{T})\bigcap area(ROI_{G})}{S_{XY}+S_{AB}-area(ROI_{T})\bigcap area(ROI_{G})}

在确定坐标的情况下,S_{XY}S_{AB}是可知的常量,所以,我们只需要求解area(ROI_{T})\bigcap area(ROI_{G})即可。

这里我们先来看一下水平方向上的情况:

手写IoU(u音标手写怎么写)

从上述的三种情况中我们可以看出: 

当有重叠或者是内含的情况时,我们可以通过  W = min(X_{1},A_{1}) - max(X_{0},A_{0})  计算得到重叠部分的长度.

当满足第一种情况时,发现W<=0.

竖直方向上的处理方式类似,得到H.

代码:

A:
左下角坐标(left_x,left_y)
右上角坐标(right_x,right_y)
B:
左下角坐标(left_x,left_y)
右上角坐标(right_x,right_y)

def IOU(rectangle A, rectangleB):
    W = min(A.right_x, B.right_x) - max(A.left_x, B.left_x)
    H = min(A.right_y, B.right_y) - max(A.left_y, B.left_y)
    if W <= 0 or H <= 0:
        return 0;
    SA = (A.right_x - A.left_x) * (A.right_y - A.left_y)
    SB = (B.right_x - B.left_x) * (B.right_y - B.left_y)
    cross = W * H
    return cross/(SA + SB - cross)

语义分割的IoU计算:

IoU一般都是基于类进行计算的,也有基于图片计算的。一定要看清数据集的评价标准。
基于类进行计算的IoU就是将每一类的IoU计算之后累加,再进行平均,得到的就是基于全局的评价,所以我们求的IoU其实是取了均值的IoU,也就是均交并比(mean IoU)

计算公式一样:

                     手写IoU(u音标手写怎么写)

手写IoU(u音标手写怎么写)

 先贴代码:

def compute_ious(pred, label, classes):
    '''computes iou for one ground truth mask and predicted mask'''
    ious = [] # 记录每一类的iou
    for c in classes:
        label_c = (label == c) # label_c为true/false矩阵
        pred_c = (pred == c)
        intersection = np.logical_and(pred_c, label_c).sum()
        union = np.logical_or(pred_c, label_c).sum()
        if union == 0:
            ious.append(float('nan'))  
        else
            ious.append(intersection / union)
    return np.nanmean(ious) #返回当前图片里所有类的mean iou

def compute_iou_batch(preds, labels, classes=None):
    '''computes mean iou for a batch of ground truth masks and predicted masks'''
    ious = []
    preds = np.copy(preds) # copy is imp
    labels = np.array(labels) # tensor to np
    for pred, label in zip(preds, labels): # iter one batch
        ious.append(compute_ious(pred, label, classes))
    iou = np.nanmean(ious) # mean iou of one batch
    return iou

基于类计算的IoU时,输入pred和label的size可以有多种形式:

假设原图大小为(256\times 1600),期望识别的目标有四种,label的形式是一张图片对应一份mask[0,1,2,3,4],0代表背景类。则根据label生成的mask为(1\times256\times1600),这层mask的取值为0/1/2/3/4,则pred和label的大小都是(1\times256\times1600)classes=[1,2,3,4],这里忽略背景类classes=[0]的计算。此时,分别对class=1,2,3,4计算iou,并返回它们的均值。代码如上。

假设原图大小为(256\times 1600),期望识别的目标有四种,label的形式是一张图片对应四份二进制mask[0,1],则根据label生成的mask为(4\times256\times1600),这四层mask的取值为0/1,则pred和label的大小都是(4\times256\times1600)classes=[1]。此时,一起计算四类的iou,并返回。即上述代码中compute_ious里的ious只有一个值。(不要问我为什么要这样处理标签,做的一个比赛给的标签就是这样的orz…)

至于基于图片怎么计算IoU,暂时还没用到.

参考:语义分割的评价指标——IoU

           两个矩形的交并比(IOU)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128817.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MATLAB画图颜色渐变「建议收藏」

    MATLAB画图颜色渐变「建议收藏」原文(https://wenku.baidu.com/view/bf87a9d5804d2b160a4ec03f.html)1渐变1.1t=[linspace(0,2*pi)nan];x=sin(t);y=cos(2*t);z=sqrt(t);%所要绘制的曲线方程patch(x,y,z,z,’edgecolor’,’flat’,’facecolor’,’none’)vi…

    2022年5月31日
    276
  • 精彩编码 【进制转换】

    精彩编码 【进制转换】

    2022年1月10日
    49
  • 【哈佛幸福课笔记】【1】

    【哈佛幸福课笔记】【1】【哈佛幸福课笔记】【1】​​ 一个月的时间看完了哈佛幸福课,正如Tal所说课程的结束才是学习的开始。对于课程观点的思考,对于个人习惯的培养,对于思维模式的转变还需要花大量的时间去练习。这个系列的帖子将作为我个人的读书笔记,也欢迎机缘巧合点开这个帖子的网友一起讨论。(第一章思维导图)​ 课程在讲述的时候有时候并不是线性完整的逻辑,一个观点有时尚没讲完会进入到新的观点中,这样课程显得不是那么的死板不是单纯的说教而是有趣的互动和对实验数据的分析。课程整体的结构十分清晰,可以说干货很多。1.关于内部

    2022年7月25日
    6
  • QuoteName\生成Sql语句

    QuoteName\生成Sql语句ifexists(selectnamefromtempdb.dbo.sysobjectswhereid=object_id(N’tempdb.dbo.#tempWorkDate’)andtype=’u’)droptable#tempWorkDateCREATETABLE[#tempWorkDate]([WorkDate][varc…

    2022年7月25日
    7
  • 【shell案例】CentOS7安装MySQL脚本案例

    【shell案例】CentOS7安装MySQL脚本案例前言此脚本为一个学员在工作中遇到在centos7中安装mysql的问题,于是安排一个学员花了15分钟写了一个脚本,可以正常安装使用。mysql的版本为5.7版本此脚本涉及到安装好mysql后,日志中没有临时密码的问题,所以该学员使用了破解mysql密码登陆修改去修改密码的方法,也算是一种好方法,在工作中,能解决问题才是根本,其他的技巧都是扯淡。虽然脚本还存在一些问题,但测试后发现可以正常安装,敢写就是一种进步。脚本源码因时间紧张,该学员未加注释,但我相信只要学完了shell基础的小伙伴都可以看懂

    2022年5月27日
    31
  • 在 Ubuntu 12.04 上通过安装源安装 Open vSwitch (OVS)

    在 Ubuntu 12.04 上通过安装源安装 Open vSwitch (OVS)

    2021年12月9日
    77

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号