· Hakan Çelik · OpenCV / Görüntü İşleme · 2 dk okuma
Hough Daire Dönüşümü

OpenCV Serisi 22/64
- 1. Boya Fırçası Olarak Fare
- 2. Canny Kenar Algılama
- 3. Görüntü Geçişleri
- 4. Görüntü Piramitleri
- 5. Görüntülerde Aritmetik İşlemler
- 6. Görüntülerle İlgili Temel İşlemler
- 7. Görüntünün Geometrik Dönüşümleri
- 8. Görüntüyü Yumuşatma - ( Smoothing Images )
- 9. Histogramlar
- 10. Konturler ( Contours )
- 11. Morfolojik Dönüşümler
- 12. Opencv Nedir Ve Kurulumu
- 13. Opencv Resim Işlemleri
- 14. Opencv Video Işlemleri
- 15. Opencv'de Çizim Fonksiyonları
- 16. Performans Ölçüm Ve Geliştirme Teknikleri
- 17. Renk Alanlarını Değiştirme
- 18. Renk Paleti Olarak Parça Çubuğu ( Trackbar )
- 19. Resim Eşikleme
- 20. Şablon Eşleştirme
- 21. Hough Doğru Dönüşümü
- 22. Hough Daire Dönüşümü
- 23. Fourier Dönüşümü
- 24. Histogram Eşitleme
- 25. 2B Histogramlar
- 26. Histogram Geri Projeksiyonu
- 27. Kontur Özellikleri
- 28. Kontur Nitelikleri
- 29. Konturlerle Daha Fazla İşlev
- 30. Kontur Hiyerarşisi
- 31. GrabCut ile Etkileşimli Ön Plan Çıkarma
- 32. Watershed Algoritması ile Görüntü Segmentasyonu
- 33. Özellikleri Anlamak
- 34. Harris Köşe Tespiti
- 35. Shi-Tomasi Köşe Dedektörü ve İzlenecek İyi Özellikler
- 36. SIFT'e Giriş (Ölçek Değişmez Özellik Dönüşümü)
- 37. SURF'e Giriş (Hızlandırılmış Sağlam Özellikler)
- 38. Köşe Tespiti için FAST Algoritması
- 39. BRIEF — İkili Sağlam Bağımsız Temel Özellikler
- 40. ORB (Yönlü FAST ve Döndürülmüş BRIEF)
- 41. Özellik Eşleştirme
- 42. Özellik Eşleştirme + Nesneleri Bulmak için Homografi
- 43. Meanshift ve Camshift ile Nesne Takibi
- 44. Optik Akış
- 45. Arka Plan Çıkarma
- 46. Kamera Kalibrasyonu
- 47. Poz Tahmini
- 48. Epipolar Geometri
- 49. Stereo Görüntülerden Derinlik Haritası
- 50. k-En Yakın Komşuyu Anlamak
- 51. kNN ile El Yazısı OCR
- 52. SVM'yi Anlamak
- 53. SVM ile El Yazısı OCR
- 54. K-Ortalamalar Kümeleme'yi Anlamak
- 55. OpenCV'de K-Ortalamalar Kümeleme
- 56. Görüntü Gürültü Giderme
- 57. Görüntü Onarımı (Inpainting)
- 58. Yüksek Dinamik Aralık (HDR) Görüntüleme
- 59. Haar Cascade ile Yüz Tespiti
- 60. pip ile OpenCV Kurulumu
- 61. Ubuntu'da OpenCV-Python Kurulumu
- 62. Fedora'da OpenCV-Python Kurulumu
- 63. Windows'ta OpenCV-Python Kurulumu
- 64. OpenCV-Python Bağlayıcıları Nasıl Çalışır?
Hough Daire Dönüşümü
Hedefler
Bu bölümde öğrenecekleriniz:
- Bir görüntüdeki daireleri bulmak için Hough Dönüşümünü kullanmak
- Şu fonksiyonu göreceksiniz:
cv2.HoughCircles()
Teori
Bir daire matematiksel olarak şöyle ifade edilir:
(x - x_merkez)² + (y - y_merkez)² = r²
Burada (x_merkez, y_merkez) dairenin merkezi, r ise yarıçapıdır. Bu denklemden 3 parametremiz olduğu görülmektedir; dolayısıyla Hough dönüşümü için 3 boyutlu bir akümülatöre ihtiyaç duyulur ve bu oldukça verimsiz olur. Bu nedenle OpenCV, kenarların gradyan bilgisini kullanan daha akıllı bir yöntem olan Hough Gradyan Yöntemini kullanır.
OpenCV’de Hough Daire Dönüşümü
Kullanacağımız fonksiyon cv2.HoughCircles()’dır. Pek çok argümanı vardır ve bunlar dokümantasyonda ayrıntılı biçimde açıklanmıştır. Doğrudan koda geçelim:
import numpy as np
import cv2 as cv
img = cv.imread('opencv-logo-white.png', cv.IMREAD_GRAYSCALE)
assert img is not None, "Dosya okunamadı, os.path.exists() ile kontrol edin"
img = cv.medianBlur(img, 5)
cimg = cv.cvtColor(img, cv.COLOR_GRAY2BGR)
circles = cv.HoughCircles(img, cv.HOUGH_GRADIENT, 1, 20,
param1=50, param2=30, minRadius=0, maxRadius=0)
circles = np.uint16(np.around(circles))
for i in circles[0, :]:
# Dış daireyi çiz
cv.circle(cimg, (i[0], i[1]), i[2], (0, 255, 0), 2)
# Dairenin merkezini çiz
cv.circle(cimg, (i[0], i[1]), 2, (0, 0, 255), 3)
cv.imshow('Tespit Edilen Daireler', cimg)
cv.waitKey(0)
cv.destroyAllWindows()Fonksiyon Parametreleri
- image: 8-bit, tek kanallı gri tonlamalı girdi görüntüsü.
- method: Tespit yöntemi — şu an için yalnızca
cv2.HOUGH_GRADIENTdesteklenmektedir. - dp: Akümülatör çözünürlüğünün görüntü çözünürlüğüne oranı. Örneğin
dp=1ile akümülatör görüntüyle aynı çözünürlüğe sahip olur,dp=2ile yarı çözünürlükte olur. - minDist: Tespit edilen dairelerin merkezleri arasındaki minimum mesafe. Çok küçük bir değer birden fazla iç içe daire tespit edebilir; çok büyük ise bazı daireler kaçırılabilir.
- param1: Yönteme özgü ilk parametre.
HOUGH_GRADIENTiçin Canny kenar tespitine geçirilen üst eşik değeridir (alt eşik yarısı kadar olur). - param2: Yönteme özgü ikinci parametre.
HOUGH_GRADIENTiçin akümülatör eşiğidir. Küçüldükçe daha fazla (yanlış) daire tespit edilir. - minRadius: Minimum daire yarıçapı.
- maxRadius: Maksimum daire yarıçapı.
Sonuç aşağıda gösterilmektedir:

Hakan Çelik


