OpenCV中的cv2.fitline函數詳解

一、cv2.fitline是什麼

cv2.fitline函數是OpenCV中的一個較為重要的函數,它可以通過擬合一條直線,對圖像中的一些邊緣或輪廓進行線性擬合。在圖像分析和處理的許多領域中都會用到這個函數,例如斑點檢測、物體跟蹤等。

cv2.fitline函數的具體用法為:

cv2.fitline(points, distType, param, reps, aeps)

其中,points代表的是二維點集,distType是擬合線時所使用的距離類型,param表示該距離類型的額外參數,reps是隨機樣本取樣時的次數,aeps表示擬合線的精度。

二、使用cv2.fitline實現線性擬合

通過cv2.fitline函數可以對圖像中的邊緣或輪廓進行線性擬合,以便於後續的分析和處理。下面我們通過一個實例來展示如何使用cv2.fitline函數實現線性擬合。

首先我們準備一個二值化圖像,用於展示該函數的作用。具體的實現代碼如下所示:

import cv2
import numpy as np 

img = np.zeros((512,512,1), np.uint8)
cv2.rectangle(img, (100,100), (300,250), (255,255,255), 3)
cv2.imshow("Image", img)
cv2.waitKey(0)
cv2.destroyAllWindows()

運行結果如下所示:

接下來我們對這個圖像中的直線進行線性擬合,具體實現代碼如下所示:

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
edges = cv2.Canny(gray,50,150,apertureSize = 3)
lines = cv2.HoughLines(edges,1,np.pi/180,200)
for line in lines:
    rho,theta = line[0]
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a*rho
    y0 = b*rho
    x1 = int(x0 + 1000*(-b))
    y1 = int(y0 + 1000*(a))
    x2 = int(x0 - 1000*(-b))
    y2 = int(y0 - 1000*(a))
    cv2.line(img,(x1,y1),(x2,y2),(0,0,255),2)
cv2.imshow('houghlines3',img)
cv2.waitKey(0)
cv2.destroyAllWindows()

運行結果如下所示:

緊接着,我們可以使用cv2.fitline函數對得到的直線進行線性擬合,具體實現代碼如下所示:

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
edges = cv2.Canny(gray,50,150,apertureSize = 3)
lines = cv2.HoughLines(edges,1,np.pi/180,200)
for line in lines:
    rho,theta = line[0]
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a*rho
    y0 = b*rho
    x1 = int(x0 + 1000*(-b))
    y1 = int(y0 + 1000*(a))
    x2 = int(x0 - 1000*(-b))
    y2 = int(y0 - 1000*(a))
    cv2.line(img,(x1,y1),(x2,y2),(0,0,255),2)
    [vx,vy,x,y] = cv2.fitLine(lines[0], cv2.DIST_L2,0,0.01,0.01)
    lefty = int((-x*vy/vx) + y)
    righty = int(((cols-x)*vy/vx)+y)
    cv2.line(img,(cols-1,righty),(0,lefty),(0,255,0),2)
cv2.imshow('fitline',img)
cv2.waitKey(0)
cv2.destroyAllWindows()

運行結果如下所示:

我們可以看到,在經過擬合的直線上,出現了兩個綠色的點,它們分別代表了直線的起點和終點。

三、參數詳解

cv2.fitline函數中所涉及的參數對於線性擬合的效果有着非常重要的影響。下面我們對參數進行詳細的說明。

a. points參數

points參數是cv2.fitline函數中用於放置二維點集的參數,該參數是一個(N * 2)的NumPy數組,其中每一行表示二維空間中一個點的坐標,N表示樣本點的個數。需要注意的是,該參數必須具有單精度或雙精度浮點類型。

b. distType參數

distType參數是擬合線時使用的距離類型,在cv2.fitline函數中可以指定為以下幾種值:

  • cv2.DIST_L2:表示歐幾里得距離(L2範數)
  • cv2.DIST_L1:表示曼哈頓距離(L1範數)
  • cv2.DIST_L12:表示L1-L2混合距離(設置參數的方式如下所示:cv2.DIST_L12(0.5))
  • cv2.DIST_FAIR:表示矯正後的Fair距離(設置參數的方式如下所示:cv2.DIST_FAIR(0.5))
  • cv2.DIST_WELSCH:表示矯正後的Welsch距離(設置參數的方式如下所示:cv2.DIST_WELSCH(0.5))

c. param參數

param參數表示distType所對應的額外參數,對於魯棒估計距離或某些混合距離類型,該參數是必須設置的。如果沒有設置該參數,cv2.fitline函數將以0作為默認值進行計算。該參數的類型必須是浮點型。

d. reps參數

reps參數是隨機樣本取樣的次數。當計算分量時,cv2.fitline函數會從給定的二維點集中隨機提取reps組點並計算擬合直線。默認值是2。

e. aeps參數

aeps通常表示擬合的精度,但實際上是一個與誤差範圍有關的閾值。當兩點之間的垂足距離小於aeps時,該點被認為是與擬合直線“吻合”的點。默認值是0.01。

四、cv2.fitline的實際應用場景

cv2.fitline函數在圖像分析和處理的許多領域中都有着廣泛的應用。例如,它可以用於:

  • 斑點檢測:當斑點呈線狀的時候,使用cv2.fitline函數可以得到斑點的長度和方向。
  • 物體跟蹤:當物體呈線狀的時候,使用cv2.fitline函數可以得到物體的速度和方向。
  • 邊緣檢測:cv2.fitline可以用於提取邊緣的方向和長度。
  • 運動估計:利用cv2.fitline可以估計圖像中物體的運動方向和速度。

五、總結

本文對OpenCV中cv2.fitline函數進行了比較詳細的講解。簡單來說,cv2.fitline可以通過擬合一條直線,對圖像中的一些邊緣或輪廓進行線性擬合。在圖像分析和處理的許多領域中都會用到這個函數。除此之外,本文還介紹了cv2.fitline函數的具體用法、參數詳解以及實際應用場景等內容。

原創文章,作者:KOIC,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/138162.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
KOIC的頭像KOIC
上一篇 2024-10-04 00:19
下一篇 2024-10-04 00:19

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • 如何在PyCharm中安裝OpenCV?

    本文將從以下幾個方面詳細介紹如何在PyCharm中安裝OpenCV。 一、安裝Python 在安裝OpenCV之前,請確保已經安裝了Python。 如果您還沒有安裝Python,可…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • 單片機打印函數

    單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • Python OpenCV 直線檢測

    本文將介紹在Python OpenCV中進行直線檢測的方法,主要涉及到圖像的邊緣檢測、霍夫變換和繪製直線等操作。 一、邊緣檢測 由於直線檢測是從圖像的邊緣開始的,因此必須先找到圖像…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Python定義函數判斷奇偶數

    本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

    編程 2025-04-29
  • Python實現計算階乘的函數

    本文將介紹如何使用Python定義函數fact(n),計算n的階乘。 一、什麼是階乘 階乘指從1乘到指定數之間所有整數的乘積。如:5! = 5 * 4 * 3 * 2 * 1 = …

    編程 2025-04-29

發表回復

登錄後才能評論