Python計(jì)算任意多邊形間的重疊面積的示例代碼_第1頁
Python計(jì)算任意多邊形間的重疊面積的示例代碼_第2頁
Python計(jì)算任意多邊形間的重疊面積的示例代碼_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

第Python計(jì)算任意多邊形間的重疊面積的示例代碼跟某人討論一個(gè)排樣問題。

他說,算法搜索速度很慢,每兩個(gè)物體間的重疊面積計(jì)算時(shí)間若按1s來算,300個(gè)物體需要計(jì)算將近9萬次。

我說,這用計(jì)算機(jī)視覺難道不是幾句話解決的嘛!

(小小的嘚瑟一把,雖然做了這么久的CV,一直覺得自己一無所成,但是沒想到默默的就能解決別人的問題了哈哈哈~~)

本文檔目的為:

給定的數(shù)據(jù)為多邊形的各個(gè)頂點(diǎn),為N*2的矩陣,N為多邊形的頂點(diǎn)個(gè)數(shù),計(jì)算任意兩個(gè)多邊形重疊面積計(jì)算的工具介紹及程序。

注意,并不涉及IOU的計(jì)算(雖然只是一句話的事哈哈哈)等,只是要重疊面積。

1.shapely工具箱

判斷任意兩個(gè)多邊形的面積是否有交集有函數(shù)A.intersects(B)實(shí)現(xiàn),若A和B有交集,返回為TRUE,若沒有交集,返回為FALSE;

計(jì)算任意兩個(gè)多邊形的面積有函數(shù)A.intersection(B).area,輸出直接為A和B的交集的面積。

那么問題在于,如何將多邊形頂點(diǎn)的坐標(biāo),換為組成多邊形的所有內(nèi)部點(diǎn)的坐標(biāo)。

python有個(gè)工具箱shapely。用于解決多邊形有關(guān)問題。其中有個(gè)多邊形填充函數(shù)Polygon.

shapely的安裝方法為:

pipinstallShapely

但是不知道為什么,用該方法安裝時(shí),一直報(bào)錯(cuò),后來直接從/~gohlke/pythonlibs/#shapely(直接ctrl+F搜索shapely快速轉(zhuǎn)到下載位置)下載了該文件,用地址名安裝。

安裝成功后,即可用下面示意的程序計(jì)算面積。

2.程序

importnumpyasnp

importtime

fromshapely.geometryimportPolygon#多邊形

importscipy.ioasio

defCal_area_2poly(data1,data2):

任意兩個(gè)圖形的相交面積的計(jì)算

:paramdata1:當(dāng)前物體

:paramdata2:待比較的物體

:return:當(dāng)前物體與待比較的物體的面積交集

poly1=Polygon(data1).convex_hull#Polygon:多邊形對象

poly2=Polygon(data2).convex_hull

ifnotersects(poly2):

inter_area=0#如果兩四邊形不相交

else:

inter_area=ersection(poly2).area#相交面積

returninter_area

data1=[]#帶比較的第一個(gè)物體的頂點(diǎn)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論