· Hakan Çelik · OpenCV / Hesaplamalı Fotoğrafçılık · 3 dk okuma

Görüntü Gürültü Giderme

OpenCV'de Non-Local Means algoritması ile görüntüdeki gürültüyü nasıl kaldıracağınızı öğrenin. cv.fastNlMeansDenoising() ve çoklu kare denoising fonksiyonlarını inceledik.
OpenCV Serisi 56/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?

Görüntü Gürültü Giderme

Hedefler

  • Görüntüdeki gürültüyü kaldırmak için Non-Local Means Denoising algoritmasını öğreneceğiz
  • cv.fastNlMeansDenoising(), cv.fastNlMeansDenoisingColored() gibi fonksiyonları inceleyeceğiz

Teori

Önceki bölümlerde Gauss Bulanıklaştırma, Medyan Bulanıklaştırma gibi pek çok görüntü düzleştirme tekniği gördük. Bu teknikler küçük miktarlardaki gürültüyü belirli ölçüde kaldırmak için iyiydi. Söz konusu tekniklerde pikselin etrafındaki küçük bir komşuluğu alarak gauss ağırlıklı ortalama, medyan gibi işlemler yapıp merkez elemanı değiştiriyorduk. Kısacası gürültü giderme, pikselin yerel komşuluğunda gerçekleşiyordu.

Gürültünün bir özelliği vardır: Gürültü genellikle sıfır ortalamaya sahip rastgele bir değişken kabul edilir. Gürültülü bir piksel düşünün: p = p0 + n — burada p0 pikselin gerçek değeri, n ise gürültüdür. Farklı görüntülerden aynı pikselin çok sayıda (N tane) örneğini alıp ortalamasını hesaplarsanız, gürültünün ortalaması sıfır olduğundan p = p0 elde edersiniz.

Fikir basit: Gürültüyü ortalamayla gidermek için benzer görüntülere ihtiyacımız var. Görüntüde küçük bir pencere (5x5 gibi) düşünün. Aynı yama görüntünün başka bir yerinde de bulunabilir. Bu benzer yamalar bir araya getirilerek ortalamaları alınırsa o piksel değiştirilir. Buna Non-Local Means Denoising denir.

Non-Local Means Yama

Görüntüdeki mavi yamalar birbirine benziyor, yeşil yamalar da birbirine benziyor. Bir piksel alınır, etrafında küçük bir pencere oluşturulur, görüntüde benzer pencereler aranır, tüm pencereler ortalaması alınır ve piksel bu sonuçla değiştirilir. Bu yöntem daha önce gördüğümüz bulanıklaştırma tekniklerinden daha fazla zaman alır, ancak sonuçları çok iyidir.

Renkli görüntüler için görüntü CIELAB renk uzayına dönüştürülür, ardından L ve AB bileşenleri ayrı ayrı gürültü giderilir.

OpenCV’de Görüntü Gürültü Giderme

OpenCV bu tekniğin dört çeşidini sağlar:

  1. cv.fastNlMeansDenoising() — tek gri tonlamalı görüntüyle çalışır
  2. cv.fastNlMeansDenoisingColored() — renkli görüntüyle çalışır
  3. cv.fastNlMeansDenoisingMulti() — kısa sürede çekilen görüntü dizisiyle çalışır (gri tonlamalı)
  4. cv.fastNlMeansDenoisingColoredMulti() — yukarıdakiyle aynı, renkli görüntüler için

Ortak parametreler:

  • h: Filtre gücünü belirler. Yüksek h değeri gürültüyü daha iyi giderir ama görüntü detaylarını da kaybeder (10 iyidir)
  • hForColorComponents: Yalnızca renkli görüntüler için h ile aynı (genellikle h ile aynı)
  • templateWindowSize: Tek sayı olmalı (7 önerilir)
  • searchWindowSize: Tek sayı olmalı (21 önerilir)

1. cv.fastNlMeansDenoisingColored()

Renkli görüntülerden gürültü kaldırmak için kullanılır (Gauss gürültüsü beklenir):

import numpy as np
import cv2 as cv
from matplotlib import pyplot as plt

img = cv.imread('die.png')

dst = cv.fastNlMeansDenoisingColored(img, None, 10, 10, 7, 21)

plt.subplot(121), plt.imshow(img)
plt.subplot(122), plt.imshow(dst)
plt.show()

Aşağıda sigma=25 Gauss gürültüsüyle bozulmuş giriş görüntüsünün büyütülmüş sonucu:

NLM Sonuç

2. cv.fastNlMeansDenoisingMulti()

Aynı yöntemi bir videoya uygulayalım. İlk argüman gürültülü kareler listesi, ikinci argüman imgToDenoiseIndex gürültü gidereceğimiz kareyi belirtir, üçüncüsü temporalWindowSize gürültü giderme için kullanılacak komşu kare sayısıdır (tek sayı olmalı):

import numpy as np
import cv2 as cv
from matplotlib import pyplot as plt

cap = cv.VideoCapture('vtest.avi')

# İlk 5 kareyi listeye al
img = [cap.read()[1] for i in range(5)]

# Tümünü gri tonlamaya çevir
gray = [cv.cvtColor(i, cv.COLOR_BGR2GRAY) for i in img]

# float64'e dönüştür
gray = [np.float64(i) for i in gray]

# Varyansı 25 olan gürültü oluştur
noise = np.random.randn(*gray[1].shape) * 10

# Gürültüyü görüntülere ekle
noisy = [i + noise for i in gray]

# uint8'e geri dönüştür
noisy = [np.uint8(np.clip(i, 0, 255)) for i in noisy]

# 3. kareyi, 5 kareyi dikkate alarak gürültü gider
dst = cv.fastNlMeansDenoisingMulti(noisy, 2, 5, None, 4, 7, 35)

plt.subplot(131), plt.imshow(gray[2], 'gray')
plt.subplot(132), plt.imshow(noisy[2], 'gray')
plt.subplot(133), plt.imshow(dst, 'gray')
plt.show()

Elde edilen sonucun büyütülmüş görünümü:

NLM Çoklu Kare

Hesaplama için önemli miktarda zaman gerektirir. Sonuçta: ilk görüntü orijinal kare, ikincisi gürültülü kare, üçüncüsü gürültü giderilmiş görüntü.


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.