微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python实现IOU计算案例

这篇文章主要介绍了python实现IoU计算案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

计算两个矩形的交并比,通常在检测任务里面可以作为一个检测指标。你的预测bBox和groundtruth之间的差异,就可以通过IoU来体现。很简单的算法实现,我也随便写了一个,嗯,很简单。

1. 使用时,请注意bBox四个数字的顺序(y0,x0,y1,x1),顺序不太一样。

#!/usr/bin/env python # encoding: utf-8 def compute_IoU(rec1, rec2): """ computing IoU :param rec1: (y0, x0, y1, x1), which reflects (top, left, bottom, right) :param rec2: (y0, x0, y1, x1) :return: scala value of IoU """ # computing area of each rectangles S_rec1 = (rec1[2] - rec1[0]) * (rec1[3] - rec1[1]) S_rec2 = (rec2[2] - rec2[0]) * (rec2[3] - rec2[1]) # computing the sum_area sum_area = S_rec1 + S_rec2 # find the each edge of intersect rectangle left_line = max(rec1[1], rec2[1]) right_line = min(rec1[3], rec2[3]) top_line = max(rec1[0], rec2[0]) bottom_line = min(rec1[2], rec2[2]) # judge if there is an intersect if left_line >= right_line or top_line >= bottom_line: return 0 else: intersect = (right_line - left_line) * (bottom_line - top_line) return (intersect / (sum_area - intersect))*1.0 if __name__=='__main__': rect1 = (661, 27, 679, 47) # (top, left, bottom, right) rect2 = (662, 27, 682, 47) IoU = compute_IoU(rect1, rect2) print(IoU)

补充知识:基于Python实现的IoU算法---最简单易懂的代码实现

概念介绍:

交并比:(Intersection over Union)

如上图所示,IoU值定位为两个矩形框面积的交集和并集的比值。即:

交并比的实现也是非常简单的,执行过程如下:

1. 交集形状的宽度计算为:

IoU_W = min(x1,x2,x3,x4)+w1+w2-max(x1,x2,x3,x4)

2. 交集形状的高度计算为:

IoU_H = min(y1,y2,y3,y4)+h1+h2-max(y1,y2,y3,y4)

其实是很简单的几何关系变换,上面的图可以帮助你很好的理解这个意思。

代码实现:001-IoU计算

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

相关推荐