· Hakan Çelik · OpenCV / Özellik Tespiti · 2 dk okuma
SURF'e Giriş (Hızlandırılmış Sağlam Özellikler)

OpenCV Serisi 37/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?
SURF’e Giriş (Hızlandırılmış Sağlam Özellikler)
Hedefler
Bu bölümde:
- SURF’un temellerini göreceğiz
- OpenCV’deki SURF işlevselliğini göreceğiz
Teori
Son bölümde anahtar nokta tespiti ve tanımlaması için SIFT’i gördük. Ancak görece yavaştı ve insanlar daha hızlandırılmış bir versiyona ihtiyaç duydu. 2006’da Bay, H., Tuytelaars, T. ve Van Gool, L. tarafından yayınlanan “SURF: Speeded Up Robust Features” adlı makalede SURF adında yeni bir algoritma tanıtıldı. Adından da anlaşılacağı gibi SIFT’in hızlandırılmış versiyonudur.
SIFT’te Lowe, ölçek uzayı bulmak için Gauss Laplace’ını Gauss Farkı ile yaklaştırdı. SURF biraz daha ileri giderek LoG’u Kutu Filtre ile yaklaştırır. Bu yaklaşımın büyük bir avantajı, kutu filtresiyle evrişimin integral görüntüler yardımıyla kolayca hesaplanabilmesidir. Ve farklı ölçekler için paralel olarak yapılabilir. Ayrıca SURF, hem ölçek hem de konum için Hessian matrisinin determinantına dayanır.
Yönelim ataması için SURF, 6s boyutundaki bir komşuluk için yatay ve dikey yönde dalgacık yanıtlarını kullanır. Gauss ağırlıkları da uygulanır.
Özellik tanımlaması için SURF, yatay ve dikey yönde Dalgacık yanıtlarını kullanır. Anahtar nokta etrafında 20s×20s boyutunda bir komşuluk alınır. 4×4 alt bölgelere bölünür. Her alt bölge için yatay ve dikey dalgacık yanıtları alınarak bir vektör oluşturulur:
v = (Σdx, Σdy, Σ|dx|, Σ|dy|)
Bu 64 boyutlu SURF özellik tanımlayıcısı verir. Daha fazla ayırt edicilik için 128 boyutlu genişletilmiş versiyon da mevcuttur.
Analiz, SIFT ile karşılaştırıldığında 3 kat daha hızlı olduğunu göstermektedir. SURF, bulanıklık ve döndürme içeren görüntüleri iyi işler.
OpenCV’de SURF
Not: SURF patentlidir ve opencv_contrib modülünde bulunur. Ticari uygulamalar için kullanmadan önce lisans gerekliliklerini kontrol edin.
img = cv.imread('fly.png', cv.IMREAD_GRAYSCALE)
# Hessian Eşiği 400 ile SURF nesnesi oluştur
surf = cv.xfeatures2d.SURF_create(400)
# Anahtar noktaları ve tanımlayıcıları doğrudan bul
kp, des = surf.detectAndCompute(img, None)
print(len(kp))
# 699Görüntüde göstermek için 50 civarına indirelim. Hessian Eşiğini artıralım:
surf.setHessianThreshold(50000)
kp, des = surf.detectAndCompute(img, None)
print(len(kp))
# 47
img2 = cv.drawKeypoints(img, kp, None, (255, 0, 0), 4)
plt.imshow(img2), plt.show()SURF’un blob dedektörüne daha çok benzediğini görebilirsiniz. Kelebek kanatlarındaki beyaz blob’ları tespit eder.
U-SURF uygulamak isterseniz (yönelim bulmaz, daha hızlıdır):
surf.setUpright(True)
kp = surf.detect(img, None)
img2 = cv.drawKeypoints(img, kp, None, (255, 0, 0), 4)
plt.imshow(img2), plt.show()128 boyutlu tanımlayıcı kullanmak için:
surf.setExtended(True)
kp, des = surf.detectAndCompute(img, None)
print(surf.descriptorSize()) # 128
print(des.shape) # (47, 128)
Hakan Çelik


