8、skimage直方图与均衡化

目录html

一、计算直方图python

二、绘制直方图数组

三、彩色图片三通道直方图函数

四、直方图均衡化code


在图像处理中,直方图是很是重要,也是很是有用的一个处理要素。orm

在skimage库中对直方图的处理,是放在exposure这个模块中。htm

一、计算直方图

函数:skimage.exposure.histogram(imagenbins=256)blog

在numpy包中,也提供了一个计算直方图的函数histogram(),二者大同小义。图片

返回一个tuple(hist, bins_center), 前一个数组是直方图的统计量,后一个数组是每一个bin的中间值图像处理

import numpy as np
from skimage import exposure,data
image =data.camera()*1.0
hist1=np.histogram(image, bins=2)   #用numpy包计算直方图
hist2=exposure.histogram(image, nbins=2)  #用skimage计算直方图
print(hist1)
print(hist2)

输出:

(array([107432, 154712], dtype=int64), array([ 0. , 127.5, 255. ]))
(array([107432, 154712], dtype=int64), array([ 63.75, 191.25]))

分红两个bin,每一个bin的统计量是同样的,但numpy返回的是每一个bin的两端的范围值,而skimage返回的是每一个bin的中间值

二、绘制直方图

绘图均可以调用matplotlib.pyplot库来进行,其中的hist函数能够直接绘制直方图。

调用方式:

n, bins, patches = plt.hist(arr, bins=10, normed=0, facecolor='black', edgecolor='black',alpha=1,histtype='bar')

参数:

  • hist的参数很是多,但经常使用的就这六个,只有第一个是必须的,后面四个可选

  • arr: 须要计算直方图的一维数组

  • bins: 直方图的柱数,可选项,默认为10

  • normed: 是否将获得的直方图向量归一化。默认为0

  • facecolor: 直方图颜色

  • edgecolor: 直方图边框颜色

  • alpha: 透明度

  • histtype: 直方图类型,‘bar’, ‘barstacked’, ‘step’, ‘stepfilled’

返回值 :

  • n: 直方图向量,是否归一化由参数normed设定

  • bins: 返回各个bin的区间范围

  • patches: 返回每一个bin里面包含的数据,是一个list

from skimage import data
import matplotlib.pyplot as plt
img=data.camera()
plt.figure("hist")
arr=img.flatten()
n, bins, patches = plt.hist(arr, bins=256, normed=1,edgecolor='None',facecolor='red')  
plt.show()
 

其中的flatten()函数是numpy包里面的,用于将二维数组序列化成一维数组。

是按行序列,如

mat=[[1 2 3

     4 5 6]]

通过 mat.flatten()后,就变成了

mat=[1 2 3 4 5 6]

三、彩色图片三通道直方图

通常来讲直方图都是征对灰度图的,若是要画rgb图像的三通道直方图,实际上就是三个直方图的叠加。

from skimage import data
import matplotlib.pyplot as plt
img=data.lena()
ar=img[:,:,0].flatten()
plt.hist(ar, bins=256, normed=1,facecolor='r',edgecolor='r',hold=1)
ag=img[:,:,1].flatten()
plt.hist(ag, bins=256, normed=1, facecolor='g',edgecolor='g',hold=1)
ab=img[:,:,2].flatten()
plt.hist(ab, bins=256, normed=1, facecolor='b',edgecolor='b')
plt.show()

其中,加一个参数hold=1,表示能够叠加

四、直方图均衡化

若是一副图像的像素占有不少的灰度级并且分布均匀,那么这样的图像每每有高对比度和多变的灰度色调。直方图均衡化就是一种能仅靠输入图像直方图信息自动达到这种效果的变换函数。它的基本思想是对图像中像素个数多的灰度级进行展宽,而对图像中像素个数少的灰度进行压缩,从而扩展取值的动态范围,提升了对比度和灰度色调的变化,使图像更加清晰。

from skimage import data,exposure
import matplotlib.pyplot as plt
img=data.moon()
plt.figure("hist",figsize=(8,8))

arr=img.flatten()
plt.subplot(221)
plt.imshow(img,plt.cm.gray)  #原始图像
plt.subplot(222)
plt.hist(arr, bins=256, normed=1,edgecolor='None',facecolor='red') #原始图像直方图

img1=exposure.equalize_hist(img)
arr1=img1.flatten()
plt.subplot(223)
plt.imshow(img1,plt.cm.gray)  #均衡化图像
plt.subplot(224)
plt.hist(arr1, bins=256, normed=1,edgecolor='None',facecolor='red') #均衡化直方图

plt.show()