Python實現(xiàn)圖像增強_第1頁
Python實現(xiàn)圖像增強_第2頁
Python實現(xiàn)圖像增強_第3頁
Python實現(xiàn)圖像增強_第4頁
Python實現(xiàn)圖像增強_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

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

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

圖1原圖

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

1.提高對比度

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

2.Gamma校正

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

3.直方圖均衡化

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

4.直方圖規(guī)定化

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

5.中值、均值濾波器

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

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

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

處理流程:

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

圖2中值濾波

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

圖3Gamma校正

第三步:提升對比度,亮度,處理后,結(jié)果如圖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#設(shè)置為3*3的濾波器

defm_filter(x,y,step):

"""中值濾波函數(shù)"""

sum_s=[]#定義空數(shù)組

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

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

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

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)+β"""

#α調(diào)節(jié)對比度,β調(diào)節(jié)亮度

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

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

returndst

img4=Contrast_and_Brightness(1.1,30,img3)

cv2.imshow("Contrast",img4)

#創(chuàng)建一個窗口

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

#中文字體設(shè)置

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

#顯示原圖

plt.subplot(121)#子圖1

#顯示原圖,設(shè)置標題和字體

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

#顯示處理過的圖像

plt.subplot(122)#子圖2

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

plt.imshow(img4,plt

溫馨提示

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

評論

0/150

提交評論