手写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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ubuntu安装cuda和cudnn_ubuntu查看是否安装cuda

    ubuntu安装cuda和cudnn_ubuntu查看是否安装cuda目录1、查看系统推荐的cuda版本2、官网下载cuda软件包3、安装4、环境配置5、验证cuda是否正常1、查看系统推荐的cuda版本查看前应先安装显卡驱动,可以查看NVIDIA显卡驱动安装nvidia-smi这里显示的是cuda11.4版本2、官网下载cuda软件包官网cuda下载对应的cuda版本这里选择11.4.4的版本wgethttps://developer.download.nvidia.com/comput.

    2022年9月23日
    0
  • code blocks使用方法总结「建议收藏」

    code blocks使用方法总结「建议收藏」下载和安装:官网地址:http://www.codeblocks.org/downloadstips:同一个版本有多个安装文件,官网上有对于各个文件的简要介绍。最好选择 mingw-se

    2022年8月4日
    3
  • python进阶(6)深拷贝和浅拷贝[通俗易懂]

    python进阶(6)深拷贝和浅拷贝[通俗易懂]深拷贝和浅拷贝不管对于浅拷贝、还是深拷贝,针对不可变对象str、int、tuple(有点特殊)、boolean,它的内存地址是不变的,拷贝的仅仅是值importcopya=1b=co

    2022年7月28日
    3
  • 什么是波特率,波特率怎么计算[通俗易懂]

    什么是波特率,波特率怎么计算[通俗易懂]✍什么是波特率,波特率怎么计算➹概述:  ☆简而言之,串口传输的波特率即为每秒钟传输二进制的位数。  ☆脱离枯燥乏味的文字描述,我们用波形和数字来看看波特率是什么吧☟。  ☆说明:系统时钟50M,波特率115200。  基础知识:因果系统时钟-50M时钟周期150∗106{{\rm{1}}\over{{\rm{50*1}}{{\rm{0}}^{\rm{6}}}}}50∗1061​假设1个时钟周期可以计数1次(其实FPGA就是这样)50M时钟1s计数5000

    2022年4月20日
    96
  • python下mqtt服务器的搭建_搭建MQTT服务器

    python下mqtt服务器的搭建_搭建MQTT服务器就让我来试试传说中最适用于IOT的MQTT协议。安装虽然搜索资料很多,但大多是MQTT的使用,尽管有搭建服务器的文章,但我感觉写的不太清楚,大多数文章选择了Mosquitto(也许是Eclipse大厂出品的原因)。经过寻找,找到了Nodejs写的mosca,但在Pi上老是安装失败,翻了翻Issues,找到了同作者写的依赖性小,轻量化的aedes。npminstallaedes–save//…

    2022年5月8日
    506
  • 关于unity3d播放flash动画,使用插件uniswf

    关于unity3d播放flash动画,使用插件uniswf

    2021年11月21日
    41

发表回复

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

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