本文主要是介绍Skimage图像处理教程3)曝光度调整,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这里所谓的曝光度的,这里所谓的曝光度,实际上是借用了英文单词exposure的翻译,因为在这一讲中,我们要涉及到python中skimage.exposure中涉及到的函数啦。这一讲主要包括图像的直方图,直方图均衡化,自适应直方图均衡化,颜色阈值调整,gamma校正等等内容。
# 返回直方图, 直方图分成几份,返回两个数组分别是该组别的像素个数和组别
skimage.exposure.histogram(image, nbins=256)# 直方图均衡化,mask和原图大小一致bool类型只有0或1
skimage.exposure.equalize_hist(image, nbins=256, mask=None)# 自适应直方图均衡化
skimage.exposure.equalize_adapthist (image, kernel_size=None, clip_limit=0.01, nbins=256)# 重置强度区间
# image会自动计算图像的最大值和最小值
# 给出数据结构如np.uint8则会把数据归到uint8的区间之内
# 或者给出最大最小值[min, max]
skimage.exposure.rescale_intensity(image, in_range='image', out_range='dtype')# 返回图像的累积分布和每个分块的中点
skimage.exposure.cumulative_distribution(image, nbins=256)# 对图像进行gamma调整
# 输入输出都是0到1之间,新像素值Out = In^gamma
skimage.exposure.adjust_gamma(image, gamma=1, gain=1)# 对图像进行sigmoid纠正,这个操作可能是用在特定领域感觉不太常见
# 公式是Out = 1/(1 + exp*(gain*(cutoff - In)))
# inv如果是True则返回负的sigmoid纠正结果
# 输入输出是0到1之间
skimage.exposure.adjust_sigmoid(image, cutoff=0.5, gain=10, inv=False)# 对图像进行log调整
# inv为false时Out = gain*log(1 + In)
# inv为true时Out = gain*(2^In - 1)
skimage.exposure.adjust_log(image, gain=1, inv=False)# 判断图片是否是低分辨率
# 具体的计算手册也并没有写的十分清楚,因此贴图在此,不细描述。
skimage.exposure.is_low_contrast(image, fraction_threshold=0.05, lower_percentile=1, upper_percentile=99, method='linear')
下面我们展示几个处理后的结果
import skimage
img = skimage.data.immunohistochemistry()
skimage.io.imshow(img)
skimage.io.show()img_histeq = skimage.exposure.equalize_adapthist (img,20)
skimage.io.imshow(img_histeq)
skimage.io.show()img_gamma = skimage.exposure.adjust_gamma(img, gamma=0.5, gain=1)
skimage.io.imshow(img_gamma)
skimage.io.show()img_sigmoid = skimage.exposure.adjust_sigmoid(img)
skimage.io.imshow(img_sigmoid)
skimage.io.show()
从结果上看,经过直方图均衡化处理,图像的对比度增强了,gamma校正主要改变图片的饱和度和对比度,sigmoid纠感觉图像的对比度有所增加,同时更加鲜艳。
更多skimage教程请看这里
这篇关于Skimage图像处理教程3)曝光度调整的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!