Python實現圖像增強_第1頁
Python實現圖像增強_第2頁
Python實現圖像增強_第3頁
Python實現圖像增強_第4頁
Python實現圖像增強_第5頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第Python實現圖像增強本文實例為大家分享了Python實現圖像增強的具體代碼,供大家參考,具體內容如下

題目描述:對于下面這幅圖像(圖1),請問可以通過那些圖像增強的手段,達到改善視覺效果的目的?請顯示處理結果,并附簡要處理流程說明。

圖1原圖

常用的圖像增強方法有以下幾種:

1.提高對比度

采用了線性函數對圖像的灰度值進行變換。

2.Gamma校正

采用了非線性函數(指數函數)對圖像的灰度值進行變換。

3.直方圖均衡化

將原始圖像的直方圖通過積分概率密度函數轉化為概率密度為1(理想情況)的圖像,從而達到提高對比度的作用。直方圖均衡化的實質也是一種特定區域的展寬,但是會導致整個圖像向亮的區域變換。當原始圖像給定時,對應的直方圖均衡化的效果也相應的確定了。

4.直方圖規定化

針對直方圖均衡化的存在的一些問題,將原始圖像的直方圖轉化為規定的直方圖的形式。一般目標圖像的直方圖的確定需要參考原始圖像的直方圖,并利用多高斯函數得到。

5.中值、均值濾波器

均值濾波方法:對待處理的當前像素,選擇一個模板,該模板為其鄰近的若干個像素組成,用模板的均值來替代原像素的值的方法。

中值濾波方法:對待處理的當前像素,選擇一個模板,該模板為其鄰近的若干個像素組成,對模板的像素由小到大進行排序,再用模板的中值來替代原像素的值的方法。

從圖像中我們可以看出,該圖片帶有很多椒鹽噪聲,并且圖像有些暗,于是我們選擇中值濾波方法對圖片進行處理(中值濾波對椒鹽噪聲具有較好效果),并提高對比度和亮度。

處理流程:

第一步:采用中值濾波方法對圖像進行處理,處理后,結果如圖2所示:

圖2中值濾波

第二步:Gamma校正,處理后,結果如圖3所示:

圖3Gamma校正

第三步:提升對比度,亮度,處理后,結果如圖4所示:

圖4對比度、亮度提升

最后輸出對比圖,如圖5所示:

圖5效果對比圖

Python代碼:

#author:lph

#funtion:imageenhance

importcv2

importnumpyasnp

fromtkinterimport*

fromskimageimportfilters,exposure

importmatplotlib.pyplotasplt

fromskimage.morphologyimportdisk

frommatplotlib.font_managerimportFontProperties

#讀入圖片

im=cv2.imread('./image/image.png',0)

im_copy=cv2.imread('./image/image.png',0)

#如果圖片為空,返回錯誤信息,并終止程序

ifimisNone:

print("圖片打開失敗!")

exit()

#中值濾波去噪

medStep=3#設置為3*3的濾波器

defm_filter(x,y,step):

"""中值濾波函數"""

sum_s=[]#定義空數組

forkinrange(-int(step/2),int(step/2)+1):

forminrange(-int(step/2),int(step/2)+1):

sum_s.append(im[x+k][y+m])#把模塊的像素添加到空數組

sum_s.sort()#對模板的像素由小到大進行排序

returnsum_s[(int(step*step/2)+1)]

foriinrange(int(medStep/2),im.shape[0]-int(medStep/2)):

forjinrange(int(medStep/2),im.shape[1]-int(medStep/2)):

im_copy[i][j]=m_filter(i,j,medStep)#用模板的中值來替代原像素的值

cv2.imshow("Median",im_copy)

#Gamma校正

img3=exposure.adjust_gamma(im_copy,1.05)

cv2.imshow("Gamma",img3)

#對比度、亮度增強

defContrast_and_Brightness(alpha,beta,img):

"""使用公式f(x)=α.g(x)+β"""

#α調節對比度,β調節亮度

blank=np.zeros(img.shape,img.dtype)#創建圖片類型的零矩陣

dst=cv2.addWeighted(img,alpha,blank,1-alpha,beta)#圖像混合加權

returndst

img4=Contrast_and_Brightness(1.1,30,img3)

cv2.imshow("Contrast",img4)

#創建一個窗口

plt.figure('對比圖',figsize=(7,5))

#中文字體設置

font=FontProperties(fname=r"c:\windows\fonts\simsun.ttc",size=14)#新宋體

#顯示原圖

plt.subplot(121)#子圖1

#顯示原圖,設置標題和字體

plt.imshow(im,plt.cm.gray),plt.title('處理前圖片',fontproperties=font)

#顯示處理過的圖像

plt.subplot(122)#子圖2

#顯示處理后的圖,設置標題和字體

plt.imshow(img4,plt

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論