亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

opencv?python中cv.approxPolyDP函數(shù)詳細(xì)解釋

 更新時(shí)間:2024年01月30日 10:11:16   作者:清風(fēng)云襄  
這篇文章主要給大家介紹了關(guān)于opencv?python中cv.approxPolyDP函數(shù)詳細(xì)解釋的相關(guān)資料,OpenCV中的approxPolyDP()函數(shù)用于對(duì)形狀進(jìn)行逼近,以減少多邊形的頂點(diǎn)數(shù),可以用于對(duì)圖像輪廓點(diǎn)進(jìn)行多邊形擬合,需要的朋友可以參考下

在OpenCV Python中,cv.approxPolyDP是一個(gè)用于多邊形逼近的函數(shù)。它使用Douglas-Peucker算法來減少多邊形的點(diǎn)數(shù)。

該函數(shù)需要兩個(gè)參數(shù):輸入多邊形和一個(gè)表示逼近精度的參數(shù)。輸入多邊形是一個(gè)由點(diǎn)組成的數(shù)組,而逼近精度是一個(gè)用于控制輪廓近似的精度參數(shù)。

該函數(shù)在輸入多邊形中保留重要的角度,并刪除不必要的頂點(diǎn),從而減少了生成多邊形所需的點(diǎn)數(shù)。它可以用于圖像處理中的輪廓發(fā)現(xiàn)和分析,通過減少多邊形點(diǎn)數(shù),可以更容易地檢測(cè)和識(shí)別形狀。

下面是一個(gè)簡(jiǎn)單的示例

展示了如何在OpenCV Python中使用cv.approxPolyDP來逼近多邊形:

import cv2 as cv
import numpy as np

# 讀取圖像
img = cv.imread("polygon.jpg")

# 轉(zhuǎn)換為灰度圖像
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)

# 二值化圖像
ret, thresh = cv.threshold(gray, 127, 255, cv.THRESH_BINARY)

# 找到輪廓
contours, hierarchy = cv.findContours(thresh, cv.RETR_TREE, cv.CHAIN_APPROX_SIMPLE)

# 逼近多邊形
approx = cv.approxPolyDP(contours[0], 0.01 * cv.arcLength(contours[0], True), True)

# 繪制輪廓和逼近多邊形
cv.drawContours(img, [contours[0]], 0, (0, 255, 0), 2)
cv.drawContours(img, [approx], 0, (255, 0, 0), 2)

# 顯示圖像
cv.imshow("Image", img)
cv.waitKey(0)
cv.destroyAllWindows()

在此示例中,我們首先讀取圖像并將其轉(zhuǎn)換為灰度圖像。然后,我們使用cv.threshold將其轉(zhuǎn)換為二值化圖像,并使用cv.findContours找到其輪廓。接下來,我們將使用cv.approxPolyDP逼近多邊形。最后,我們使用cv.drawContours將原始輪廓和逼近多邊形繪制到圖像上。

請(qǐng)注意,實(shí)際應(yīng)用中,需要使用適當(dāng)?shù)闹祦碚{(diào)整逼近精度參數(shù),以使逼近過程產(chǎn)生最佳結(jié)果。

cv.approxPolyDP函數(shù)有三個(gè)參數(shù),分別是:

  • curve:輸入多邊形的輪廓。
  • epsilon:逼近精度參數(shù),表示逼近精度的界限。該參數(shù)是一個(gè)正數(shù),其值越小則逼近程度越高。通常建議使用輪廓周長(zhǎng)的一定比例來計(jì)算該參數(shù),常見的比例因子為0.01。
  • closed:布爾值參數(shù),表示輸出的逼近多邊形是否閉合。如果布爾值為True,則輸出的多邊形是封閉的。如果為False,則只返回線段。

在實(shí)際使用時(shí),需要針對(duì)具體的應(yīng)用場(chǎng)景和圖像情況來調(diào)整epsilon的值,以充分利用其控制逼近精度的功能。

需要注意的是,函數(shù)返回值是輸出的逼近多邊形的點(diǎn)數(shù)組形式,可以使用cv.drawContours函數(shù)將其繪制到圖像上。

cv.approxPolyDP 函數(shù)返回的是多邊形的頂點(diǎn)坐標(biāo)數(shù)組,可以使用cv.contourArea函數(shù)根據(jù)這些頂點(diǎn)坐標(biāo)計(jì)算多邊形的面積。需要注意的是,cv.contourArea 函數(shù)只能用于計(jì)算封閉的輪廓的面積,因此需要在調(diào)用cv.approxPolyDP 函數(shù)時(shí)將 closed 參數(shù)設(shè)為 True,以輸出封閉的多邊形輪廓。

具體的代碼實(shí)現(xiàn)方法如下:

# 輸入輪廓 contour,逼近精度 epsilon 和封閉參數(shù) closed,返回逼近多邊形的面積
def compute_approxPolyDP_area(contour, epsilon, closed=True):
    # 計(jì)算逼近多邊形的頂點(diǎn)坐標(biāo)
    approx = cv.approxPolyDP(contour, epsilon, closed)
    # 計(jì)算逼近多邊形的面積
    area = cv.contourArea(approx)
    return area

其中,輸入?yún)?shù) contour 是輸入輪廓的頂點(diǎn)坐標(biāo)數(shù)組,epsilon 是逼近精度參數(shù),closed 是封閉參數(shù);輸出結(jié)果 area 是逼近多邊形的面積。

可以使用 OpenCV 中的函數(shù) cv2.minAreaRect 和 cv2.boxPoints 來計(jì)算輪廓包圍圖形的最小矩形框,并得到矩形框的的四個(gè)頂點(diǎn)坐標(biāo)。然后可以使用 Python 矩形操作庫(kù) Shapely 來計(jì)算矩形和輪廓交集的面積。

具體的步驟如下:

  • 使用 cv2.findContours 函數(shù)得到輸入輪廓的頂點(diǎn)坐標(biāo)數(shù)組。
# img 為輸入圖像
contours, hierarchy = cv2.findContours(img, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
  • 使用 cv2.minAreaRect 函數(shù)計(jì)算輪廓包圍的最小矩形框及其四個(gè)頂點(diǎn)的坐標(biāo)。
rect = cv2.minAreaRect(contours[0])  # 計(jì)算最小矩形框
box = cv2.boxPoints(rect)  # 得到矩形框的四個(gè)頂點(diǎn)坐標(biāo)
box = np.int0(box)  # 轉(zhuǎn)換為整型
  • 使用 Shapely 庫(kù)計(jì)算矩形和輪廓交集的面積。
from shapely.geometry import Polygon

# 計(jì)算矩形和輪廓交集的面積
intersection_area = 0
if len(contours) > 0:
    polygon = Polygon(contours[0].reshape(-1, 2))
    rect_polygon = Polygon(box.reshape(-1, 2))
    intersection = rect_polygon.intersection(polygon)
    if intersection.geom_type == 'Polygon':
        intersection_area = intersection.area

其中,Polygon 函數(shù)用于創(chuàng)建一個(gè)多邊形對(duì)象,intersection 函數(shù)用于計(jì)算兩個(gè)多邊形的交集。最終的 intersection_area 變量即為矩形和輪廓交集的面積。

完整代碼如下所示:

import cv2
import numpy as np
from shapely.geometry import Polygon

# 讀取輸入圖像
img = cv2.imread('input.jpg', 0)

# 計(jì)算輪廓
contours, hierarchy = cv2.findContours(img, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

# 計(jì)算最小矩形框
rect = cv2.minAreaRect(contours[0])
box = cv2.boxPoints(rect)
box = np.int0(box)

# 計(jì)算矩形和輪廓交集的面積
intersection_area = 0
if len(contours) > 0:
    polygon = Polygon(contours[0].reshape(-1, 2))
    rect_polygon = Polygon(box.reshape(-1, 2))
    intersection = rect_polygon.intersection(polygon)
    if intersection.geom_type == 'Polygon':
        intersection_area = intersection.area

# 輸出交集面積
print("Intersection area:", intersection_area)

其中,input.jpg 為輸入圖像文件名,可以替換為其他圖像。

使用 OpenCV 中的函數(shù) cv2.boundingRect 對(duì)多邊形逼近得到的輪廓進(jìn)行包圍矩形計(jì)算時(shí),得到的坐標(biāo)是最小矩形的左上角坐標(biāo)和寬度高度。也就是說,boundingRect 得到的矩形框是能夠完全覆蓋多邊形的最小矩形框,而不是包含多邊形的最大矩形框。

簡(jiǎn)單來說,boundingRect 得到的矩形框是能夠最小化多邊形占用的空間大小的矩形框。實(shí)際應(yīng)用中,boundingRect 函數(shù)通常用于求取多邊形的包圍盒,以便進(jìn)行后續(xù)圖形處理、物體識(shí)別等操作。

注意事項(xiàng):

Douglas-Peucker算法:

(1)在曲線的起點(diǎn) A 和終點(diǎn) B 之間做一條直線 AB,是曲線的弦;

(2)尋找曲線上離該直線段距離最大的點(diǎn) C,計(jì)算其與 AB 的距離 d;

(3)比較距離 d 與設(shè)定的閾值 threshold,如果小于設(shè)定閾值則該直線段作為曲線的近似,該段曲線處理完畢。

(4)如果距離 d 大于設(shè)定閾值,則以 C 點(diǎn)將曲線 AB 分為兩段 AC 和 BC,并分別對(duì)這兩段進(jìn)行以上步驟的處理。

(5)當(dāng)所有曲線都處理完畢時(shí),依次連接所有分割點(diǎn)形成的折線,作為曲線的近似。

總結(jié)

到此這篇關(guān)于opencv python中cv.approxPolyDP函數(shù)詳細(xì)解釋的文章就介紹到這了,更多相關(guān)opencv python中的cv.approxPolyDP 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 教你使用Python畫圣誕樹做浪漫的程序員

    教你使用Python畫圣誕樹做浪漫的程序員

    這不是圣誕節(jié)快到了,還不用Python繪制個(gè)圣誕樹和煙花讓女朋友開心開心,也算是親手做的,稍稍花了點(diǎn)心思,學(xué)會(huì)了趕緊畫給你的那個(gè)她吧
    2022-12-12
  • python3.6之xlwt如何設(shè)置單元格對(duì)齊方式

    python3.6之xlwt如何設(shè)置單元格對(duì)齊方式

    這篇文章主要介紹了python3.6之xlwt如何設(shè)置單元格對(duì)齊方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Python中深淺拷貝的區(qū)別詳細(xì)分析

    Python中深淺拷貝的區(qū)別詳細(xì)分析

    深拷貝和淺拷貝都是對(duì)原對(duì)象的拷貝,都會(huì)生成一個(gè)看起來相同的對(duì)象,下面這篇文章主要給大家介紹了關(guān)于Python中深淺拷貝的區(qū)別的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 全網(wǎng)非常詳細(xì)的pytest配置文件

    全網(wǎng)非常詳細(xì)的pytest配置文件

    本文主要介紹了全網(wǎng)非常詳細(xì)的pytest配置文件,pytest的主配置文件,可以改變pytest的默認(rèn)行為,有很多可配置的選項(xiàng),感興趣的可以了解一下
    2022-07-07
  • Python語言中的數(shù)據(jù)類型-序列

    Python語言中的數(shù)據(jù)類型-序列

    這篇文章主要介紹了Python語言中的數(shù)據(jù)類型-序列,前面我們提到了Python數(shù)據(jù)類型中的內(nèi)置數(shù)值類型與字符串類型。今天學(xué)習(xí)一下Python的序列數(shù)據(jù)類型,要知道的是在Python中沒有數(shù)組這一數(shù)據(jù)結(jié)構(gòu),需要的朋友可以參考一下
    2022-02-02
  • Python安裝后測(cè)試連接MySQL數(shù)據(jù)庫(kù)方式

    Python安裝后測(cè)試連接MySQL數(shù)據(jù)庫(kù)方式

    這篇文章主要介紹了Python安裝后測(cè)試連接MySQL數(shù)據(jù)庫(kù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 詳解Python實(shí)現(xiàn)字典合并的四種方法

    詳解Python實(shí)現(xiàn)字典合并的四種方法

    這篇文章主要為大家詳細(xì)介紹了Python的合并字典的四種方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • PyMongo安裝使用筆記

    PyMongo安裝使用筆記

    這篇文章主要介紹了PyMongo安裝使用筆記,本文講解使用pip方式安裝PyMongo,并給出一個(gè)pymongo的簡(jiǎn)單使用代碼實(shí)例,需要的朋友可以參考下
    2015-04-04
  • python實(shí)現(xiàn)函數(shù)極小值

    python實(shí)現(xiàn)函數(shù)極小值

    今天小編就為大家分享一篇python實(shí)現(xiàn)函數(shù)極小值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python網(wǎng)絡(luò)爬蟲神器PyQuery的基本使用教程

    Python網(wǎng)絡(luò)爬蟲神器PyQuery的基本使用教程

    這篇文章主要給大家介紹了關(guān)于Python網(wǎng)絡(luò)爬蟲神器PyQuery的基本使用教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)使用PyQuery具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-02-02

最新評(píng)論