· Hakan Çelik · OpenCV / Hesaplamalı Fotoğrafçılık · 2 dk okuma
Görüntü Onarımı (Inpainting)

OpenCV Serisi 57/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?
Görüntü Onarımı (Inpainting)
Hedefler
- Eski fotoğraflardaki küçük gürültüleri, çizikleri vb. inpainting adı verilen bir yöntemle nasıl kaldıracağımızı öğreneceğiz
- OpenCV’deki inpainting işlevlerini göreceğiz
Temel Kavramlar
Evinizde siyah noktalar veya çizikler içeren eski, bozulmuş fotoğraflarınız olabilir. Bunları bir boyama aracında silmek işe yaramaz çünkü siyah yapıları yalnızca beyazla değiştirir. Bu durumlarda görüntü onarımı (image inpainting) tekniği kullanılır. Temel fikir basit: Bozuk işaretleri komşu piksellerle değiştirerek komşuluk gibi görünmesini sağlamak.

Bu amaç için çeşitli algoritmalar tasarlanmıştır ve OpenCV bunlardan ikisini sağlar. Her ikisine de aynı fonksiyon olan cv.inpaint() ile erişilir.
Algoritma 1: Telea (INPAINT_TELEA)
Alexandru Telea’nın 2004 tarihli “An Image Inpainting Technique Based on the Fast Marching Method” makalesine dayanır. Hızlı Yürüyüş Yöntemi (Fast Marching Method) tabanlıdır. Algoritma, onarılacak bölgenin sınırından başlar ve içeri doğru ilerleyerek her şeyi doldurur. Onarılacak pikselin komşuluğundaki tüm bilinen piksellerin normalize ağırlıklı toplamıyla pikseli değiştirir.
Algoritma 2: Navier-Stokes (INPAINT_NS)
Bertalmio vd.‘nin 2001 tarihli “Navier-Stokes, Fluid Dynamics, and Image and Video Inpainting” makalesine dayanır. Akışkanlar dinamiği ve kısmi diferansiyel denklemleri kullanır. Bilinen bölgelerden bilinmeyen bölgelere doğru kenarlar boyunca ilerler. Onarım bölgesinin sınırındaki gradyan vektörlerini eşleştirirken izofotları (eşit yoğunluklu noktaları birleştiren çizgiler) sürdürür.
Kod
Giriş görüntüsüyle aynı boyutta bir maske oluşturmamız gerekiyor; maskedeki sıfır olmayan pikseller onarılacak alanı gösterir:
import numpy as np
import cv2 as cv
img = cv.imread('messi_2.jpg')
mask = cv.imread('mask2.png', cv.IMREAD_GRAYSCALE)
dst = cv.inpaint(img, mask, 3, cv.INPAINT_TELEA)
cv.imshow('dst', dst)
cv.waitKey(0)
cv.destroyAllWindows()Aşağıda sonucu görebilirsiniz. İlk görüntü bozulmuş giriş, ikincisi maske, üçüncüsü birinci algoritmanın sonucu, sonuncusu ikinci algoritmanın sonucu:

Hakan Çelik


