matlab灰度的对数变换
时间: 2023-11-03 22:07:12 浏览: 105
灰度对数变换是一种常用的图像增强方法,它可以增强图像的低灰度部分,使得图像的细节更加清晰。在Matlab中,可以使用灰度对数变换公式y=a+log(1+x)/b来实现灰度对数变换,其中a控制曲线的垂直偏移量,b为正常数,控制曲线。具体实现过程可以参考以下代码:
clc
image = imread('D:\2.png');
image_matrix=image(:,:,1);
image_matrix=double(image_matrix);
[height,width,channels]=size(image);
G=zeros(height,width);
%输入值
a=10;
b=0.025;
%灰度映射表,灰度在0到255之间
gray_map = zeros(1,256);
%计算灰度映射表
for i=1:256
y=log(1+i)/b+a;
if(y<0)
y=0;
elseif(y>255)
y=255;
end
gray_map(i)=round(y);
end
for i=1:height
for j=1:width
T = image_matrix(i,j);
if(T==0)
G(i,j)=gray_map(1);
else
G(i,j)=gray_map(T);
end
end
end
image_out = uint8(G);
%显示
subplot(1,2,1);
imshow(image);
subplot(1,2,2);
imshow(image_out);
阅读全文