· Hakan Çelik · OpenCV / Makine Öğrenmesi · 2 dk okuma
k-En Yakın Komşuyu Anlamak
OpenCV Serisi 50/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?
k-En Yakın Komşuyu Anlamak
Hedefler
Bu bölümde, k-En Yakın Komşu (kNN) algoritmasının kavramlarını anlayacağız.
Teori
kNN, denetimli öğrenme için mevcut en basit sınıflandırma algoritmalarından biridir. Fikir, özellik uzayındaki test verilerinin en yakın eşleşmelerini aramaktır.
Görüntüde iki aile var: Mavi Kareler ve Kırmızı Üçgenler. Her aileye Sınıf diyoruz. Onların evleri, Özellik Uzayı adını verdiğimiz kasaba haritalarında gösterilir.
Şimdi kasabaya yeni bir üye gelir ve yeni bir ev kurulur (yeşil daire). Bu yeni üyeyi Mavi veya Kırmızı ailelerden birine eklememiz gerekir. Bu sürece Sınıflandırma diyoruz.
Basit bir yöntem, en yakın komşunun kim olduğunu kontrol etmektir. Bu durumda Kırmızı Üçgen ailesidir. Bu En Yakın Komşu sınıflandırması olarak adlandırılır.
Ancak bu yaklaşımla bir sorun var: Kırmızı Üçgen en yakın komşu olabilir, ama yakında çok sayıda Mavi Kare de varsa? Bunun yerine k en yakın aile kontrol edilebilir — hangi aile çoğunluktaysa yeni üye o aileye ait olur. Bu yönteme k-En Yakın Komşu denir.
Hepsine eşit önem vermek yerine, uzaklığa göre ağırlık verilebilir: yeni gelene daha yakın olanlar daha yüksek ağırlık alır. Buna ağırlıklı kNN denir.
OpenCV’de kNN
import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt
# 25 bilinen/eğitim verisinin (x, y) değerlerini içeren özellik seti
trainData = np.random.randint(0, 100, (25, 2)).astype(np.float32)
# Her birini Kırmızı (0) veya Mavi (1) olarak etiketle
responses = np.random.randint(0, 2, (25, 1)).astype(np.float32)
# Kırmızı komşuları al ve çiz
red = trainData[responses.ravel() == 0]
plt.scatter(red[:, 0], red[:, 1], 80, 'r', '^')
# Mavi komşuları al ve çiz
blue = trainData[responses.ravel() == 1]
plt.scatter(blue[:, 0], blue[:, 1], 80, 'b', 's')
plt.show()
# Şimdi yeni bir girdi al ve onun nasıl sınıflandırıldığına bak
newcomer = np.random.randint(0, 100, (1, 2)).astype(np.float32)
plt.scatter(newcomer[:, 0], newcomer[:, 1], 80, 'g', 'o')
knn = cv.ml.KNearest_create()
knn.train(trainData, cv.ml.ROW_SAMPLE, responses)
ret, results, neighbours, dist = knn.findNearest(newcomer, 3)
print("result: {}\n".format(results))
print("neighbours: {}\n".format(neighbours))
print("distance: {}\n".format(dist))
plt.show()![]()
![]()
Hakan Çelik


