用两种方法编写用均值滤波去噪的matlab程序。

 我来答
汐雨烟
推荐于2019-09-18 · TA获得超过1.7万个赞
知道小有建树答主
回答量:150
采纳率:100%
帮助的人:5.6万
展开全部

1、双循环语句,移动平均法。

<p>双循环语句,移动平均法</p> <p>%均值滤波</p>

 <p>clc,clear;</p>

<p>f=imread('lena.bmp');</p>

 <p>subplot(121),imshow(f),title('原图');</p>

<p>f1=imnoise(f,'gaussian',0.002,0.0008);</p>

<p>%subplot(222),imshow(f1),title('添加高斯噪声图');</p> 

<p>k1=floor(3/2)+1;</p> 

<p>k2=floor(3/2)+1;</p> <p>X=f1;</p>

 <p>[M,N]=size(X);</p> <p>uint8 Y=zeros(M,N);</p> 

<p>funBox=zeros(3,3);</p> <p>for i=1:M-3    </p>

<p>    for j=1:N-3        </p> <p>        funBox=X(i:i+3,j:j+3);        </p> 

<p>        s=sum(funBox(:));</p> <p>        h=s/9;   </p> 

<p>        Y(i+k1,j+k2)=h;    </p> <p>    end;</p> 

<p>end;</p> <p>Y=Y/255;</p> 

<p>subplot(122),imshow(Y),title('均值滤波');</p> 

<p>实现图:</p> 

2、filter2。

<p>filter2</p> 

<p>clear all;</p> 

<p>I=imread('lena.bmp');</p> 

<p>%读入预处理图像</p>

<p>imshow(I)</p> <p>%显示预处理图像</p> 

<p>K1=filter2(fspecial('average',3),I)/255;</p> <p>%进行3*3均值滤波</p>

<p>K2=filter2(fspecial('average',5),I)/255;</p> <p>%进行5*5均值滤波</p>

<p>K3=filter2(fspecial('average',7),I)/255;</p> <p>%进行7*7均值滤波</p>

<p>figure,imshow(K1)</p> <p>figure,imshow(K2)</p> 

<p>figure,imshow(K3)</p>

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式