溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python怎么計(jì)算任意多邊形間的重疊面積

發(fā)布時(shí)間:2021-08-19 14:01:34 來(lái)源:億速云 閱讀:648 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Python怎么計(jì)算任意多邊形間的重疊面積”,在日常操作中,相信很多人在Python怎么計(jì)算任意多邊形間的重疊面積問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Python怎么計(jì)算任意多邊形間的重疊面積”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

目錄
  • 簡(jiǎn)介

  • 1. shapely工具箱

  • 2. 程序

簡(jiǎn)介

跟某人討論一個(gè)排樣問(wèn)題。
他說(shuō),算法搜索速度很慢,每?jī)蓚€(gè)物體間的重疊面積計(jì)算時(shí)間若按1s來(lái)算,300個(gè)物體需要計(jì)算將近9萬(wàn)次。
我說(shuō),這用計(jì)算機(jī)視覺(jué)難道不是幾句話解決的嘛!
(小小的嘚瑟一把,雖然做了這么久的CV,一直覺(jué)得自己一無(wú)所成,但是沒(méi)想到默默的就能解決別人的問(wèn)題了哈哈哈~~)

本文檔目的為:
給定的數(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,若沒(méi)有交集,返回為FALSE;
計(jì)算任意兩個(gè)多邊形的面積有函數(shù)A.intersection(B).area,輸出直接為A和B的交集的面積。

那么問(wèn)題在于,如何將多邊形頂點(diǎn)的坐標(biāo),換為組成多邊形的所有內(nèi)部點(diǎn)的坐標(biāo)。
python有個(gè)工具箱shapely。用于解決多邊形有關(guān)問(wèn)題。其中有個(gè)多邊形填充函數(shù)Polygon.

shapely的安裝方法為:

pip install Shapely

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

Python怎么計(jì)算任意多邊形間的重疊面積

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

2. 程序

import numpy as np
import time
from shapely.geometry import Polygon  # 多邊形
import scipy.io as io

def Cal_area_2poly(data1,data2):
    """
    任意兩個(gè)圖形的相交面積的計(jì)算
    :param data1: 當(dāng)前物體
    :param data2: 待比較的物體
    :return: 當(dāng)前物體與待比較的物體的面積交集
    """

    poly1 = Polygon(data1).convex_hull      # Polygon:多邊形對(duì)象
    poly2 = Polygon(data2).convex_hull

    if not poly1.intersects(poly2):
        inter_area = 0  # 如果兩四邊形不相交
    else:
        inter_area = poly1.intersection(poly2).area  # 相交面積
    return inter_area
    
data1 = []  # 帶比較的第一個(gè)物體的頂點(diǎn)坐標(biāo)
data2 = []   #待比較的第二個(gè)物體的頂點(diǎn)坐標(biāo)
area = Cal_area_2poly(data1,data2)

到此,關(guān)于“Python怎么計(jì)算任意多邊形間的重疊面積”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI