浅谈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抓取框架 Scrapy的架构
Aug 12 Python
Django + Uwsgi + Nginx 实现生产环境部署的方法
Jun 20 Python
python判断输入日期为第几天的实例
Nov 13 Python
对python pandas 画移动平均线的方法详解
Nov 28 Python
python构建基础的爬虫教学
Dec 23 Python
Python3 导入上级目录中的模块实例
Feb 16 Python
详解python项目实战:模拟登陆CSDN
Apr 04 Python
python爬虫爬取监控教务系统的思路详解
Jan 08 Python
Python基于Tensor FLow的图像处理操作详解
Jan 15 Python
python 按钮点击关闭窗口的实现
Mar 04 Python
PyQt5实现画布小程序
May 30 Python
Python办公自动化之教你如何用Python将任意文件转为PDF格式
Jun 28 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
为了这两部电子管收音机,买了6套全新电子管和10粒刻度盘灯泡
2021/03/02 无线电
怎样在PHP中通过ADO调用Asscess数据库和COM程序
2006/10/09 PHP
php adodb连接不同数据库
2009/03/19 PHP
php实现的双向队列类实例
2014/09/24 PHP
php常用字符串比较函数实例汇总
2014/11/24 PHP
PHP常量DIRECTORY_SEPARATOR原理及用法解析
2020/11/10 PHP
表单的一些基本用法与技巧
2006/07/15 Javascript
jquery中this的使用说明
2010/09/06 Javascript
jQuery中实现动画效果的基本操作介绍
2013/04/16 Javascript
js时钟翻牌效果实现代码分享
2020/07/31 Javascript
js判断文本框输入的内容是否为数字
2015/12/23 Javascript
纯前端JavaScript实现Excel IO案例分享
2016/08/26 Javascript
深入浅析Vue组件开发
2016/11/25 Javascript
React 使用recharts实现散点地图的示例代码
2018/12/07 Javascript
浅谈Vue CLI 3结合Lerna进行UI框架设计
2019/04/14 Javascript
jQuery删除/清空指定元素的所有子节点实例代码
2019/07/04 jQuery
layui字体图标 loading图标静止不旋转的解决方法
2019/09/23 Javascript
js函数和this用法实例分析
2020/03/13 Javascript
Python中Random和Math模块学习笔记
2015/05/18 Python
Python的几个高级语法概念浅析(lambda表达式闭包装饰器)
2016/05/28 Python
Python图形绘制操作之正弦曲线实现方法分析
2017/12/25 Python
安装2019Pycharm最新版本的教程详解
2019/10/22 Python
Python StringIO如何在内存中读写str
2020/01/07 Python
html5 canvas实现圆形时钟代码分享
2013/12/25 HTML / CSS
Java的for语句中break, continue和return的区别
2013/12/19 面试题
护士实习自我鉴定
2013/10/22 职场文书
大学生自我评价怎样写好
2013/10/23 职场文书
校园十佳歌手策划书
2014/01/22 职场文书
计算机网络工程专业职业生涯规划书
2014/03/10 职场文书
乡镇四风对照检查材料
2014/08/31 职场文书
巾帼文明岗汇报材料
2014/12/24 职场文书
党校学习个人总结
2015/02/15 职场文书
2014年度个人工作总结范文
2015/03/09 职场文书
民事调解书范文
2015/05/20 职场文书
行为规范主题班会
2015/08/13 职场文书
学生会副主席竞选稿
2015/11/19 职场文书