python计算两个矩形的重叠_python计算两个矩形框重合百分比的实例

如下所示:

def mat_inter(box1,box2):

# 判断两个矩形是否相交

# box=(xA,yA,xB,yB)

x01, y01, x02, y02 = box1

x11, y11, x12, y12 = box2

lx = abs((x01 + x02) / 2 - (x11 + x12) / 2)

ly = abs((y01 + y02) / 2 - (y11 + y12) / 2)

sax = abs(x01 - x02)

sbx = abs(x11 - x12)

say = abs(y01 - y02)

sby = abs(y11 - y12)

if lx <= (sax + sbx) / 2 and ly <= (say + sby) / 2:

return True

else:

return False

def solve_coincide(box1,box2):

# box=(xA,yA,xB,yB)

# 计算两个矩形框的重合度

if mat_inter(box1,box2)==True:

x01, y01, x02, y02 = box1

x11, y11, x12, y12 = box2

col=min(x02,x12)-max(x01,x11)

row=min(y02,y12)-max(y01,y11)

intersection=col*row

area1=(x02-x01)*(y02-y01)

area2=(x12-x11)*(y12-y11)

coincide=intersection/(area1+area2-intersection)

return coincide

else:

return False

以上这篇python计算两个矩形框重合百分比的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

本文标题: python计算两个矩形框重合百分比的实例

本文地址: http://www.cppcns.com/jiaoben/python/243846.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值