python3+opencv3識別圖片中的圓形(霍夫變換)

在圖片裏識別足球

霍夫圓變換的幾個參數知識:

  • dp,用來檢測圓心的累加器圖像的分辨率於輸入圖像之比的倒數,且此參數允許創建一個比輸入圖像分辨率低的累加器。上述文字不好理解的話,來看例子吧。例如,如果dp= 1時,累加器和輸入圖像具有相同的分辨率。如果dp=2,累加器便有輸入圖像一半那麼大的寬度和高度。
  • minDist,爲霍夫變換檢測到的圓的圓心之間的最小距離,即讓我們的算法能明顯區分的兩個不同圓之間的最小距離。這個參數如果太小的話,多個相鄰的圓可能被錯誤地檢測成了一個重合的圓。反之,這個參數設置太大的話,某些圓就不能被檢測出來了。
  • param1,有默認值100。它是method設置的檢測方法的對應的參數。對當前唯一的方法霍夫梯度法,它表示傳遞給canny邊緣檢測算子的高閾值,而低閾值爲高閾值的一半。
  • param2,也有默認值100。它是method設置的檢測方法的對應的參數。對當前唯一的方法霍夫梯度法,它表示在檢測階段圓心的累加器閾值。它越小的話,就可以檢測到更多根本不存在的圓,而它越大的話,能通過檢測的圓就更加接近完美的圓形了。
  • minRadius,默認值0,表示圓半徑的最小值。
  • maxRadius,也有默認值0,表示圓半徑的最大值。


源代碼:

[python] view plain copy
  1. # -*- coding: utf-8 -*-  
  2. """ 
  3. Created on Tue Sep 26 23:15:39 2017 
  4.  
  5. @author: tina 
  6. """  
  7. import cv2  
  8. import numpy as np  
  9. import matplotlib.pyplot as plt  
  10.   
  11. img = cv2.imread('C:\\Users\\tina\\Pictures\\ahh\\ball.jpg')  
  12. gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)  
  13.   
  14. plt.subplot(121),plt.imshow(gray,'gray')  
  15. plt.xticks([]),plt.yticks([])  
  16.   
  17. circles1 = cv2.HoughCircles(gray,cv2.HOUGH_GRADIENT,1,  
  18. 600,param1=100,param2=30,minRadius=80,maxRadius=97)  
  19. circles = circles1[0,:,:]  
  20. circles = np.uint16(np.around(circles))  
  21. for i in circles[:]:   
  22.     cv2.circle(img,(i[0],i[1]),i[2],(255,0,0),5)  
  23.     cv2.circle(img,(i[0],i[1]),2,(255,0,255),10)  
  24.     cv2.rectangle(img,(i[0]-i[2],i[1]+i[2]),(i[0]+i[2],i[1]-i[2]),(255,255,0),5)  
  25.       
  26. print("圓心座標",i[0],i[1])  
  27. plt.subplot(122),plt.imshow(img)  
  28. plt.xticks([]),plt.yticks([])  

原圖:


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章