手写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)

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • navicat premium注册和激活码-激活码分享

    (navicat premium注册和激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

  • 【转载】究竟什么才是高精度地图(雷锋网)

    【转载】究竟什么才是高精度地图(雷锋网)原文地址:究竟什么才是高精度地图(一)究竟什么才是高精度地图(二)究竟什么才是高精度地图(三)究竟什么才是高精度地图(一)导语:如果有一张辅助的高精度地图,能否避免特斯拉ModelS的事故?

  • mac键盘快捷键使用大全_苹果电脑shift是哪个键

    mac键盘快捷键使用大全_苹果电脑shift是哪个键为了让初次用Mac的新手和小白们更快地上手,小编整理了一份Mac常用快捷键列表,虽然都是比较基础的入门知识,但也能帮助到大家更快地学习和查找macOS的键盘快捷键,以此提高电脑的操作效率。Mac与Windows的几个不同按键一切开始前,我们先来认识一下苹果Mac键盘上几个陌生的按键,比如⌘(Command/Cmd)、⌥“Option”、⌃“Ctrl”、⇧“Shift”等等。其中最为独特的就是Mac键盘专有的按键⌘,它叫做“Command”键(缩写叫Cmd,

  • Matlab归一化函数(mapminmax)

    Matlab归一化函数(mapminmax)功能:将矩阵的每一行处理成[-1,1]区间。处理需要归一化的m*n矩阵X,归一化后的矩阵记为Y。主要有5种调用形式1.[Y,PS]=mapminmax(X,YMIN,YMAX)其中,YMIN是我们期望归一化后矩阵Y每行的最小值,YMAX是我们期望归一化后矩阵Y每行的最大值。例1:待处理矩阵X=[456;789]我们期望归一化后每行的最小值为0,最大值为1.程序如下…

  • mysql 时区设定_mysql的时区设置「建议收藏」

    mysql 时区设定_mysql的时区设置「建议收藏」IDEA配置mysql数据库时,地址,用户名,密码,数据库名填写之后,点测试连接,提示Serverreturnsinvalidtimezone.Goto’Advanced’tabandset’serverTimezone’prope如图翻译过来就是:服务器返回无效时区。进入“高级”选项卡,手动设置“serverTimezone”属性。网上查询了一下解决方案,原来是要设置时区…

    2022年10月28日
  • python要不要装pycharm-Python和pyCharm安装「建议收藏」

    python要不要装pycharm-Python和pyCharm安装「建议收藏」Python是一种解释型脚本语言,可以应用于以下领域:Web和Internet开发科学计算和统计人工智能教育桌面界面开发软件开发后端开发Python在数据分析、后端开发、人工智能、运维、全栈开发等多方面都具有得天独厚的优势。与其他语言相比,Python无论是在就业薪水方面,还是在市场岗位需求方面,都是当之无愧的黑马。1.Python下载不要点击灰色按钮,这个是Python的最新版本,但不是稳…

发表回复

您的电子邮箱地址不会被公开。

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