opencv中直方图均衡函数cv::equalizeHist()的使用!!严格用程序进行了验证!

最近开始学习OPENCV,通过验证书中的例程,从网上寻找别人的例程和解释,我发现人们多半都是不负责的,各种转载!你们有没有真正验证过????????


先给一个别人关于cv::equalizeHist()的使用  找了很多博客 都是如下写的  然后给个例程! 可是你真的有验证过嘛?你得到的均衡的直方图真的能按照这个公式算出来嘛???

qualizeHist

灰度图象直方图均衡化

void cvEqualizeHist( const CvArr* src, CvArr* dst );

src

输入的 8-比特 单信道图像

dst

输出的图像与输入图像大小与数据类型相同

函数 cvEqualizeHist 采用如下法则对输入图像进行直方图均衡化:


1. 计算输入图像的直方图 H

2.  直方图归一化,因此直方块和为255

3. 计算直方图积分: 

4. 采用H'作为查询表:dst(x,y)=H'(src(x,y))进行图像变换。

-------------------------------


我的例子!8X9的矩阵  得到直方图 

135  25

158 15

255 32

归一化累积直方图

135   25/72

158    40/72

255    72/72

乘上255得到对应的像素

135  88

158  141

255  255

按照别人博客里的方法 得到的新的图像矩阵为:

255 255 255 255 141 141 141 141  141

255 255 255 255 141 141 141 141  141

255 255 255 255 141 141 141 141  141

255 255 255 255   88   88    88   88   88

255 255 255 255   88   88    88   88   88

255 255 255 255   88   88    88   88   88

255 255 255 255   88   88    88   88   88

255 255 255 255   88   88    88   88   88

但是!很明显!我们得到的均衡后的矩阵并不是这个!而是

我找了很久的资料! 原来是把

给拉伸到了0-255的范围里!!!!所有人都没有讲!!!!导致走了很多弯路想明白!!!不过也印象深刻

方法:

拉伸后灰度=(当前灰度-最小灰度)×255/(255-最小灰度)  所以 88对应的灰度=(88-88)×255/(255-88)=0

141对应的灰度=(141-88)×255/(255-88)=81;

255对应的灰度=(255-88)×255/(255-88)=255;

所以得到的最终的均衡图像矩阵为


你可能感兴趣的:(opencv,直方图均衡化)