· Hakan Çelik · OpenCV / Görüntü İşleme · 3 dk okuma

Görüntü Piramitleri

Görüntü piramitlerini öğreneceğiz Biz görüntü piramitleri yeni bir meyve oluşturmak için kullanacağız, 'Orapple” ve bu fonksiyonları göreceğiz: cv2.pyrUp(), cv2.pyridge()
OpenCV Serisi 4/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ü Piramitleri

Image Pyramids

Hedef

Bu bölümde,

  • Görüntü piramitlerini öğreneceğiz
  • Biz görüntü piramitleri yeni bir meyve oluşturmak için kullanacağız, “Orapple”
  • ve bu fonksiyonları göreceğiz: cv2.pyrUp(), cv2.pyridge()

Teori

Normalde, sabit boyutlu bir görüntü ile çalışırdık. Ama bazı durumlarda, aynı görüntünün farklı çözünürlük görüntüleri ile çalışmak gerekir. Örneğin, bir görüntüde bir şey ararken yüz gibi, nesnenin görüntüde ne boyutta olabileceğine emin olamayız. Bu durumda farklı çözünürlük ve tüm görüntülerde nesne aramak için görüntü kümesi oluşturmak gerekir. Farklı çözünürlüğe sahip bu görüntü kümesine görüntü piramitleri denir ( çünkü en alttaki en büyük görüntü ve en üstteki en küçük görüntü ile yığında tutuldukları zaman piramitlere benzer. ).

İki çeşit görüntü piramidi vardır

  • Gaussian Pyramid ( Gauss piramidi )
  • Laplacian Pyramids ( Laplacian piramitleri )

Gaussian piramidi yüksek düzey ( düşük çözünürlük ) düşük düzey (yüksek çözünürlük) resim ( görüntü )deki ardışık satır ve sütunları kaldırarak oluşturulur. Daha sonra daha yüksek düzeydeki her piksel Gauss ağırlıkları ile temel düzeyde 5 pikselden gelen katkıyla oluşur.

Bunu yaparak bir , M x X görüntüsü M/2 x N/2 görüntüsü olur.

Yani alan orijinal alanın dörtte birine düşer. Buna oktav ( Octave ) denir. Biz piramidin daha altına giderek ( yani çözünürlük azalır ) aynı desen devam eder. Benzer şekilde genişlerken, alan her düzeyde 4 kez olur. Gauss piramitlerini cv2.pyrDown() ve cv2.pyrUp() functions fonksiyonlarını kullanarak bulabiliriz.

img = cv2.imread('messi5.jpg')
lower_reso = cv2.pyrDown(higher_reso)

Aşağıda bir görüntü piramidinde 4 seviyedir.

Şimdi görüntü piramitlerinin aşagısına inebiliriz cv2.pyrUp() fonksiyonu ile. higher_reso2 = cv2.pyrUp(lower_reso)

Unutmayın, higher_reso2 higher_reso eşit değildir, çünkü çözünürlüğü düşürdükten sonra bilgiyi kaybedersin. Aşağıda görüntü önceki durumda en küçük görüntüden oluşturulan piramit 3 düzey aşağıdır. Orijinal görüntü ile karşılaştırın.

Laplacian piramitleri Gauss piramitlerinden oluşur. Bunun için özel bir işlev yoktur. Laplacian Piramidi görüntüleri sadece kenar görüntüleri gibidir. Elementlerin çoğu sıfırdır. Görüntü sıkıştırmasında kullanılırlar. Laplacian piramidinde bir seviye Gauss piramidindeki bu seviye ile Gauss piramidindeki üst seviyesinin genişletilmiş versiyonu arasındaki fark ile oluşur. Bir Laplacian düzeyi üç düzeyleri aşağıdaki gibi görünür. (kontrast içeriğini geliştirmek için ayarlanır gibi görünecektir):

görüntü piramitleri

Piramitleri Kullanarak Görüntü Karıştırma

Görüntü karşılaştırma piramitlerin bir uygulamasıdır. Örneğin, görüntü dikiminde iki görüntüyü bir araya getirmeniz gerekir, ancak görüntüler arasındaki kesintiler nedeniyle iyi görünmeyebilir. Bu durumda, piramitler ile karıştırma görüntülerde çok fazla veri bırakmadan sorunsuz karıştırma sağlar. Bunun klasik bir örneği iki meyvenin, portakal ve elma karışımıdır. Şimdi ne söylediğimi anlamak için sonuca bakın. orapple Lütfen ek kaynakları ve referansları kontrol edin ,bu görüntü karıştırma, Laplacian Piramitleri vb tam diagramatik ayrıntıları vardır Basitçe şöyle yapılır.

  • Elma ve portakal olan iki resim yüklenir.
  • Elma ve portakal için Gauss piramitleri bulunur.
  • Gauss piramitlerinden Laplacian piramitlerini bulunur.
  • Şimdi Laplacian piramitlerinin her kademesinde elma ve turuncu sağ yarısı sol yarısı katılır.
  • Sonunda bu ortak görüntü piramitlerinden, orijinal görüntüyü yeniden oluşturun.

Aşağıda tam kodu var. (Basitlik uğruna, her adım ayrı ayrı yapılır, daha fazla bellek alabilir. Eğer isterseniz optimize edebilirsiniz).

import cv2
import numpy as np,sys
A = cv2.imread('apple.jpg')
B = cv2.imread('orange.jpg')
# A için Gaussian piramidi oluşturuluyor
G = A.copy()
gpA = [G]
for i in xrange(6):
    G = cv2.pyrDown(G)
    gpA.append(G)
# B için Gaussian piramidi oluşturuluyor
G = B.copy()
gpB = [G]
for i in xrange(6):
    G = cv2.pyrDown(G)
    gpB.append(G)
# A için Laplacian piramidi oluşturuluyor
lpA = [gpA[5]]
for i in xrange(5,0,-1):
    GE = cv2.pyrUp(gpA[i])
    L = cv2.subtract(gpA[i-1],GE)
    lpA.append(L)
# B için Laplacian piramidi oluşturuluyor
lpB = [gpB[5]]
for i in xrange(5,0,-1):
    GE = cv2.pyrUp(gpB[i])
    L = cv2.subtract(gpB[i-1],GE)
    lpB.append(L)
# Şimdi her düzeyde görüntünün sol ve sağ yarısı eklenir
LS = []
for la,lb in zip(lpA,lpB):
    rows,cols,dpt = la.shape
    ls = np.hstack((la[:,0:cols/2], lb[:,cols/2:]))
    LS.append(ls)
# şimdi yeniden yapılandıralım
ls_ = LS[0]
for i in xrange(1,6):
    ls_ = cv2.pyrUp(ls_)
    ls_ = cv2.add(ls_, LS[i])
# Her yarım direkt bağlantı ile görüntü
real = np.hstack((A[:,:cols/2],B[:,cols/2:]))
cv2.imwrite('Pyramid_blending2.jpg',ls_)
cv2.imwrite('Direct_blending.jpg',real)

Ek kaynak :

Image Blending ( görüntü karşılaştıma )


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.