溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

OpenCV C++中直方圖均衡化技巧

發(fā)布時間:2024-08-26 17:33:42 來源:億速云 閱讀:86 作者:小樊 欄目:編程語言

在OpenCV C++中,直方圖均衡化是一種常用的圖像處理技術(shù),用于增強(qiáng)圖像的視覺質(zhì)量

  1. 包含必要的頭文件:
#include <opencv2/opencv.hpp>
#include<iostream>
  1. 加載圖像并將其轉(zhuǎn)換為灰度圖像:
cv::Mat image = cv::imread("input.jpg", cv::IMREAD_COLOR);
cv::Mat gray_image;
cv::cvtColor(image, gray_image, cv::COLOR_BGR2GRAY);
  1. 計算原始圖像的直方圖:
int histSize = 256;
float range[] = {0, 256};
const float* histRange = {range};
cv::Mat hist;
calcHist(&gray_image, 1, 0, cv::Mat(), hist, 1, &histSize, &histRange, true, false);
  1. 對原始直方圖進(jìn)行歸一化處理:
cv::Mat norm_hist;
cv::normalize(hist, norm_hist, 0, 255, cv::NORM_MINMAX, -1, cv::Mat());
  1. 計算累積直方圖:
cv::Mat cumulative_hist(histSize, 1, CV_32F);
cumulative_hist.at<float>(0) = norm_hist.at<float>(0);
for (int i = 1; i< histSize; i++) {
    cumulative_hist.at<float>(i) = cumulative_hist.at<float>(i - 1) + norm_hist.at<float>(i);
}
  1. 應(yīng)用直方圖均衡化:
cv::Mat equalized_image(image.rows, image.cols, CV_8UC1);
for (int y = 0; y< image.rows; y++) {
    for (int x = 0; x< image.cols; x++) {
        int pixelValue = static_cast<int>(gray_image.at<uchar>(y, x));
        equalized_image.at<uchar>(y, x) = static_cast<uchar>(cumulative_hist.at<float>(pixelValue));
    }
}
  1. 顯示原始圖像和均衡化后的圖像:
cv::imshow("Original Image", image);
cv::imshow("Equalized Image", equalized_image);
cv::waitKey(0);

這個示例展示了如何使用OpenCV C++實現(xiàn)直方圖均衡化。請注意,這里我們只處理了灰度圖像。如果你想處理彩色圖像,可以先將其分解為多個通道(紅、綠、藍(lán)),然后對每個通道應(yīng)用相同的操作。最后,將處理過的通道合并成一個新的彩色圖像。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

c++
AI