python实现的Iou与Giou代码


Posted in Python onJanuary 18, 2020

最近看了网上很多博主写的iou实现方法,但Giou的代码似乎比较少,于是便自己写了一个,新手上路,如有错误请指正,话不多说,上代码:

def Iou(rec1,rec2):
  x1,x2,y1,y2 = rec1 #分别是第一个矩形左右上下的坐标
  x3,x4,y3,y4 = rec2 #分别是第二个矩形左右上下的坐标
  area_1 = (x2-x1)*(y1-y2)
  area_2 = (x4-x3)*(y3-y4)
  sum_area = area_1 + area_2
  w1 = x2 - x1#第一个矩形的宽
  w2 = x4 - x3#第二个矩形的宽
  h1 = y1 - y2
  h2 = y3 - y4
  W = min(x1,x2,x3,x4)+w1+w2-max(x1,x2,x3,x4)#交叉部分的宽
  H = min(y1,y2,y3,y4)+h1+h2-max(y1,y2,y3,y4)#交叉部分的高
  Area = W*H#交叉的面积
  Iou = Area/(sum_area-Area)
  return Iou

def Giou(rec1,rec2):
  x1,x2,y1,y2 = rec1 #分别是第一个矩形左右上下的坐标
  x3,x4,y3,y4 = rec2
  iou = Iou(rec1,rec2)
  area_C = (max(x1,x2,x3,x4)-min(x1,x2,x3,x4))*(max(y1,y2,y3,y4)-min(y1,y2,y3,y4))
  area_1 = (x2-x1)*(y1-y2)
  area_2 = (x4-x3)*(y3-y4)
  sum_area = area_1 + area_2
  w1 = x2 - x1#第一个矩形的宽
  w2 = x4 - x3#第二个矩形的宽
  h1 = y1 - y2
  h2 = y3 - y4
  W = min(x1,x2,x3,x4)+w1+w2-max(x1,x2,x3,x4)#交叉部分的宽
  H = min(y1,y2,y3,y4)+h1+h2-max(y1,y2,y3,y4)#交叉部分的高
  Area = W*H#交叉的面积
  add_area = sum_area - Area #两矩形并集的面积
  end_area = (area_C - add_area)/area_C #(c/(AUB))/c的面积
  giou = iou - end_area
  return giou


rec1 = (27,47,130,90)
rec2 = (30,68,150,110)
iou = Iou(rec1,rec2)
giou = Giou(rec1,rec2)
print("Iou = {},Giou = {}".format(iou,giou))

以上这篇python实现的Iou与Giou代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现字典依据value排序
Feb 24 Python
Python3控制路由器——使用requests重启极路由.py
May 11 Python
python求质数的3种方法
Sep 28 Python
PyCharm鼠标右键不显示Run unittest的解决方法
Nov 30 Python
Python实现的特征提取操作示例
Dec 03 Python
Python中出现IndentationError:unindent does not match any outer indentation level错误的解决方法
Apr 18 Python
树莓派动作捕捉抓拍存储图像脚本
Jun 22 Python
Django中提示消息messages的设置方式
Nov 15 Python
Python tkinter常用操作代码实例
Jan 03 Python
使用python matploblib库绘制准确率,损失率折线图
Jun 16 Python
Python图像阈值化处理及算法比对实例解析
Jun 19 Python
python安装sklearn模块的方法详解
Nov 28 Python
Python 简单计算要求形状面积的实例
Jan 18 #Python
python实现用类读取文件数据并计算矩形面积
Jan 18 #Python
python不使用for计算两组、多个矩形两两间的iou方式
Jan 18 #Python
浅谈Python3实现两个矩形的交并比(IoU)
Jan 18 #Python
利用setuptools打包python程序的方法步骤
Jan 18 #Python
python计算二维矩形IOU实例
Jan 18 #Python
解决python replace函数替换无效问题
Jan 18 #Python
You might like
PHP实现上传文件并存进数据库的方法
2015/07/16 PHP
php格式化json函数示例代码
2016/05/12 PHP
多个Laravel项目如何共用migrations详解
2018/09/25 PHP
js 浏览本地文件夹系统示例代码
2013/10/24 Javascript
js实现简单登录功能的实例代码
2013/11/09 Javascript
JavaScript中实现sprintf、printf函数
2015/01/27 Javascript
jquery实现标签支持图文排列带上下箭头按钮的选项卡
2015/03/14 Javascript
javascript中Math.random()使用详解
2015/04/15 Javascript
JS+Canvas实现的俄罗斯方块游戏完整实例
2016/12/12 Javascript
基于react框架使用的一些细节要点的思考
2017/05/31 Javascript
Vue自定义指令封装节流函数的方法示例
2018/07/09 Javascript
在vue中使用eslint,配合vscode的操作
2020/11/09 Javascript
JavaScript实现打字游戏
2021/02/19 Javascript
[18:32]DOTA2 HEROS教学视频教你分分钟做大人-谜团
2014/06/12 DOTA
[04:28]2014DOTA2国际邀请赛 采访小兔子LGD挺进钥匙体育馆
2014/07/14 DOTA
[47:26]完美世界DOTA2联赛 LBZS vs Forest 第二场 11.07
2020/11/09 DOTA
Python学习之asyncore模块用法实例教程
2014/09/29 Python
django session完成状态保持的方法
2018/11/27 Python
pytorch自定义初始化权重的方法
2019/08/17 Python
在keras中model.fit_generator()和model.fit()的区别说明
2020/06/17 Python
俄罗斯披萨、寿司和面食送货到家服务:2 Берега
2019/12/15 全球购物
土木工程专业个人求职信
2013/12/05 职场文书
优秀小学生家长评语
2014/01/30 职场文书
校园安全教育广播稿
2014/02/17 职场文书
教师年度考核评语
2014/04/28 职场文书
爱与责任演讲稿
2014/05/20 职场文书
4s店销售经理岗位职责
2014/07/19 职场文书
学校领导班子对照检查材料
2014/08/28 职场文书
2014年幼儿园教研工作总结
2014/12/04 职场文书
员工年度工作总结2015
2015/05/18 职场文书
美容院管理规章制度
2015/08/05 职场文书
大学生先进个人主要事迹材料
2015/11/04 职场文书
党性教育心得体会(共6篇)
2016/01/21 职场文书
入党转正申请自我鉴定
2019/06/25 职场文书
读《推着妈妈去旅行》有感1500字
2019/10/15 职场文书
Go归并排序算法的实现方法
2022/04/06 Golang