python数字图像处理之对比度与亮度调整示例


Posted in Python onJune 28, 2022

skimage包的exposure模块

图像亮度与对比度的调整,是放在skimage包的exposure模块里面

1、gamma调整

python数字图像处理之对比度与亮度调整示例

对原图像的像素,进行幂运算,得到新的像素值。公式中的g就是gamma值。

如果gamma>1, 新图像比原图像暗

如果gamma<1,新图像比原图像亮

函数格式为:skimage.exposure.adjust_gamma(image, gamma=1)

gamma参数默认为1,原像不发生变化 。

from skimage import data, exposure, img_as_float
import matplotlib.pyplot as plt
image = img_as_float(data.moon())
gam1= exposure.adjust_gamma(image, 2)   #调暗
gam2= exposure.adjust_gamma(image, 0.5)  #调亮
plt.figure('adjust_gamma',figsize=(8,8))
plt.subplot(131)
plt.title('origin image')
plt.imshow(image,plt.cm.gray)
plt.axis('off')
plt.subplot(132)
plt.title('gamma=2')
plt.imshow(gam1,plt.cm.gray)
plt.axis('off')
plt.subplot(133)
plt.title('gamma=0.5')
plt.imshow(gam2,plt.cm.gray)
plt.axis('off')
plt.show()

python数字图像处理之对比度与亮度调整示例

2、log对数调整

这个刚好和gamma相反

原理:I=log(I)

from skimage import data, exposure, img_as_float
import matplotlib.pyplot as plt
image = img_as_float(data.moon())
gam1= exposure.adjust_log(image)   #对数调整
plt.figure('adjust_gamma',figsize=(8,8))
plt.subplot(121)
plt.title('origin image')
plt.imshow(image,plt.cm.gray)
plt.axis('off')
plt.subplot(122)
plt.title('log')
plt.imshow(gam1,plt.cm.gray)
plt.axis('off')
plt.show()

python数字图像处理之对比度与亮度调整示例

3、判断图像对比度是否偏低

函数:is_low_contrast(img)

返回一个bool型值

from skimage import data, exposure
image =data.moon()
result=exposure.is_low_contrast(image)
print(result)

输出为False

4、调整强度

函数:

skimage.exposure.rescale_intensity(image, in_range='image', out_range='dtype')

in_range 表示输入图片的强度范围,默认为'image', 表示用图像的最大/最小像素值作为范围

out_range 表示输出图片的强度范围,默认为'dype', 表示用图像的类型的最大/最小值作为范围

默认情况下,输入图片的[min,max]范围被拉伸到[dtype.min, dtype.max],如果

dtype=uint8, 那么dtype.min=0, dtype.max=255

import numpy as np
from skimage import exposure
image = np.array([51, 102, 153], dtype=np.uint8)
mat=exposure.rescale_intensity(image)
print(mat)

输出为[  0 127 255]

即像素最小值由51变为0,最大值由153变为255,整体进行了拉伸,但是数据类型没有变,还是uint8

前面我们讲过,可以通过img_as_float()函数将unit8类型转换为float型,实际上还有更简单的方法,就是乘以1.0

import numpy as np
image = np.array([51, 102, 153], dtype=np.uint8)
print(image*1.0)

即由[51,102,153]变成了[  51.  102.  153.]

而float类型的范围是[0,1],因此对float进行rescale_intensity 调整后,范围变为[0,1],而不是[0,255]

import numpy as np
from skimage import exposure
image = np.array([51, 102, 153], dtype=np.uint8)
tmp=image*1.0
mat=exposure.rescale_intensity(tmp)
print(mat)

结果为[ 0. &nbsp; 0.5  1. ]

如果原始像素值不想被拉伸,只是等比例缩小,就使用in_range参数,如:

import numpy as np
from skimage import exposure
image = np.array([51, 102, 153], dtype=np.uint8)
tmp=image*1.0
mat=exposure.rescale_intensity(tmp,in_range=(0,255))
print(mat)

输出为:[ 0.2  0.4  0.6],即原像素值除以255

如果参数in_range的[main,max]范围要比原始像素值的范围[min,max] 大或者小,那就进行裁剪,如:

mat=exposure.rescale_intensity(tmp,in_range=(0,102))
print(mat)

输出[ 0.5  1.   1. ],即原像素值除以102,超出1的变为1

如果一个数组里面有负数,现在想调整到正数,就使用out_range参数。如:

import numpy as np
from skimage import exposure
image = np.array([-10, 0, 10], dtype=np.int8)
mat=exposure.rescale_intensity(image, out_range=(0, 127))
print(mat)

输出[  0  63 127]

以上就是python数字图像处理之对比度与亮度调整示例的详细内容,更多关于python数字图像对比度亮度调整的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python删除指定目录下过期文件的2个脚本分享
Apr 10 Python
简述Python中的进程、线程、协程
Mar 18 Python
使用python 爬虫抓站的一些技巧总结
Jan 10 Python
matplotlib调整子图间距,调整整体空白的方法
Aug 03 Python
python+splinter实现12306网站刷票并自动购票流程
Sep 25 Python
python 将日期戳(五位数时间)转换为标准时间
Jul 11 Python
python之yield和Generator深入解析
Sep 18 Python
python selenium循环登陆网站的实现
Nov 04 Python
浅谈python已知元素,获取元素索引(numpy,pandas)
Nov 26 Python
浅谈keras通过model.fit_generator训练模型(节省内存)
Jun 17 Python
Python OpenCV 彩色与灰度图像的转换实现
Jun 05 Python
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
Mar 03 Python
python数字图像处理实现图像的形变与缩放
在python中读取和写入CSV文件详情
Jun 28 #Python
python数字图像处理之图像的批量处理
如何利用python实现Simhash算法
Jun 28 #Python
python数字图像处理:图像的绘制
python数字图像处理数据类型及颜色空间转换
python数据分析之单因素分析线性拟合及地理编码
You might like
ThinkPHP实现二级循环读取的方法
2014/11/03 PHP
JavaScript 快捷键设置实现代码
2009/03/13 Javascript
jQuery 源代码显示控件 (Ajax加载方式).
2009/05/18 Javascript
更优雅的事件触发兼容
2011/10/24 Javascript
jquery中prop()方法和attr()方法的区别浅析
2013/09/06 Javascript
jquery中邮箱地址 URL网站地址正则验证实例代码
2013/09/15 Javascript
javascript中的document.open()方法使用介绍
2013/10/09 Javascript
JavaScript设计模式之工厂方法模式介绍
2014/12/28 Javascript
JavaScript数组前面插入元素的方法
2015/04/06 Javascript
利用BootStrap的Carousel.js实现轮播图动画效果
2016/12/21 Javascript
Vue 2中ref属性的使用方法及注意事项
2017/06/12 Javascript
Bootstrap Multiselect 常用组件实现代码
2017/07/09 Javascript
vue.js获得当前元素的文字信息方法
2018/03/09 Javascript
关于Google发布的JavaScript代码规范你要知道哪些
2018/04/04 Javascript
JS伪继承prototype实现方法示例
2018/06/20 Javascript
Vue $mount实战之实现消息弹窗组件
2019/04/22 Javascript
Vue SPA 初次进入加载动画实现代码
2019/11/14 Javascript
layui写后台表格思路和赋值用法详解
2019/11/14 Javascript
使用JS实现动态时钟
2020/03/12 Javascript
在vue中使用回调函数,this调用无效的解决
2020/08/11 Javascript
[00:15]天涯墨客终极技能展示
2018/08/25 DOTA
Python用zip函数同时遍历多个迭代器示例详解
2016/11/14 Python
Python图片裁剪实例代码(如头像裁剪)
2017/06/21 Python
python Pygame的具体使用讲解
2017/11/03 Python
Python全栈之列表数据类型详解
2019/10/01 Python
python实现的读取网页并分词功能示例
2019/10/29 Python
Python图像处理库PIL的ImageDraw模块介绍详解
2020/02/26 Python
Python中zipfile压缩文件模块的基本使用教程
2020/06/14 Python
利用HTML5绘制点线面组成的3D图形的示例
2015/05/12 HTML / CSS
BIFFI美国站:意大利BIFFI BOUTIQUES豪华多品牌时装零售公司
2020/02/11 全球购物
JAVA代码查错题
2014/10/10 面试题
校园奶茶店创业计划书
2014/01/23 职场文书
岗位聘任协议书
2015/09/21 职场文书
2016春季幼儿园大班开学寄语
2015/12/03 职场文书
MySQL中一条update语句是如何执行的
2022/03/16 MySQL
python实现手机推送 代码也就10行左右
2022/04/12 Python