【YOLO】用 Python 来计算 IOU
来源:互联网 发布:mac 3d动画制作软件 编辑:程序博客网 时间:2024/05/24 05:03
在做YOLO目标检测相关的项目,里面涉及到计算IOU,可以理解为系统预测出来的框与原来图片中标记的框的重合程度。 因为YOLO的实现是用tensorflow实现的,而我又要单独列出来,所以就打算用Python来计算 IOU。
IOU的计算这个问题,其实我们可以转化成两个矩形框的重合程度,那么
- 第一步是判断是否重合
- 第二步是计算重合程度
这里有个难点,如何判断是否重合。我的理解是分别比较两个矩形的重心在x轴方向上和y轴方向上的距离与两个矩形的长或者宽的一半的和的大小。如果重心的在x轴和y轴上的距离都比他们边长和的一半要小就符合相交的条件。
第二个就是计算重合程度,那么我们采用的是 IOU = 相交的面积 /(两个框的面积和 - 相交的面积)。这里相交的面积的计算,需要我们知道相交面积的左上角顶点和右下角顶点。这两个顶点,我们直接比较横纵坐标就可以求出来,比较简单就不赘述。
那么下面我就展示我的代码了。
def calcIOU(one_x, one_y, one_w, one_h, two_x, two_y, two_w, two_h):if((abs(one_x - two_x) < ((one_w + two_w) / 2.0)) and (abs(one_y - two_y) < ((one_h + two_h) / 2.0))):lu_x_inter = max((one_x - (one_w / 2.0)), (two_x - (two_w / 2.0)))lu_y_inter = min((one_y + (one_h / 2.0)), (two_y + (two_h / 2.0)))rd_x_inter = min((one_x + (one_w / 2.0)), (two_x + (two_w / 2.0)))rd_y_inter = max((one_y - (one_h / 2.0)), (two_y - (two_h / 2.0)))inter_w = abs(rd_x_inter - lu_x_inter)inter_h = abs(lu_y_inter - rd_y_inter)inter_square = inter_w * inter_hunion_square = (one_w * one_h) + (two_w * two_h) - inter_squarecalcIOU = inter_square / union_square * 1.0print("calcIOU:", calcIOU)else:print("No intersection!")return calcIOUdef main():calcIOU(1, 2, 2, 2, 2, 1, 2, 2)if __name__ == '__main__':main()
阅读全文
1 0
- 【YOLO】用 Python 来计算 IOU
- Python计算机视觉里的IOU计算
- matlab中的IoU计算函数
- IOU
- iou
- 用python来玩科学计算
- 计算两个矩形IOU的算法
- 计算图片中矩形间的IOU
- 目标检测中的IOU计算问题
- darknet yolo 计算mAP,recall
- YOLO模型test计算流程
- YOLO计算验证集Acc
- YOLO
- YOLO
- YOLO
- yolo
- YOLO
- yolo
- 多块PCIe SSD插在同一个主板上时,Linux 对这几块SSD的命名
- applicationContext.xml添加自动提示失败
- 发送有序广播案例
- 学习笔记TF019:序列分类、IMDB影评分类
- 自制Java虚拟机(四)-对象、new、invokespecial
- 【YOLO】用 Python 来计算 IOU
- 机器学习知识点(三十五)蒙特卡罗方法
- shiro 安全框架的使用
- OpenGL 入门基础教程 —— 矩阵的变换
- Android Studio中的R.java在哪里
- 2017年上海金马五校赛 解题报告
- 计算二进制中1的个数
- 代码里的“随机应变”
- android Path 学习