opencv —— equalizeHist 直方图均衡化实现对比度增强

直方图均匀化简介

从这张未经处理的灰度图可以看出,其灰度集中在非常小的一个范围内。这就导致了图片的强弱对比不强烈。

直方图均衡化的目的,就是把原始的直方图变换为在整个灰度范围(0~255)内均匀分布的形式,从而增加像素灰度值的动态范围,达到增强图像整体对比度的效果。

 

直方图均衡化的列表计算

序号

运算

步骤和结果

1

列出原始图灰度值 f(0 ≤ f ≤ L-1)

01234567
2列出原始直方图(概率表达)0.020.050.090.120.140.20.220.16
3计算原始累计直方图 gf(灰度值 ≤ f 的概率和)0.020.070.160.280.420.620.841.00
4取整 g=(int) [(L-1)·gf + 0.5]00123467
5确定对应关系(原灰度值 -> 新灰度值)0->0 1->0 2->1 3->2 4->3 5->4 6->6 7->7 
6更新直方图0.070.090.120.140.200.220.16

实现直方图均衡化:equalizeHist 函数

equalize 函数实现的灰度直方图均衡化算法,就是把直方图的每个灰度值进行归一化处理,求每种灰度的累积分布,接着得到一个映射的灰度映射表,然后根据相应的灰度值来修正原图中的每个像素。

void equalize(InputArray src, OutputArray dst);

  • src,输入图像,即源图像,填 Mat 类的对象即可,但需要为 8 位单通道的图像。
  • dst,输出结果,需要和源图像有一样的尺寸和类型。

代码示例:

#include<opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;
int main() {
    Mat src = imread("C:/Users/齐明洋/Desktop/1.jpg");
    imshow("src", src);

    Mat gray, dst;
    cvtColor(src, gray, COLOR_BGR2GRAY);
    imshow("gray", gray);
    equalizeHist(gray, dst);
    imshow("dst", dst);

    waitKey(0);
    
}

效果展示:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值