如何基于OpenCV&Python實(shí)現(xiàn)霍夫變換圓形檢測(cè)
簡述
基于python使用opencv實(shí)現(xiàn)在一張圖片中檢測(cè)出圓形,并且根據(jù)坐標(biāo)和半徑標(biāo)記出圓。不涉及理論,只講應(yīng)用。
霍夫變換檢測(cè)圓形的原理
其實(shí)檢測(cè)圓形和檢測(cè)直線的原理差別不大,只不過直線是在二維空間,因?yàn)閥=kx+b,只有k和b兩個(gè)自由度。而圓形的一般性方程表示為(x-a)²+(y-b)²=r²。那么就有三個(gè)自由度圓心坐標(biāo)a,b,和半徑r。這就意味著需要更多的計(jì)算量,而OpenCV中提供的cvHoughCircle()函數(shù)里面可以設(shè)定半徑r的取值范圍,相當(dāng)于有一個(gè)先驗(yàn)設(shè)定,在每一個(gè)r來說,在二維空間內(nèi)尋找a和b就可以了,能夠減少計(jì)算量。
相關(guān)函數(shù)
函數(shù)說明:
Python: cv2.HoughCircles(image, method, dp, minDist[, circles[, param1[, param2[, minRadius[, maxRadius]]]]]) → circles
參數(shù)說明:
- image- 8位,單通道,灰度輸入圖像。
- circles- 找到的圓的輸出向量。每個(gè)向量被編碼為3元素的浮點(diǎn)向量 (x,y,半徑)。
- circle_storage - 在C函數(shù)中,這是一個(gè)將包含找到的圓的輸出序列的內(nèi)存存儲(chǔ)。
- method- 使用檢測(cè)方法。目前,唯一實(shí)現(xiàn)的方法是 CV_HOUGH_GRADIENT,基本上是 21HT,在[Yuen90]中有描述 。
- dp - 累加器分辨率與圖像分辨率的反比。例如,如果 dp = 1,則累加器具有與輸入圖像相同的分辨率。如果 dp = 2,則累加器的寬度和高度都是一半。
- minDist -檢測(cè)到的圓的中心之間的最小距離。如果參數(shù)太小,除了真正的參數(shù)外,可能會(huì)錯(cuò)誤地檢測(cè)到多個(gè)鄰居圈。如果太大,可能會(huì)錯(cuò)過一些圈子。
- param1 - 第一個(gè)方法特定的參數(shù)。在CV_HOUGH_GRADIENT的情況下, 兩個(gè)傳遞給Canny()邊緣檢測(cè)器的閾值較高(較小的兩個(gè)小于兩倍)。
- param2 - 第二種方法參數(shù)。在CV_HOUGH_GRADIENT的情況下,它是檢測(cè)階段的圓心的累加器閾值。越小,可能會(huì)檢測(cè)到越多的虛假圈子。首先返回對(duì)應(yīng)于較大累加器值的圈子。
- minRadius -最小圓半徑。
- maxRadius - 最大圓半徑。
這是根據(jù)opencv官方文檔谷歌翻譯過來的,參數(shù)比較多,但用的時(shí)候只修改一些主要的,傳入的圖像和最大最小圓半徑,以達(dá)到檢測(cè)出想要的圓的效果。
還有要注意函數(shù)的返回值
找到的圓的輸出向量。每個(gè)向量被編碼為3元素的浮點(diǎn)向量 (x,y,半徑)。
這句話不是很好理解,我們直接輸出返回值就會(huì)發(fā)現(xiàn)是個(gè) 三層嵌套list,最內(nèi)層list有三個(gè)元素,分別是圓心的行,列,半徑,這表示一個(gè)圓的基本信息。多個(gè)圓基本信息組成了一個(gè)新的list,這個(gè)list包含了檢測(cè)到的所有圓,即長度就是檢測(cè)到圓的個(gè)數(shù)。最外層再加了個(gè)list,至于干啥的不清楚了,不影響使用就好。
下圖是輸出函數(shù)返回值的一個(gè)實(shí)例圖

實(shí)例演示
完整代碼
import cv2
#載入并顯示圖片
img=cv2.imread('circle.png')
cv2.imshow('img',img)
#灰度化
gray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#輸出圖像大小,方便根據(jù)圖像大小調(diào)節(jié)minRadius和maxRadius
print(img.shape)
#霍夫變換圓檢測(cè)
circles= cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT,1,100,param1=100,param2=30,minRadius=5,maxRadius=300)
#輸出返回值,方便查看類型
print(circles)
#輸出檢測(cè)到圓的個(gè)數(shù)
print(len(circles[0]))
print('-------------我是條分割線-----------------')
#根據(jù)檢測(cè)到圓的信息,畫出每一個(gè)圓
for circle in circles[0]:
#圓的基本信息
print(circle[2])
#坐標(biāo)行列
x=int(circle[0])
y=int(circle[1])
#半徑
r=int(circle[2])
#在原圖用指定顏色標(biāo)記出圓的位置
img=cv2.circle(img,(x,y),r,(0,0,255),-1)
#顯示新圖像
cv2.imshow('res',img)
#按任意鍵退出
cv2.waitKey(0)
cv2.destroyAllWindows()
運(yùn)行結(jié)果

shell輸出截圖

總結(jié)
到此這篇關(guān)于基于OpenCV&Python實(shí)現(xiàn)霍夫變換圓形檢測(cè)的文章就介紹到這了,更多相關(guān)OpenCV霍夫變換圓形檢測(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python基于YOLOv8和OpenCV實(shí)現(xiàn)車道線和車輛檢測(cè)功能
使用YOLOv8(You Only Look Once)和OpenCV實(shí)現(xiàn)車道線和車輛檢測(cè),目標(biāo)是創(chuàng)建一個(gè)可以檢測(cè)道路上的車道并識(shí)別車輛的系統(tǒng),并估計(jì)它們與攝像頭的距離,這篇文章主要介紹了Python基于YOLOv8和OpenCV實(shí)現(xiàn)車道線和車輛檢測(cè),需要的朋友可以參考下2025-01-01
將python flask項(xiàng)目打包成可以運(yùn)行的軟件的全過程(包含報(bào)錯(cuò)解決)
這篇文章主要給大家介紹了將python flask項(xiàng)目打包成可以用運(yùn)行的軟件(包含報(bào)錯(cuò)解決),文中通過代碼示例和圖文結(jié)合講解的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-02-02
Python標(biāo)準(zhǔn)庫os庫的常用功能解析
這篇文章主要介紹了Python標(biāo)準(zhǔn)庫os庫的常用功能解析,os庫是Python標(biāo)準(zhǔn)庫之一,它提供了非常豐富的文件及目錄讀寫的方法2022-07-07
python FastApi實(shí)現(xiàn)數(shù)據(jù)表遷移流程詳解
今天我們來聊一聊在FastApi里面,數(shù)據(jù)遷移工作,F(xiàn)astAPI是一個(gè)現(xiàn)代的,快速(高性能)python web框架。本文將利用fastapi實(shí)現(xiàn)數(shù)據(jù)表遷移功能,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-08-08
Python項(xiàng)目管理工具Poetry使用示例詳解
這篇文章主要為大家介紹了Python項(xiàng)目管理工具Poetry使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09

