OpenCV入门教程05.02:图像直方图均衡化

索引地址:系列索引

灰度直方图均衡化

大多数自然图像,其灰度分布集中在较窄的区间,引起图像细节不够清晰,采用直方图修正后可使图像的灰度间距拉开或使灰度分布均匀,从而增大反差,使图像细节清晰,达到增强的目的。例如一幅过曝光的图片,其灰度级都集中在高亮度范围内,而曝光不足的图片,其灰度集中在低亮度范围内,具有这样直方图的图片其可视效果比较差。

直方图均衡化方法的基本思想是,对在图像中像素个数多的灰度级进行展宽,而对像素个数少的灰度级进行缩减。从而达到清晰图像的目的,增强图像的整体对比度。

其基本处理思路是,把原始图像的灰度直方图从比较集中的某个灰度区间变成在全部灰度范围内的均匀分布。即在每个灰度级上都具有相同像素点数的过程。

直方图均衡化是通过拉伸像素强度分布范围来增强图像对比度的一种方法.

说得更清楚一些, 对于一些直方图来说, 你可以看到像素主要集中在中间的一些强度值上. 直方图均衡化要做的就是 拉伸 这个范围. 见下面左图: 绿圈圈出了 少有像素分布其上的 强度值. 对其应用均衡化后, 得到了中间图所示的直方图. 均衡化的图像见下面右图.

histogram

测试代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
//---------------------------------【头文件、命名空间包含部分】---------------------------
// 描述:包含程序所使用的头文件和命名空间
//-----------------------------------------------------------------------------------------------
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
using namespace cv;

//--------------------------------------【main( )函数】-----------------------------------------
// 描述:控制台应用程序的入口函数,我们的程序从这里开始执行
//-----------------------------------------------------------------------------------------------
int main() {
// 【1】加载源图像
Mat srcImage, dstImage;
srcImage = imread("1.jpg", 1);
if (!srcImage.data) {
printf("读取图片错误,请确定目录下是否有imread函数指定图片存在~! \n");
return false;
}

// 【2】转为灰度图并显示出来
cvtColor(srcImage, srcImage, COLOR_BGR2GRAY);
imshow("Original", srcImage);

// 【3】进行直方图均衡化
equalizeHist(srcImage, dstImage);

// 【4】显示结果 经过直方图均衡化后的图
imshow("Result", dstImage);

// 等待用户按键退出程序
waitKey(0);
return 0;
}

测试结果:

hist

彩色直方图均衡化

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// 功能:代码 3-11 彩色直方图均衡化实现
// 作者:朱伟 zhu1988wei@163.com
// 来源:《OpenCV图像处理编程实例》
// 博客:http://blog.csdn.net/zhuwei1988
// 更新:2016-8-1
// 说明:版权所有,引用或摘录请联系作者,并按照上面格式注明出处,谢谢。//
#include <opencv2/opencv.hpp>
int main() {
// 图像获取及验证
cv::Mat srcImage = cv::imread("..\\images\\flower3.jpg");
if (!srcImage.data)
return 1;
// 存储彩色直方图及图像通道向量
cv::Mat colorHeqImage;
std::vector<cv::Mat> BGR_plane;
// 对BGR通道进行分离
cv::split(srcImage, BGR_plane);
// 分别对BGR进行直方图均衡化
for (int i = 0; i < BGR_plane.size(); i++)
cv::equalizeHist(BGR_plane[ i ], BGR_plane[ i ]);
// 合并对应各个通道
cv::merge(BGR_plane, colorHeqImage);
cv::imshow("srcImage", srcImage);
cv::imshow("colorHeqImage", colorHeqImage);
cv::waitKey(0);
return 0;
}

效果为

colorful


OpenCV入门教程05.02:图像直方图均衡化
https://blog.jackeylea.com/opencv/opnecv-image-equalize-histogram/
作者
JackeyLea
发布于
2020年6月21日
许可协议