浅谈Python Opencv中gamma变换的使用详解


Posted in Python onApril 02, 2018

伽马变换就是用来图像增强,其提升了暗部细节,简单来说就是通过非线性变换,让图像从暴光强度的线性响应变得更接近人眼感受的响应,即将漂白(相机曝光)或过暗(曝光不足)的图片,进行矫正。

伽马变换的基本形式如下:

大于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变换的使用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
学习python的几条建议分享
Feb 10 Python
python使用正则表达式检测密码强度源码分享
Jun 11 Python
Python中捕捉详细异常信息的代码示例
Sep 18 Python
Python中文字符串截取问题
Jun 15 Python
实现python版本的按任意键继续/退出
Sep 26 Python
Python优先队列实现方法示例
Sep 21 Python
python+pyqt实现12306图片验证效果
Oct 25 Python
Python数据分析:手把手教你用Pandas生成可视化图表的教程
Dec 15 Python
Python获取、格式化当前时间日期的方法
Feb 10 Python
Python绘制全球疫情变化地图的实例代码
Apr 20 Python
Python基于callable函数检测对象是否可被调用
Oct 16 Python
python3判断IP地址的方法
Mar 04 Python
opencv改变imshow窗口大小,窗口位置的方法
Apr 02 #Python
python opencv设置摄像头分辨率以及各个参数的方法
Apr 02 #Python
python opencv 图像尺寸变换方法
Apr 02 #Python
Python聊天室程序(基础版)
Apr 01 #Python
Python socket实现简单聊天室
Apr 01 #Python
简单实现python聊天程序
Apr 01 #Python
简单实现Python爬取网络图片
Apr 01 #Python
You might like
PHPExcel简单读取excel文件示例
2016/05/26 PHP
简单的pgsql pdo php操作类实现代码
2016/08/25 PHP
TNC vs BOOM BO3 第三场2.13
2021/03/10 DOTA
javascript下数值型比较难点说明
2010/06/07 Javascript
javascript Array对象基础知识小结
2010/11/16 Javascript
javascript学习笔记(六) Date 日期类型
2012/06/19 Javascript
jquery自定义属性(类型/属性值)
2013/05/21 Javascript
javascript自动给文本url地址增加链接的方法分享
2014/01/20 Javascript
Vue组件开发初探
2017/02/14 Javascript
微信小程序 动态传参实例详解
2017/04/27 Javascript
js实现股票实时刷新数据案例
2017/05/14 Javascript
JavaScript常用工具方法封装
2019/02/12 Javascript
Javascript文本框脚本实现方法解析
2020/10/30 Javascript
手动实现vue2.0的双向数据绑定原理详解
2021/02/06 Vue.js
python http接口自动化脚本详解
2018/01/02 Python
Python实现购物车程序
2018/04/16 Python
使用Python快速搭建HTTP服务和文件共享服务的实例讲解
2018/06/04 Python
python中使用psutil查看内存占用的情况
2018/06/11 Python
Python模块的制作方法实例分析
2019/12/21 Python
django2.2 和 PyMySQL版本兼容问题
2020/02/17 Python
详解Windows下PyCharm安装Numpy包及无法安装问题解决方案
2020/06/18 Python
如何利用python进行时间序列分析
2020/08/04 Python
5 分钟读懂Python 中的 Hook 钩子函数
2020/12/09 Python
python自动打开浏览器下载zip并提取内容写入excel
2021/01/04 Python
怎样实现H5+CSS3手指滑动切换图片的示例代码
2019/05/05 HTML / CSS
GIVENCHY纪梵希官方旗舰店:高定彩妆与贵族护肤品
2018/04/16 全球购物
亲属关系公证书
2014/04/08 职场文书
蓝颜请假条
2014/04/11 职场文书
服务承诺书怎么写
2014/05/24 职场文书
2015年节能降耗工作总结
2015/05/22 职场文书
国情备忘录观后感
2015/06/04 职场文书
2016七夕情人节寄语
2015/12/04 职场文书
三好学生评选事迹材料(2016精选版)
2016/02/25 职场文书
CSS 实现多彩、智能的阴影效果
2021/05/12 HTML / CSS
html2 canvas svg不能识别的解决方案
2021/06/03 HTML / CSS
DIY胆机必读:各国电子管评价
2022/04/06 无线电