python 用opencv實現圖像修復和圖像金字塔
我們將學習如何通過一種稱為修復的方法去除舊照片中的小噪音,筆畫等。基本思路很簡單:用相鄰像素替換那些壞標記,使其看起來像鄰域。
cv2.inpaint()
cv2.INPAINT_TELEA cv2.INPAINT_NSimport numpy as npimport cv2 as cvimg = cv.imread(’messi_2.jpg’)mask = cv.imread(’mask2.png’,0)dst = cv.inpaint(img,mask,3,cv.INPAINT_TELEA)cv.imshow(’dst’,dst)cv.waitKey(0)cv.destroyAllWindows()
第一張圖顯示降級輸入,第二個圖像是面具,第三個圖像是第一個算法的結果,最后一個圖像是第二個算法的結果。
圖像金字塔
通常,我們曾經使用恒定大小的圖像.但在某些情況下,我們需要使用不同分辨率的(相同)圖像.例如,在搜索圖像中的某些內容時,如臉部,我們不確定該對象在所述圖像中的大小.
具有不同分辨率的圖像被稱為圖像金字塔(因為當它們保持在堆疊中,底部具有最高分辨率圖像而頂部具有最低分辨率圖像時,它看起來像金字塔).
圖像金字塔有兩種:
高斯金字塔和 拉普拉斯金字塔高斯金字塔的頂部是通過將底部圖像中的連續的行和列去除得到的.頂部圖像中的每個像素值等于下一層圖像中 5 個像素的高斯加權平均值.這樣操作一次一個 MxN 的圖像就變成了一個 M/2xN/2 的圖像。所以這幅圖像的面積就變為原來圖像面積的四分之一.這被稱為an Octave(一個八度)。連續進行這樣的操作就會得到一個分辨率不斷下降的圖像金字塔.
函數cv2.pyrDown()從一個高分辨率大尺寸的圖像向上構建一個金子塔 (尺寸變小,分辨率降低).代碼:
import cv2img = cv2.imread(’img.jpg’)lower_reso = cv2.pyrDown(img)cv2.imshow(’src’,img)cv2.imshow(’HigherReso’,lower_reso)cv2.waitKey()
繼續使用函數cv2.pyrUp()從一個低分辨率小尺寸的圖像向下構建一個金子塔(尺寸變大,但分辨率不會增加)代碼:
import cv2img = cv2.imread(’img.jpg’)lower_reso = cv2.pyrDown(img)higher_reso2 = cv2.pyrUp(lower_reso)cv2.imshow(’show’,higher_reso2)cv2.waitKey()
NOTE:
當用 cv2.pyrDown(),圖像的分辨率就會降低,信息就會被丟失.如果先cv2.pyrDown()產生的中間圖像再使用函數cv2.pyrUp()得到圖像,與原圖像相比分辨率差了很多.可以修改代碼:
import cv2img = cv2.imread(’img.jpg’)higher_reso2 = cv2.pyrUp(img)lower_reso = cv2.pyrDown(higher_reso2)cv2.imshow(’show’,lower_reso)cv2.waitKey()
拉普拉斯金字塔由高斯金字塔形成,大部分元素都是零,用于圖像壓縮.代碼:
import cv2img = cv2.imread(’img.jpg’)img = cv2.Canny(img, 100, 200)higher_reso2 = cv2.pyrUp(img)lower_reso = cv2.pyrDown(higher_reso2)cv2.imshow(’src’,img)cv2.imshow(’higher_reso2’,higher_reso2)cv2.imshow(’lower_reso’,lower_reso)cv2.waitKey()
以上就是python 用opencv實現圖像修復和圖像金字塔的詳細內容,更多關于python 圖像修復和圖像金字塔的資料請關注好吧啦網其它相關文章!
相關文章:
1. css代碼優化的12個技巧2. .NET SkiaSharp 生成二維碼驗證碼及指定區域截取方法實現3. django創建css文件夾的具體方法4. ASP中if語句、select 、while循環的使用方法5. ASP中實現字符部位類似.NET里String對象的PadLeft和PadRight函數6. jsp網頁實現貪吃蛇小游戲7. ASP 信息提示函數并作返回或者轉向8. 存儲于xml中需要的HTML轉義代碼9. MyBatis JdbcType 與Oracle、MySql數據類型對應關系說明10. CentOS郵件服務器搭建系列—— POP / IMAP 服務器的構建( Dovecot )
