亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python學(xué)習(xí)之直方圖均衡化原理詳解

 更新時(shí)間:2022年03月02日 10:01:49   作者:MrWinter  
直方圖均衡化是以累計(jì)分布函數(shù)為核心,將原始圖像灰度直方圖從比較集中的某個(gè)灰度區(qū)間,非線性地映射為在全部灰度范圍內(nèi)的較均勻分布,從而增強(qiáng)對(duì)比度。本文將為大家詳細(xì)講解直方圖均衡化的原理,需要的可以參考一下

1.點(diǎn)算子

點(diǎn)算子是兩個(gè)像素灰度值間的映射關(guān)系,屬于像素的逐點(diǎn)運(yùn)算,相鄰像素不參與運(yùn)算。點(diǎn)算子是最簡(jiǎn)單的圖像處理手段,如:亮度調(diào)整、對(duì)比度調(diào)整、顏色變換、直方圖均衡化等等。

2.線性灰度變換

線性灰度變換表達(dá)為:

其中rk、sk分別為輸入、輸出點(diǎn)像素灰度值。

▲圖2.1 線性灰度變換

當(dāng)a>1時(shí),輸出圖像像素灰度范圍擴(kuò)大,圖像對(duì)比度增強(qiáng),當(dāng)a<1時(shí)反之。這是因?yàn)槿搜鄄灰讌^(qū)分相近的灰度值,因此若圖像灰度值范圍較小,觀感上細(xì)節(jié)不夠清晰。當(dāng)a=1、b≠0時(shí),點(diǎn)算子使圖像灰度整體上移或下移,即整體變亮或變暗。

▲圖2.2 圖像對(duì)比度(左為弱對(duì)比度,右為強(qiáng)對(duì)比度)

3.直方圖均衡化

下圖再次給出了關(guān)于圖像對(duì)比度的例子。

▲圖3.1 圖像對(duì)比度示例

直方圖均衡化是以累計(jì)分布函數(shù)為核心,將原始圖像灰度直方圖從比較集中的某個(gè)灰度區(qū)間,非線性地映射為在全部灰度范圍內(nèi)的較均勻分布,從而增強(qiáng)對(duì)比度。

下面闡述直方圖均衡化的數(shù)學(xué)原理。首先作原始圖像灰度的概率直方圖如圖。

▲圖3.2 直方圖均衡化原理

設(shè)輸入像素灰度值為rk,累計(jì)分布函數(shù)為

其中ni為圖像中灰度值為ri的像素頻數(shù),n為圖像像素總數(shù)。設(shè)輸出像素灰度值為sk,像素范圍為smin-smax。期望輸出灰度直方圖是均勻分布,即

令C(sk)=C(rk),即得

所以最終直方圖均衡化的點(diǎn)算子為

所以最終直方圖均衡化的點(diǎn)算子為

4.代碼實(shí)戰(zhàn)

按照前文的原理編寫累積分布函數(shù)計(jì)算公式,以及均衡化算子

#?計(jì)算累計(jì)分布函數(shù)
def?C(rk):
??#?讀取圖片灰度直方圖
??#?bins為直方圖直方柱的取值向量
??#?hist為bins各取值區(qū)間上的頻數(shù)取值
??hist,?bins?=?np.histogram(rk,?256,?[0,?256])
??#?計(jì)算累計(jì)分布函數(shù)
??return?hist.cumsum()
#?計(jì)算灰度均衡化映射
def?T(rk):
??cdf?=?C(rk)
??#?均衡化
??cdf?=?(cdf?-?cdf.min())?*?(255?-?0)?/?(cdf.max()?-?cdf.min())?+?0
??return?cdf.astype('uint8')

均衡化時(shí)直接調(diào)用函數(shù)即可,下面給出完整代碼

import?numpy?as?np
import?cv2?as?cv
from?matplotlib?import?pyplot?as?plt

#?計(jì)算累計(jì)分布函數(shù)
def?C(rk):
??#?讀取圖片灰度直方圖
??#?bins為直方圖直方柱的取值向量
??#?hist為bins各取值區(qū)間上的頻數(shù)取值
??hist,?bins?=?np.histogram(rk,?256,?[0,?256])
??#?計(jì)算累計(jì)分布函數(shù)
??return?hist.cumsum()

#?計(jì)算灰度均衡化映射
def?T(rk):
??cdf?=?C(rk)
??#?均衡化
??cdf?=?(cdf?-?cdf.min())?*?(255?-?0)?/?(cdf.max()?-?cdf.min())?+?0
??return?cdf.astype('uint8')


#?讀取圖片
img?=?cv.imread('1.png',?0)
#?將二維數(shù)字圖像矩陣轉(zhuǎn)變?yōu)橐痪S向量
rk?=?img.flatten()

#?原始圖像灰度直方圖
plt.hist(rk,?256,?[0,?255],?color?=?'r')
cv.imshow("原圖像",img)

#?直方圖均衡化
imgDst?=?T(rk)[img]
cv.imshow("直方圖均衡化后的圖像",imgDst)
plt.hist(imgDst.flatten(),?256,?[0,?255],?color?=?'b')

plt.show()

看看效果:

▲圖4.1 直方圖均衡化效果(灰度直方圖)

▲圖4.2 均衡化前

▲圖4.3 均衡化后

以上就是Python學(xué)習(xí)之直方圖均衡化原理詳解的詳細(xì)內(nèi)容,更多關(guān)于Python直方圖均衡化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論