· Hakan Çelik · OpenCV / Video Analizi · 3 dk okuma

Meanshift ve Camshift ile Nesne Takibi

Meanshift ve Camshift algoritmalarını kullanarak nesneleri görüntülerde takip etmeyi öğrenin. cv2.meanShift() ve cv2.CamShift() fonksiyonlarını renk histogramıyla nesne takibinde anlattım.
OpenCV Serisi 43/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?

Meanshift ve Camshift ile Nesne Takibi

Hedefler

Bu bölümde:

  • Nesneleri takip etmek için Meanshift ve Camshift algoritmaları hakkında bilgi edineceğiz
  • cv.meanShift() ve cv.CamShift() fonksiyonlarını öğreneceğiz

Meanshift

Meanshift algoritmasının arkasındaki fikir çok basittir. Bir nokta setiniz olduğunu varsayalım (piksel dağılımı, histogram gibi olabilir). Küçük bir pencere verildiğinde, bu pencereyi maksimum yoğunluklu bölgeye (veya en fazla nokta sayısına) taşımak istiyorsunuz. Aşağıdaki basit görüntüde gösterildiği gibi:

Başlangıç penceresi mavi daire ile “C1” etiketiyle gösterilir. Orijinal merkezi “C1_o” noktasıyla gösterilen mavi dikdörtgen olarak gösterilir. Pencerenin içindeki tüm noktaların centroidini hesaplarsanız, bu noktaların ağırlık merkezini “C1_r” ile gösterilen bir noktada elde edersiniz ve pencereyi yeni merkeze taşırsınız. Süreci tekrar uygularsınız, pencereyi taşırsınız ta ki yakınsayıncaya kadar, yani pencere merkezi ve centroid aynı yerde olana kadar.

OpenCV’de Meanshift

OpenCV’de Meanshift kullanmak için önce hedef nesneyi tanımlamamız gerekiyor. Bu nesneyi bir histogram ile temsil ediyoruz. Hedef nesneyi başlangıçta elle seçiyoruz veya buluyoruz. Sonra her karedeki nesneyi takip etmek için cv.meanShift() kullanıyoruz.

import numpy as np
import cv2 as cv

cap = cv.VideoCapture('slow.flv')

# nesnenin başlangıç konumunu al
ret, frame = cap.read()

# kurulum için r, h, c, w'yi değiştirin
r, h, c, w = 250, 90, 400, 125
track_window = (c, r, w, h)

# ilgi bölgesini kur
roi = frame[r:r+h, c:c+w]
hsv_roi = cv.cvtColor(roi, cv.COLOR_BGR2HSV)
mask = cv.inRange(hsv_roi, np.array((0., 60., 32.)), np.array((180., 255., 255.)))
roi_hist = cv.calcHist([hsv_roi], [0], mask, [180], [0, 180])
cv.normalize(roi_hist, roi_hist, 0, 255, cv.NORM_MINMAX)

# Sonlandırma kriteri: 10 iterasyon veya en az 1 piksel hareket et
term_crit = (cv.TERM_CRITERIA_EPS | cv.TERM_CRITERIA_COUNT, 10, 1)

while True:
    ret, frame = cap.read()

    if ret == True:
        hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV)
        dst = cv.calcBackProject([hsv], [0], roi_hist, [0, 180], 1)

        # meanshift uygula
        ret, track_window = cv.meanShift(dst, track_window, term_crit)

        # sonucu resme çiz
        x, y, w, h = track_window
        img2 = cv.rectangle(frame, (x, y), (x + w, y + h), 255, 2)
        cv.imshow('img2', img2)

        k = cv.waitKey(30) & 0xff
        if k == 27:
            break
    else:
        break

Camshift

Dikkat ettiniz mi, Meanshift pencerenin boyutunu değiştirmiyor. Nesne kameraya yaklaşırken pencere aynı boyutta kalıyor, bu iyi değil. Bu sorunu çözmek için CAMshift (Sürekli Uyarlanabilir Meanshift) algoritması önerildi.

Camshift, önce nesnenin renginin geri projeksiyonunu hesaplar. Ardından Meanshift’i uygular. Meanshift yakınsadıktan sonra pencere boyutunu ve yönelimini güncelliyor. Sonra pencereyi küçük bir miktarda genişletiyor ve yeni boyutu bulmak için Meanshift’i yeniden uyguluyor. Bu süreç yakınsamaya kadar devam eder.

import numpy as np
import cv2 as cv

cap = cv.VideoCapture('slow.flv')

ret, frame = cap.read()
r, h, c, w = 250, 90, 400, 125
track_window = (c, r, w, h)

roi = frame[r:r+h, c:c+w]
hsv_roi = cv.cvtColor(roi, cv.COLOR_BGR2HSV)
mask = cv.inRange(hsv_roi, np.array((0., 60., 32.)), np.array((180., 255., 255.)))
roi_hist = cv.calcHist([hsv_roi], [0], mask, [180], [0, 180])
cv.normalize(roi_hist, roi_hist, 0, 255, cv.NORM_MINMAX)

term_crit = (cv.TERM_CRITERIA_EPS | cv.TERM_CRITERIA_COUNT, 10, 1)

while True:
    ret, frame = cap.read()

    if ret == True:
        hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV)
        dst = cv.calcBackProject([hsv], [0], roi_hist, [0, 180], 1)

        # Meanshift yerine Camshift uygula
        ret, track_window = cv.CamShift(dst, track_window, term_crit)

        # döndürülmüş dikdörtgen çiz
        pts = cv.boxPoints(ret)
        pts = np.int0(pts)
        img2 = cv.polylines(frame, [pts], True, 255, 2)
        cv.imshow('img2', img2)

        k = cv.waitKey(30) & 0xff
        if k == 27:
            break
    else:
        break

Camshift, nesne büyürken veya küçülürken pencereyi uygun şekilde ölçeklendirir, bu onu Meanshift’ten çok daha sağlam kılar.

Ek Kaynaklar

  1. Camshift algoritması üzerine French Wikipedia makalesine dayalı İngilizce makale
  2. Bradski, G.R., “Computer Vision Face Tracking For Use in a Perceptual User Interface”, Intel Technology Journal, Q2 1998

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.