校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > Python計(jì)算任意多邊形間的重疊面積的示例代碼

Python計(jì)算任意多邊形間的重疊面積的示例代碼

熱門標(biāo)簽:湛江智能外呼系統(tǒng)廠家 長(zhǎng)沙高頻外呼系統(tǒng)原理是什么 ai電話機(jī)器人哪里好 宿遷星美防封電銷卡 地圖標(biāo)注審核表 外呼并發(fā)線路 ai電銷機(jī)器人源碼 百度地圖標(biāo)注沒有了 西藏房產(chǎn)智能外呼系統(tǒng)要多少錢

簡(jiǎn)介

跟某人討論一個(gè)排樣問題。
他說,算法搜索速度很慢,每?jī)蓚€(gè)物體間的重疊面積計(jì)算時(shí)間若按1s來算,300個(gè)物體需要計(jì)算將近9萬(wàn)次。
我說,這用計(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的安裝方法為:

pip install Shapely

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


安裝成功后,即可用下面示意的程序計(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ì)算任意多邊形間的重疊面積的示例代碼的文章就介紹到這了,更多相關(guān)Python 計(jì)算重疊面積內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python實(shí)現(xiàn)計(jì)算長(zhǎng)方形面積(帶參數(shù)函數(shù)demo)
  • python如何求圓的面積
  • 利用Python求陰影部分的面積實(shí)例代碼
  • Python計(jì)算不規(guī)則圖形面積算法實(shí)現(xiàn)解析
  • Python求凸包及多邊形面積教程
  • python實(shí)現(xiàn)輸入三角形邊長(zhǎng)自動(dòng)作圖求面積案例
  • python實(shí)現(xiàn)計(jì)算圖形面積

標(biāo)簽:寧夏 南平 普洱 海南 林芝 盤錦 漯河 大同

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python計(jì)算任意多邊形間的重疊面積的示例代碼》,本文關(guān)鍵詞  Python,計(jì)算,任意,多邊形,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python計(jì)算任意多邊形間的重疊面積的示例代碼》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python計(jì)算任意多邊形間的重疊面積的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 沈阳市| 周宁县| 彰武县| 任丘市| 枞阳县| 左云县| 邢台市| 明溪县| 独山县| 石门县| 汕尾市| 公主岭市| 广汉市| 宁化县| 武穴市| 焉耆| 三亚市| 鹤山市| 松滋市| 衡南县| 唐山市| 恭城| 晋江市| 玛多县| 静安区| 即墨市| 普陀区| 临城县| 丹江口市| 汕头市| 隆子县| 新沂市| 通辽市| 信宜市| 新田县| 英德市| 台南县| 温泉县| 东乌珠穆沁旗| 淮滨县| 固原市|