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

Yüksek Dinamik Aralık (HDR) Görüntüleme

OpenCV'de farklı pozlama değerlerine sahip fotoğraflardan HDR görüntü oluşturmayı öğrenin. Debevec, Robertson ve Mertens füzyon yöntemlerini anlattım.
OpenCV Serisi 58/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?

Yüksek Dinamik Aralık (HDR) Görüntüleme

Hedefler

  • Pozlama dizisinden HDR görüntü oluşturmayı ve görüntülemeyi öğreneceğiz
  • Pozlama dizisini birleştirmek için exposure fusion kullanacağız

Teori

Yüksek Dinamik Aralık Görüntüleme (HDRI veya HDR), standart dijital görüntüleme veya fotoğrafçılık tekniklerinden daha geniş bir parlaklık dinamik aralığını yeniden üretmek için kullanılan bir tekniktir. İnsan gözü geniş bir ışık koşulları yelpazesine uyum sağlayabilirken, çoğu görüntüleme cihazı kanal başına 8 bit kullanır ve yalnızca 256 seviyeyle sınırlıdır.

Gerçek dünya sahnelerinin fotoğraflarını çekerken parlak bölgeler aşırı pozlanabilir, karanlık bölgeler ise az pozlanabilir. HDR görüntüleme, kanal başına 8 bitten fazla (genellikle 32 bit float değerler) kullanan görüntülerle çalışır ve çok daha geniş bir dinamik aralıka olanak tanır.

HDR görüntü elde etmenin en yaygın yolu, farklı pozlama değerleriyle çekilen fotoğrafları kullanmaktır. Bu pozlamaları birleştirmek için kameranın yanıt fonksiyonunu bilmek faydalıdır. HDR görüntü oluşturulduktan sonra normal ekranlarda görüntülemek için 8 bit’e dönüştürülmesi gerekir; bu işleme tonemapping denir.

Bu öğreticide iki algoritma (Debevec, Robertson) kullanarak pozlama dizisinden HDR görüntü oluşturmayı ve HDR verisi gerektirmeyen bir alternatif olan exposure fusion (Mertens) yaklaşımını göstereceğiz.

Pozlama Dizisiyle HDR

15, 2.5, 1/4 ve 1/30 saniyelik pozlama sürelerine sahip 4 fotoğraftan oluşan sahneye bakacağız:

Pozlama Dizisi

1. Pozlama görüntülerini listeye yükleme

İlk aşama tüm görüntüleri bir listeye yüklemektir. Normal HDR algoritmaları için pozlama sürelerine de ihtiyacımız var. Görüntüler 8 bit (np.uint8), pozlama süreleri float32 ve saniye cinsinden olmalıdır:

import cv2 as cv
import numpy as np

# Pozlama görüntülerini listeye yükle
img_fn = ["img0.jpg", "img1.jpg", "img2.jpg", "img3.jpg"]
img_list = [cv.imread(fn) for fn in img_fn]
exposure_times = np.array([15.0, 2.5, 0.25, 0.0333], dtype=np.float32)

2. Pozlamaları HDR görüntüde birleştirme

İki yöntem sunuyoruz: Debevec ve Robertson. HDR görüntüsü uint8 değil float32 tipindedir:

# Pozlamaları HDR görüntüde birleştir
merge_debevec = cv.createMergeDebevec()
hdr_debevec = merge_debevec.process(img_list, times=exposure_times.copy())
merge_robertson = cv.createMergeRobertson()
hdr_robertson = merge_robertson.process(img_list, times=exposure_times.copy())

3. HDR görüntüyü tonemapping ile dönüştürme

32 bit float HDR verisini [0..1] aralığına eşliyoruz:

# Gamma düzeltmesi ile tonemapping (standart ekran parlaklığı için gamma=2.2)
tonemap1 = cv.createTonemap(gamma=2.2)
res_debevec = tonemap1.process(hdr_debevec.copy())
res_robertson = tonemap1.process(hdr_robertson.copy())

4. Mertens füzyonu ile pozlamaları birleştirme

Pozlama sürelerine ihtiyaç duymayan alternatif bir algoritma. Mertens algoritması zaten [0..1] aralığında sonuç verir, tonemapping gerekmez:

# Mertens ile exposure fusion
merge_mertens = cv.createMergeMertens()
res_mertens = merge_mertens.process(img_list)

5. 8 bit’e dönüştürme ve kaydetme

# 8 bit'e dönüştür ve kaydet
res_debevec_8bit = np.clip(res_debevec * 255, 0, 255).astype('uint8')
res_robertson_8bit = np.clip(res_robertson * 255, 0, 255).astype('uint8')
res_mertens_8bit = np.clip(res_mertens * 255, 0, 255).astype('uint8')

cv.imwrite("ldr_debevec.jpg", res_debevec_8bit)
cv.imwrite("ldr_robertson.jpg", res_robertson_8bit)
cv.imwrite("fusion_mertens.jpg", res_mertens_8bit)

Sonuçlar

Her algoritmanın sonuçlarını görebilirsiniz. Her algoritmanın istenilen sonucu elde etmek için ayarlanabilir ek parametreler olduğunu unutmayın.

Debevec:

LDR Debevec

Robertson:

LDR Robertson

Mertens Füzyonu:

Mertens Füzyon

Kamera Yanıt Fonksiyonunu Tahmin Etme

Kamera yanıt fonksiyonu (CRF), sahne radyansı ile ölçülen yoğunluk değerleri arasındaki bağlantıyı verir. Ters kamera yanıt fonksiyonunu tahmin edip HDR birleştirme için kullanabiliriz:

# Kamera yanıt fonksiyonunu tahmin et (CRF)
cal_debevec = cv.createCalibrateDebevec()
crf_debevec = cal_debevec.process(img_list, times=exposure_times)
hdr_debevec = merge_debevec.process(img_list, times=exposure_times.copy(), response=crf_debevec.copy())
cal_robertson = cv.createCalibrateRobertson()
crf_robertson = cal_robertson.process(img_list, times=exposure_times)
hdr_robertson = merge_robertson.process(img_list, times=exposure_times.copy(), response=crf_robertson.copy())

Kamera yanıt fonksiyonu her renk kanalı için 256 uzunluklu bir vektörle temsil edilir:

CRF


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.

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

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

OpenCV · 3 dk

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.