· Hakan Çelik · OpenCV / Makine Öğrenmesi · 2 dk okuma
kNN ile El Yazısı OCR
OpenCV Serisi 51/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?
kNN ile El Yazısı OCR
Hedefler
Bu bölümde:
- Temel bir OCR uygulaması oluşturmak için kNN bilgisini kullanacağız
- OpenCV ile gelen Rakamlar ve Alfabe verisi üzerinde uygulamamızı deneyeceğiz
El Yazısı Rakamların OCR’si
Amacımız, el yazısıyla yazılmış rakamları okuyabilecek bir uygulama oluşturmaktır. OpenCV, 5000 el yazısı rakam içeren bir digits.png görüntüsüyle (her rakam için 500) birlikte gelir. Her rakam 20×20 piksel boyutundadır.
import numpy as np
import cv2 as cv
img = cv.imread('digits.png')
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
# Görüntüyü 5000 hücreye böl, her biri 20×20 boyutunda
cells = [np.hsplit(row, 100) for row in np.vsplit(gray, 50)]
# Numpy dizisine dönüştür: boyutu (50, 100, 20, 20) olacak
x = np.array(cells)
# Eğitim ve test verisi hazırla
train = x[:, :50].reshape(-1, 400).astype(np.float32) # Boyut = (2500, 400)
test = x[:, 50:100].reshape(-1, 400).astype(np.float32) # Boyut = (2500, 400)
# Eğitim ve test verisi için etiketler oluştur
k = np.arange(10)
train_labels = np.repeat(k, 250)[:, np.newaxis]
test_labels = train_labels.copy()
# kNN'i başlat, eğitim verisiyle eğit, ardından k=5 ile test verisiyle test et
knn = cv.ml.KNearest_create()
knn.train(train, cv.ml.ROW_SAMPLE, train_labels)
ret, result, neighbours, dist = knn.findNearest(test, k=5)
# Doğruluğu kontrol et
matches = result == test_labels
correct = np.count_nonzero(matches)
accuracy = correct * 100.0 / result.size
print(accuracy)Bu uygulama yaklaşık %91 doğruluk sağlar. Doğruluğu artırmak için özellikle hata yapılan rakamlar için daha fazla veri ekleyebilirsiniz.
Veriyi Kaydetme ve Yükleme
Uygulamayı her başlatışımda bu eğitim verisini bulmak yerine kaydetmek daha iyidir:
# Veriyi kaydet
np.savez('knn_data.npz', train=train, train_labels=train_labels)
# Veriyi yükle
with np.load('knn_data.npz') as data:
print(data.files)
train = data['train']
train_labels = data['train_labels']
Hakan Çelik


