matlab单一灰度图像直方图均衡化
时间: 2024-01-07 18:23:16 浏览: 130
以下是进行MATLAB单一灰度图像直方图均衡化的代码示例:
```matlab
% 读取图像
image = imread('image.jpg');
% 将图像转换为灰度图像
grayImage = rgb2gray(image);
% 计算灰度图像的直方图
histogram = imhist(grayImage);
% 计算灰度图像的累积分布函数
cdf = cumsum(histogram) / numel(grayImage);
% 对每个像素进行直方图均衡化
equalizedImage = cdf(grayImage + 1);
% 将图像转换为8位无符号整数类型
equalizedImage = uint8(equalizedImage * 255);
% 显示直方图均衡化后的图像
figure;
imshow(equalizedImage);
title('直方图均衡化后的图像');
% 显示直方图均衡化前后的直方图
figure;
subplot(2, 1, 1);
bar(histogram);
title('直方图均衡化前');
subplot(2, 1, 2);
bar(imhist(equalizedImage));
title('直方图均衡化后');
```
阅读全文