python使用numpy计算两个框的iou方法示例
更新时间:2023年08月08日 09:44:43 作者:Eureka
这篇文章主要介绍了python使用numpy计算两个框的iou方法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
程序
需求简单,记录一下。
import numpy as np
import cv2
def iou(bbox1, bbox2):
xmin1, ymin1, xmax1, ymax1 = bbox1
xmin2, ymin2, xmax2, ymax2 = bbox2
# 获取矩形框交集对应的顶点坐标(intersection)
xx1 = np.max([xmin1, xmin2])
yy1 = np.max([ymin1, ymin2])
xx2 = np.min([xmax1, xmax2])
yy2 = np.min([ymax1, ymax2])
# 计算交集面积
inter_area = (np.max([0, xx2 - xx1])) * (np.max([0, yy2 - yy1]))
# 计算两个矩形框面积
area1 = (xmax1 - xmin1 ) * (ymax1 - ymin1)
area2 = (xmax2 - xmin2) * (ymax2 - ymin2)
# 计算交并比(交集/并集)
iou = inter_area / (area1 + area2 - inter_area ) # 注意:这里inter_area不能乘以2,乘以2就相当于把交集部分挖空了
return iou
def main():
img = np.zeros((600,600), dtype=np.uint8)+255 # 创建一个全白画板(灰度图)
img = np.stack((img,)*3, axis=-1) # 将灰度图转化为三通道图。目的是能在画板上画出彩色的图案。
# 初始化两个框
bbox1 = [200, 200, 400, 400] # xmin, ymin, xmax, ymax
bbox2 = [275, 300, 325, 550] # xmin, ymin, xmax, ymax
# 在画板上画出这两个彩色框
cv2.rectangle(img, (bbox1[0:2]), (bbox1[2:4]), (255,69,0), -1)
cv2.rectangle(img, (bbox2[0:2]), (bbox2[2:4]), (218,112,214), -1)
# 计算这两个框的iou
rst = iou(bbox1, bbox2)
cv2.putText(img, 'iou: %.6f' % rst, (10,30), cv2.FONT_HERSHEY_SIMPLEX, 1, (0,0,255), 2)
cv2.imwrite('res.png',img)
if __name__ == "__main__":
main()结果

以上就是python使用numpy计算两个框的iou方法示例的详细内容,更多关于python numpy计算两个框iou的资料请关注脚本之家其它相关文章!
相关文章
linux mint中搜狗输入法导致pycharm卡死的问题
这篇文章主要介绍了linux mint中搜狗输入法导致pycharm卡死的问题,这篇文章给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-10-10
python [::-1] [::-1,::-1]的具体使用
本文主要介绍了python [::-1] [::-1,::-1]的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-05-05
pycharm2022.1最新永久激活码破解补丁一键安装教程免费分享(2022持续更新)
更新到Pycharm 2022.2.x版,pycharm2022.2最新可用永久激活码分享(持续更新),pycharm激活补丁一键安装简单方便,无需手动修改文件,兼容苹果MAC,linux,Windows系统2022-07-07


最新评论