淺談Python Opencv中g(shù)amma變換的使用詳解
伽馬變換就是用來(lái)圖像增強(qiáng),其提升了暗部細(xì)節(jié),簡(jiǎn)單來(lái)說(shuō)就是通過(guò)非線性變換,讓圖像從暴光強(qiáng)度的線性響應(yīng)變得更接近人眼感受的響應(yīng),即將漂白(相機(jī)曝光)或過(guò)暗(曝光不足)的圖片,進(jìn)行矯正。
伽馬變換的基本形式如下:
大于1時(shí),對(duì)圖像的灰度分布直方圖具有拉伸作用(使灰度向高灰度值延展),而小于1時(shí),對(duì)圖像的灰度分布直方圖具有收縮作用(是使灰度向低灰度值方向靠攏)。
#分道計(jì)算每個(gè)通道的直方圖 img0 = cv2.imread('12.jpg') hist_b = cv2.calcHist([img0],[0],None,[256],[0,256]) hist_g = cv2.calcHist([img0],[1],None,[256],[0,256]) hist_r = cv2.calcHist([img0],[2],None,[256],[0,256]) def gamma_trans(img,gamma): #具體做法先歸一化到1,然后gamma作為指數(shù)值求出新的像素值再還原 gamma_table = [np.power(x/255.0,gamma)*255.0 for x in range(256)] gamma_table = np.round(np.array(gamma_table)).astype(np.uint8) #實(shí)現(xiàn)映射用的是Opencv的查表函數(shù) return cv2.LUT(img0,gamma_table) img0_corrted = gamma_trans(img0, 0.5) cv2.imshow('img0',img0) cv2.imshow('gamma_image',img0_corrted) cv2.imwrite('gamma_image.png',img0_corrted) #分通道計(jì)算Gamma校正后的直方圖 hist_b_c =cv2.calcHist([img0_corrted],[0],None,[256],[0,256]) hist_g_c =cv2.calcHist([img0_corrted],[1],None,[256],[0,256]) hist_r_c =cv2.calcHist([img0_corrted],[2],None,[256],[0,256]) fig = plt.figure('gamma') pix_hists = [[hist_b, hist_g, hist_r], [hist_b_c, hist_g_c, hist_r_c]] pix_vals = range(256) for sub_plt, pix_hist in zip([121, 122], pix_hists): ax = fig.add_subplot(sub_plt, projection='3d') for c, z, channel_hist in zip(['b', 'g', 'r'], [20, 10, 0], pix_hist): cs = [c] * 256 ax.bar(pix_vals, channel_hist, zs=z, zdir='y', color=cs, alpha=0.618, edgecolor='none', lw=0) ax.set_xlabel('Pixel Values') ax.set_xlim([0, 256]) ax.set_ylabel('Count') ax.set_zlabel('Channels') plt.show() cv2.waitKey()
以上這篇淺談Python Opencv中g(shù)amma變換的使用詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Qt6中重大改變的QtMultimedia多媒體模塊實(shí)現(xiàn)
本文主要介紹了Qt6中重大改變的QtMultimedia多媒體模塊實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09利用Python進(jìn)行圖像的加法,圖像混合(附代碼)
這篇文章主要介紹了利用Python進(jìn)行圖像的加法,圖像混合(附代碼),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python趣味挑戰(zhàn)之教你用pygame畫進(jìn)度條
pygame四種方法教會(huì)你畫進(jìn)度條,其實(shí)也不難,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下2021-05-05python實(shí)現(xiàn)簡(jiǎn)單的TCP代理服務(wù)器
這篇文章主要介紹了python實(shí)現(xiàn)簡(jiǎn)單的TCP代理服務(wù)器,包含了完整的實(shí)現(xiàn)過(guò)程及對(duì)應(yīng)的源碼與說(shuō)明文檔下載,非常具有參考借鑒價(jià)值,需要的朋友可以參考下2014-10-10python實(shí)現(xiàn)定時(shí)發(fā)送郵件
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)定時(shí)發(fā)送郵件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12Python實(shí)現(xiàn)的RSS閱讀器實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)的RSS閱讀器,實(shí)例分析了XML解析實(shí)現(xiàn)RSS閱讀的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07