【OpenCV图像处理】1.23 直方图(Histogram)均衡化

相关理论

  • 什么是直方图?

    • 图像直方图,是指对整个图像像在灰度范围内的像素值(0~255)统计出现频率次数,据此生成的直方图,称为图像直方图-直方图。直方图反映了图像灰度的分布情况。是图像的统计学特征
  • 直方图均衡化

    • 是一种提高图像对比度的方法,拉伸图像灰度值范围。
      在这里插入图片描述

    • 如何实现,通过上一课中的remap我们知道可以将图像灰度分布从一个分布映射到另外一个分布,然后在得到映射后的像素值即可。
      H ′ ( i ) = ∑ 0 ≤ j < i H ( j ) H^{\prime}(i)=\sum_{0 \leq j<i} H(j) H(i)=0j<iH(j)
      equalized ( x , y ) = H ′ ( src ⁡ ( x , y ) ) \text {equalized}(x, y)=H^{\prime}(\operatorname{src}(x, y)) equalized(x,y)=H(src(x,y))

  • API说明cv::equalizeHist

    equalizeHist(
    InputArray src,//输入图像,必须是8-bit的单通道图像
    OutputArray dst// 输出结果
    )
    

代码 & 展示效果

完整代码:

#include <iostream>
#include <string>
#include <vector>
#include <opencv2/opencv.hpp>
#include <opencv2/imgproc/types_c.h>

using namespace std;
using namespace cv;

#ifndef P23
#define P23 23
#endif

int main() {
    std::string path = "../color_line.JPG";
    cv::Mat img = cv::imread(path, 5);

    string str_input = "input image";
    string str_output = "output image";

    if(img.empty())
    {
        std::cout << "open file failed" << std::endl;
        return -1;
    }
    
#if P23 //直方图
    Mat dest;
    cvtColor(img, img, CV_BGR2GRAY);
    equalizeHist(img, dest);
    imshow(str_output, dest);
#endif

    cv::waitKey(0);
    cv::destroyAllWindows();
    return 0;
}

效果:
在这里插入图片描述
参考:图像处理基础(8):图像的灰度直方图、直方图均衡化、直方图规定化(匹配

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值