直返图均衡化代码详解

直方图均衡化的思想就是将原始图像的不均匀的直方图变换成均匀分布的形式,

即将输入图像转换为在每一及灰度级上都有相同的像素个数,就是直方图平坦,分布均匀

代码:

clc;
clear all;
close all;
histgram=zeros(1,256);%生成直方图数组,就是存储每个像素值的个数
cdf=zeros(1,256);
I=imread('lena.jpg');
imhist(I)
%%
[a b]=size(I);
for i=1:a
    for j=1:b
        k=I(i,j);
        histgram(k)=histgram(k)+1;
    end
end   %得打直方图
cdf(1)=histgram(1);
for i=2:256
    cdf(i)=cdf(i-1)+histgram(i);
end
%让前面的像素值的个数相加
for i=1:a
    for j=1:b
        k=I(i,j);
        eq(i,j)=cdf(k)*256/(a*b);
    end
end
figure;
imshow(uint8(eq));
figure;
imhist(uint8(eq))

%%
%简写形式

I1=histeq(I);
imshow(I1)


你可能感兴趣的:(直返图均衡化代码详解)