问题描述:
求matlab大神给下面一个源程序给个详细的注释,就是程序每一步的操作,速求
g=imread('C:\Users\zhourui\Desktop\1.jpg'); %读入图像的具体位置,
k=imnoise(g,'gaussian',0.1);
v=rgb2gray(k);
subplot(3,2,1);
imshow(g)
title('orginal image');
subplot(3,2,2);
imshow(v)
title('noise image');
[h,w]=size(v);
n=9;
f=double(v);
a=ones(n,n);
y=f;
for i=1:h-n+1
for j=1:w-n+1
a=f(i:i+(n-1),j:j+(n-1));
s=sum(sum(a));
y(i+(n-1)/2,j+(n-1)/2)=s/(n*n);
end
end
subplot(3,2,3);
imshow(uint8(y))
title('noise reduction by average filter');
x=f;
for i=1:h-n+1
for j=1:w-n+1
c=f(i:i+(n-1),j:j+(n-1));
e=c(1,:);
for u=2:n
e=[e,c(u,:)];
end
mm=median(e);
x (i+(n-1)/2,j+(n-1)/2)=mm;
end
end
subplot(3,2,4);
imshow(uint8(x))
title('noise reduction by median filter');
g=imread('C:\Users\zhourui\Desktop\1.jpg'); %读入图像的具体位置,
k=imnoise(g,'gaussian',0.1);
v=rgb2gray(k);
subplot(3,2,1);
imshow(g)
title('orginal image');
subplot(3,2,2);
imshow(v)
title('noise image');
[h,w]=size(v);
n=9;
f=double(v);
a=ones(n,n);
y=f;
for i=1:h-n+1
for j=1:w-n+1
a=f(i:i+(n-1),j:j+(n-1));
s=sum(sum(a));
y(i+(n-1)/2,j+(n-1)/2)=s/(n*n);
end
end
subplot(3,2,3);
imshow(uint8(y))
title('noise reduction by average filter');
x=f;
for i=1:h-n+1
for j=1:w-n+1
c=f(i:i+(n-1),j:j+(n-1));
e=c(1,:);
for u=2:n
e=[e,c(u,:)];
end
mm=median(e);
x (i+(n-1)/2,j+(n-1)/2)=mm;
end
end
subplot(3,2,4);
imshow(uint8(x))
title('noise reduction by median filter');
问题解答:
我来补答展开全文阅读