浅谈Python Opencv中gamma变换的使用详解
Python  /  管理员 发布于 7年前   325
伽马变换就是用来图像增强,其提升了暗部细节,简单来说就是通过非线性变换,让图像从暴光强度的线性响应变得更接近人眼感受的响应,即将漂白(相机曝光)或过暗(曝光不足)的图片,进行矫正。
伽马变换的基本形式如下:
大于1时,对图像的灰度分布直方图具有拉伸作用(使灰度向高灰度值延展),而小于1时,对图像的灰度分布直方图具有收缩作用(是使灰度向低灰度值方向靠拢)。
#分道计算每个通道的直方图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作为指数值求出新的像素值再还原 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) #实现映射用的是Opencv的查表函数 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)#分通道计算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中gamma变换的使用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号