成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

python如何解決不使用for計算兩組、多個矩形兩兩間的iou-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“python如何解決不使用for計算兩組、多個矩形兩兩間的iou”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“python如何解決不使用for計算兩組、多個矩形兩兩間的iou”這篇文章吧。

在灌南等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站設計、成都網(wǎng)站制作 網(wǎng)站設計制作按需定制,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站制作,成都營銷網(wǎng)站建設,外貿(mào)網(wǎng)站建設,灌南網(wǎng)站建設費用合理。

解決問題: 不使用for計算兩組、多個矩形兩兩間的iou

使用numpy廣播的方法,在python程序中并不建議使用for語句,python中的for語句耗時較多,如果使用numpy廣播的思想將會提速不少。

代碼:

def calc_iou(bbox1, bbox2):
 if not isinstance(bbox1, np.ndarray):
  bbox1 = np.array(bbox1)
 if not isinstance(bbox2, np.ndarray):
  bbox2 = np.array(bbox2)
 xmin1, ymin1, xmax1, ymax1, = np.split(bbox1, 4, axis=-1)
 xmin2, ymin2, xmax2, ymax2, = np.split(bbox2, 4, axis=-1)
 
 area1 = (xmax1 - xmin1) * (ymax1 - ymin1)
 area2 = (xmax2 - xmin2) * (ymax2 - ymin2)
 
 ymin = np.maximum(ymin1, np.squeeze(ymin2, axis=-1))
 xmin = np.maximum(xmin1, np.squeeze(xmin2, axis=-1))
 ymax = np.minimum(ymax1, np.squeeze(ymax2, axis=-1))
 xmax = np.minimum(xmax1, np.squeeze(xmax2, axis=-1))
 
 h = np.maximum(ymax - ymin, 0)
 w = np.maximum(xmax - xmin, 0)
 intersect = h * w
 
 union = area1 + np.squeeze(area2, axis=-1) - intersect
 return intersect / union

程序中輸入為多個矩形[xmin, ymin, xmax,ymax]格式的數(shù)組或者list,輸出為numpy格式,例:輸入的shape為(3, 4)、(5,4)則輸出為(3, 5)各個位置為boxes間相互的iou值。后面會卡一個iou的閾值,然后就可以將滿足條件的索引取出。如:

def delete_bbox(bbox1, bbox2, roi_bbox1, roi_bbox2, class1, class2, idx1, idx2, iou_value):
 idx = np.where(iou_value > 0.4)
 left_idx = idx[0]
 right_idx = idx[1]
 left = roi_bbox1[left_idx]
 right = roi_bbox2[right_idx]
 xmin1, ymin1, xmax1, ymax1, = np.split(left, 4, axis=-1)
 xmin2, ymin2, xmax2, ymax2, = np.split(right, 4, axis=-1)
 left_area = (xmax1 - xmin1) * (ymax1 - ymin1)
 right_area = (xmax2 - xmin2) * (ymax2 - ymin2)
 left_idx = left_idx[np.squeeze(left_area < right_area, axis=-1)]#小的被刪
 right_idx = right_idx[np.squeeze(left_area > right_area, axis=-1)]
 
 bbox1 = np.delete(bbox1, idx1[left_idx], 0)
 class1 = np.delete(class1, idx1[left_idx])
 bbox2 = np.delete(bbox2, idx2[right_idx], 0)
 class2 = np.delete(class2, idx2[right_idx])
 
 return bbox1, bbox2, class1, class2

IOU計算原理:

python如何解決不使用for計算兩組、多個矩形兩兩間的iou

ymin = np.maximum(ymin1, np.squeeze(ymin2, axis=-1))

xmin = np.maximum(xmin1, np.squeeze(xmin2, axis=-1))

ymax = np.minimum(ymax1, np.squeeze(ymax2, axis=-1))

xmax = np.minimum(xmax1, np.squeeze(xmax2, axis=-1))

h = np.maximum(ymax - ymin, 0)

w = np.maximum(xmax - xmin, 0)

intersect = h * w

計算矩形間min的大值,max的最小值,如果ymax-ymin值大于0則如左圖所示,如果小于0則如右圖所示

以上是“python如何解決不使用for計算兩組、多個矩形兩兩間的iou”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)頁名稱:python如何解決不使用for計算兩組、多個矩形兩兩間的iou-創(chuàng)新互聯(lián)
本文路徑:http://jinyejixie.com/article40/dhdieo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、靜態(tài)網(wǎng)站、網(wǎng)站策劃、網(wǎng)站制作、品牌網(wǎng)站設計、電子商務

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)
翁牛特旗| 横山县| 双桥区| 罗山县| 社会| 门头沟区| 满洲里市| 车险| 石嘴山市| 阿坝| 东兴市| 内黄县| 大城县| 黔西| 昌乐县| 土默特左旗| 自贡市| 吴江市| 离岛区| 安阳市| 昭苏县| 奉贤区| 金乡县| 贡觉县| 葫芦岛市| 武隆县| 东乌珠穆沁旗| 隆子县| 克拉玛依市| 荣成市| 丰顺县| 平昌县| 湘阴县| 天等县| 福建省| 安徽省| 乌兰察布市| 韶关市| 明溪县| 台东市| 渑池县|