Opencv中的直方图(5)直方图均衡化计算函数equalizeHist()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

对灰度图像进行直方图均衡化。
该函数使用以下算法对输入图像的直方图进行均衡化:

  • 计算输入图像 src 的直方图 H。
  • 将直方图归一化,使得直方图各 bin 之和为 255。
  • 计算直方图的积分:
    H i ′ = ∑ 0 ≤ j < i H ( j ) H'_i = \sum _{0 \le j < i} H(j) Hi=0j<iH(j)
  • 使用 H ′ H' H作为查找表对图像进行变换: dst ( x , y ) = H ′ ( src ( x , y ) ) \texttt{dst}(x,y) = H'(\texttt{src}(x,y)) dst(x,y)=H(src(x,y))

该算法对图像的亮度进行了归一化并增加了图像的对比度。

函数原型


void cv::equalizeHist	
(
	InputArray 	src,
	OutputArray 	dst 
)		

参数

  • 参数src 8 位单通道源图像。
  • 参数dst 与 src 大小和类型相同的目標图像。

代码示例

#include <iostream>
#include <opencv2/opencv.hpp>

int main( int argc, char** argv )
{
    // 读取输入图像
    cv::Mat src = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/qiu.jpg", cv::IMREAD_GRAYSCALE );

    if ( src.empty() )
    {
        std::cerr << "Error: Image cannot be loaded!" << std::endl;
        return -1;
    }

    // 创建目标图像
    cv::Mat dst;

    // 进行直方图均衡化
    cv::equalizeHist( src, dst );

    // 显示原始图像
    cv::imshow( "Original Image", src );

    // 显示均衡化后的图像
    cv::imshow( "Equalized Image", dst );

    // 等待按键,关闭窗口
    cv::waitKey( 0 );

    return 0;
}

运行结果

在这里插入图片描述

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值