欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年08月19日 11:36:27   作者:lovetaozibaby  
最近有個作業(yè),給定的數(shù)據(jù)為多邊形的各個頂點(diǎn),為N*2的矩陣,N 為多邊形的頂點(diǎn)個數(shù),計(jì)算任意兩個多邊形重疊面積計(jì)算,本文就來詳細(xì)的介紹一下

簡介

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

本文檔目的為:
給定的數(shù)據(jù)為多邊形的各個頂點(diǎn),為N*2的矩陣,N 為多邊形的頂點(diǎn)個數(shù),計(jì)算任意兩個多邊形重疊面積計(jì)算的工具介紹及程序。
注意,并不涉及IOU的計(jì)算(雖然只是一句話的事哈哈哈)等,只是要重疊面積。

1. shapely工具箱

判斷任意兩個多邊形的面積是否有交集有函數(shù)A.intersects(B)實(shí)現(xiàn),若A和B有交集,返回為TRUE,若沒有交集,返回為FALSE;
計(jì)算任意兩個多邊形的面積有函數(shù)A.intersection(B).area,輸出直接為A和B的交集的面積。

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

shapely的安裝方法為:

pip install Shapely

但是不知道為什么,用該方法安裝時(shí),一直報(bào)錯,后來直接從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):
    """
    任意兩個圖形的相交面積的計(jì)算
    :param data1: 當(dāng)前物體
    :param data2: 待比較的物體
    :return: 當(dāng)前物體與待比較的物體的面積交集
    """

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

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

到此這篇關(guān)于Python計(jì)算任意多邊形間的重疊面積的示例代碼的文章就介紹到這了,更多相關(guān)Python 計(jì)算重疊面積內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Python的Treq on Twisted來進(jìn)行HTTP壓力測試

    使用Python的Treq on Twisted來進(jìn)行HTTP壓力測試

    這篇文章主要介紹了使用Python的Treq on Twisted來進(jìn)行HTTP壓力測試,基于Python中的Twisted框架,需要的朋友可以參考下
    2015-04-04
  • 利用Python畫ROC曲線和AUC值計(jì)算

    利用Python畫ROC曲線和AUC值計(jì)算

    這篇文章給大家介紹了如何利用Python畫ROC曲線,以及AUC值的計(jì)算,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-09-09
  • Python 矩陣轉(zhuǎn)置的幾種方法小結(jié)

    Python 矩陣轉(zhuǎn)置的幾種方法小結(jié)

    今天小編就為大家分享一篇Python 矩陣轉(zhuǎn)置的幾種方法小結(jié),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • flask框架藍(lán)圖和子域名配置詳解

    flask框架藍(lán)圖和子域名配置詳解

    這篇文章主要介紹了flask框架藍(lán)圖和子域名配置,結(jié)合實(shí)例形式詳細(xì)分析了flask框架藍(lán)圖和子域名配置相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2020-01-01
  • 對python中的argv和argc使用詳解

    對python中的argv和argc使用詳解

    今天小編就為大家分享一篇對python中的argv和argc使用詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • python九九乘法表的實(shí)例

    python九九乘法表的實(shí)例

    下面小編就為大家?guī)硪黄猵ython九九乘法表的實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Python編程使用*解包和itertools.product()求笛卡爾積的方法

    Python編程使用*解包和itertools.product()求笛卡爾積的方法

    這篇文章主要介紹了Python編程使用*解包和itertools.product()求笛卡爾積的方法,涉及Python列表轉(zhuǎn)換及itertools.product()求笛卡爾積相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • Django中文件上傳和文件訪問微項(xiàng)目的方法

    Django中文件上傳和文件訪問微項(xiàng)目的方法

    這篇文章主要介紹了Django中文件上傳和文件訪問微項(xiàng)目的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • python環(huán)境路徑配置以及命令行運(yùn)行腳本

    python環(huán)境路徑配置以及命令行運(yùn)行腳本

    這篇文章主要為大家詳細(xì)介紹了python環(huán)境路徑配置以及命令行運(yùn)行腳本,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • 對Python發(fā)送帶header的http請求方法詳解

    對Python發(fā)送帶header的http請求方法詳解

    今天小編就為大家分享一篇對Python發(fā)送帶header的http請求方法詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01

最新評論