· Hakan Çelik · OpenCV / İleri Konular · 4 dk okuma

Kontur Özellikleri

Konturların alan, çevre, ağırlık merkezi, sınır kutusu gibi farklı özelliklerini bulmayı öğrenin. cv2.moments(), cv2.contourArea(), cv2.minAreaRect() ve daha birçok fonksiyonu anlattım.
OpenCV Serisi 27/64
  1. 1. Boya Fırçası Olarak Fare
  2. 2. Canny Kenar Algılama
  3. 3. Görüntü Geçişleri
  4. 4. Görüntü Piramitleri
  5. 5. Görüntülerde Aritmetik İşlemler
  6. 6. Görüntülerle İlgili Temel İşlemler
  7. 7. Görüntünün Geometrik Dönüşümleri
  8. 8. Görüntüyü Yumuşatma - ( Smoothing Images )
  9. 9. Histogramlar
  10. 10. Konturler ( Contours )
  11. 11. Morfolojik Dönüşümler
  12. 12. Opencv Nedir Ve Kurulumu
  13. 13. Opencv Resim Işlemleri
  14. 14. Opencv Video Işlemleri
  15. 15. Opencv'de Çizim Fonksiyonları
  16. 16. Performans Ölçüm Ve Geliştirme Teknikleri
  17. 17. Renk Alanlarını Değiştirme
  18. 18. Renk Paleti Olarak Parça Çubuğu ( Trackbar )
  19. 19. Resim Eşikleme
  20. 20. Şablon Eşleştirme
  21. 21. Hough Doğru Dönüşümü
  22. 22. Hough Daire Dönüşümü
  23. 23. Fourier Dönüşümü
  24. 24. Histogram Eşitleme
  25. 25. 2B Histogramlar
  26. 26. Histogram Geri Projeksiyonu
  27. 27. Kontur Özellikleri
  28. 28. Kontur Nitelikleri
  29. 29. Konturlerle Daha Fazla İşlev
  30. 30. Kontur Hiyerarşisi
  31. 31. GrabCut ile Etkileşimli Ön Plan Çıkarma
  32. 32. Watershed Algoritması ile Görüntü Segmentasyonu
  33. 33. Özellikleri Anlamak
  34. 34. Harris Köşe Tespiti
  35. 35. Shi-Tomasi Köşe Dedektörü ve İzlenecek İyi Özellikler
  36. 36. SIFT'e Giriş (Ölçek Değişmez Özellik Dönüşümü)
  37. 37. SURF'e Giriş (Hızlandırılmış Sağlam Özellikler)
  38. 38. Köşe Tespiti için FAST Algoritması
  39. 39. BRIEF — İkili Sağlam Bağımsız Temel Özellikler
  40. 40. ORB (Yönlü FAST ve Döndürülmüş BRIEF)
  41. 41. Özellik Eşleştirme
  42. 42. Özellik Eşleştirme + Nesneleri Bulmak için Homografi
  43. 43. Meanshift ve Camshift ile Nesne Takibi
  44. 44. Optik Akış
  45. 45. Arka Plan Çıkarma
  46. 46. Kamera Kalibrasyonu
  47. 47. Poz Tahmini
  48. 48. Epipolar Geometri
  49. 49. Stereo Görüntülerden Derinlik Haritası
  50. 50. k-En Yakın Komşuyu Anlamak
  51. 51. kNN ile El Yazısı OCR
  52. 52. SVM'yi Anlamak
  53. 53. SVM ile El Yazısı OCR
  54. 54. K-Ortalamalar Kümeleme'yi Anlamak
  55. 55. OpenCV'de K-Ortalamalar Kümeleme
  56. 56. Görüntü Gürültü Giderme
  57. 57. Görüntü Onarımı (Inpainting)
  58. 58. Yüksek Dinamik Aralık (HDR) Görüntüleme
  59. 59. Haar Cascade ile Yüz Tespiti
  60. 60. pip ile OpenCV Kurulumu
  61. 61. Ubuntu'da OpenCV-Python Kurulumu
  62. 62. Fedora'da OpenCV-Python Kurulumu
  63. 63. Windows'ta OpenCV-Python Kurulumu
  64. 64. OpenCV-Python Bağlayıcıları Nasıl Çalışır?

Kontur Özellikleri

Hedefler

Bu makalede öğrenecekleriniz:

  • Konturların alan, çevre, ağırlık merkezi, sınır kutusu gibi farklı özelliklerini bulmak
  • Konturlarla ilgili pek çok fonksiyon göreceksiniz

1. Momentler

Görüntü momentleri, nesnenin ağırlık merkezi, alan gibi bazı özellikleri hesaplamanıza yardımcı olur.

cv2.moments() fonksiyonu, hesaplanan tüm moment değerlerinin bir sözlüğünü döndürür:

import numpy as np
import cv2 as cv

img = cv.imread('star.jpg', cv.IMREAD_GRAYSCALE)
assert img is not None, "Dosya okunamadı, os.path.exists() ile kontrol edin"
ret, thresh = cv.threshold(img, 127, 255, 0)
contours, hierarchy = cv.findContours(thresh, 1, 2)

cnt = contours[0]
M = cv.moments(cnt)
print(M)

Bu momentlerden alan, ağırlık merkezi gibi faydalı veriler elde edebilirsiniz. Ağırlık merkezi şu bağıntılarla verilir: Cx = M10 / M00 ve Cy = M01 / M00:

cx = int(M['m10'] / M['m00'])
cy = int(M['m01'] / M['m00'])

2. Kontur Alanı

Kontur alanı cv2.contourArea() fonksiyonu veya momentlerden M['m00'] ile elde edilir:

area = cv.contourArea(cnt)

3. Kontur Çevresi

Yay uzunluğu olarak da adlandırılır. cv2.arcLength() fonksiyonu ile bulunabilir. İkinci argüman şeklin kapalı bir kontur mu (True geçilirse) yoksa sadece bir eğri mi olduğunu belirtir:

perimeter = cv.arcLength(cnt, True)

4. Kontur Yaklaşımı

Belirlediğimiz hassasiyete bağlı olarak bir kontur şeklini daha az köşe noktalı başka bir şekle yaklaştırır. Bu, Douglas-Peucker algoritmasının bir uygulamasıdır.

Bunu anlamak için görüntüde bir kare bulmaya çalıştığınızı, ancak bazı sorunlar nedeniyle mükemmel bir kare değil “bozuk bir şekil” elde ettiğinizi düşünün. Şimdi bu fonksiyonu kullanarak şekli yaklaştırabilirsiniz. İkinci argüman epsilon’dır; kontur ile yaklaşık kontur arasındaki maksimum uzaklıktır. Doğru çıktıyı elde etmek için epsilon’ın akıllıca seçilmesi gerekir:

epsilon = 0.1 * cv.arcLength(cnt, True)
approx = cv.approxPolyDP(cnt, epsilon, True)

Aşağıda ikinci görüntüde yeşil çizgi, yay uzunluğunun %10’u kadar epsilon için yaklaştırılmış eğriyi göstermektedir. Üçüncü görüntü, yay uzunluğunun %1’i kadar epsilon için aynı durumu göstermektedir:

Kontur yaklaşımı

5. Dışbükey Zarf (Convex Hull)

Dışbükey zarf, kontur yaklaşımına benzeyebilir ancak aynı değildir. cv2.convexHull() fonksiyonu bir eğriyi dışbükeylik kusurları açısından kontrol eder ve düzeltir. Genel olarak dışbükey eğriler, her zaman dışa doğru şişmiş veya en azından düz olan eğrilerdir. İçe doğru şişmişse buna dışbükeylik kusuru denir. Örneğin el görüntüsüne bakın. Kırmızı çizgi elin dışbükey zarfını göstermektedir. Çift taraflı ok işaretleri, zarfın konturlardan yerel maksimum sapmalarını gösteren dışbükeylik kusurlarını işaret etmektedir:

Dışbükey zarf

Sözdizimi hakkında:

hull = cv.convexHull(points[, hull[, clockwise[, returnPoints]]])

Argüman ayrıntıları:

  • points: İçine aktardığımız konturlardır.
  • hull: Çıktıdır, genellikle atlıyoruz.
  • clockwise: Yönelim bayrağı. True ise çıktı dışbükey zarfı saat yönünde yönelimlidir; aksi hâlde saat yönünün tersindedir.
  • returnPoints: Varsayılan olarak True. O zaman zarf noktalarının koordinatlarını döndürür. False ise zarf noktalarına karşılık gelen kontur noktalarının indekslerini döndürür.

Yukarıdaki görüntüdeki gibi bir dışbükey zarf elde etmek için aşağıdaki yeterlidir:

hull = cv.convexHull(cnt)

6. Dışbükeylik Kontrolü

Bir eğrinin dışbükey olup olmadığını kontrol etmek için cv2.isContourConvex() fonksiyonu vardır. Yalnızca True veya False döndürür:

k = cv.isContourConvex(cnt)

7. Sınır Dikdörtgeni

İki tür sınır dikdörtgeni vardır.

7a. Düz Sınır Dikdörtgeni

Nesnenin dönüşünü dikkate almayan düz bir dikdörtgendir. cv2.boundingRect() fonksiyonu ile bulunur. (x, y) dikdörtgenin sol üst koordinatı, (w, h) ise genişliği ve yüksekliğidir:

x, y, w, h = cv.boundingRect(cnt)
cv.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)

7b. Döndürülmüş Dikdörtgen

Burada sınır dikdörtgeni minimum alanla çizilir, bu nedenle dönüşü de dikkate alır. Kullanılan fonksiyon cv2.minAreaRect()’tir. Şu ayrıntıları içeren bir Box2D yapısı döndürür: (merkez (x, y), (genişlik, yükseklik), dönüş açısı). Ancak bu dikdörtgeni çizmek için cv2.boxPoints() fonksiyonu ile 4 köşeye ihtiyaç duyarız:

rect = cv.minAreaRect(cnt)
box = cv.boxPoints(rect)
box = np.int0(box)
cv.drawContours(img, [box], 0, (0, 0, 255), 2)

Her iki dikdörtgen tek bir görüntüde gösterilmiştir. Yeşil dikdörtgen normal sınır dikdörtgeni, kırmızı dikdörtgen ise döndürülmüş dikdörtgendir:

Sınır dikdörtgenleri

8. Minimum Kapsayan Daire

Sonraki adımda cv2.minEnclosingCircle() fonksiyonu ile bir nesnenin çevrel dairesini buluruz. Bu, nesneyi minimum alanla tamamen kapsayan bir dairedir:

(x, y), radius = cv.minEnclosingCircle(cnt)
center = (int(x), int(y))
radius = int(radius)
cv.circle(img, center, radius, (0, 255, 0), 2)

Minimum kapsayan daire

9. Elips Uydurma

Sonraki adım, bir nesneye elips uydurmaktır. Elipsin içine yerleştirildiği döndürülmüş dikdörtgeni döndürür:

ellipse = cv.fitEllipse(cnt)
cv.ellipse(img, ellipse, (0, 255, 0), 2)

Elips uydurma

10. Doğru Uydurma

Benzer biçimde bir dizi noktaya doğru uydurabiliriz. Aşağıdaki görüntü bir dizi beyaz nokta içermektedir. Ona düz bir doğru yaklaştırabiliriz:

rows, cols = img.shape[:2]
[vx, vy, x, y] = cv.fitLine(cnt, cv.DIST_L2, 0, 0.01, 0.01)
lefty = int((-x * vy / vx) + y)
righty = int(((cols - x) * vy / vx) + y)
cv.line(img, (cols - 1, righty), (0, lefty), (0, 255, 0), 2)

Doğru uydurma


Kaynak: OpenCV Python Tutorials — Orijinal Döküman

Back to Blog

Related Posts

View All Posts »
OpenCV-Python Bağlayıcıları Nasıl Çalışır?

OpenCV-Python Bağlayıcıları Nasıl Çalışır?

OpenCV · 3 dk

OpenCV-Python bağlayıcılarının nasıl oluşturulduğunu öğrenin. C++ modüllerinin Python'a nasıl aktarıldığını, CV_EXPORTS_W, CV_WRAP gibi makroları ve gen2.py üreteci ile hdr_parser.py başlık ayrıştırıcısını anlattım.

Haar Cascade ile Yüz Tespiti

Haar Cascade ile Yüz Tespiti

OpenCV · 3 dk

OpenCV'de Haar Cascade sınıflandırıcılarını kullanarak yüz ve göz tespiti yapın. cv.CascadeClassifier ile gerçek zamanlı nesne tespitinin temellerini anlattım.

Görüntü Onarımı (Inpainting)

Görüntü Onarımı (Inpainting)

OpenCV · 2 dk

Eski fotoğraflardaki hasarları, çizikleri ve lekeleri OpenCV'nin cv.inpaint() fonksiyonu ile nasıl onaracağınızı öğrenin. Telea ve Navier-Stokes algoritmalarını anlattım.