多种窗口中值滤波_第1页
多种窗口中值滤波_第2页
多种窗口中值滤波_第3页
多种窗口中值滤波_第4页
多种窗口中值滤波_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数字图像处理报告 非线性平滑中值滤波一. 实验目的1. 了解统计排序滤波器在数字图象处理中的作用;2. 理解中值滤波的原理、特点、适用对象;3. 掌握中值滤波的各种方法。二. 实验原理中值滤波是一种非线性信号处理方法,与其对应的中值滤波器是一种统计排序滤波器,用象素邻域内各灰度级排序的中值来代替该象素的灰度级(用一个奇数点的移动窗口, 将窗口中心点的值用窗口内的中值代替),一定条件下,可以克服线性滤波器(如邻域平滑滤波等)所带来的图象细节模糊,而且对滤除脉冲干扰及图象扫描噪声最为有效(中值滤波的输出与输入噪声的密度分布有关,对随机噪声的抑制能力,中值滤波比平均值滤波要差一些;但对脉冲干扰,特别

2、是脉冲宽度小于窗口一半、相距较远的窄脉冲干扰,中值滤波的效果较好)。 设有一个一维序列f1, f2, , fn ,取窗口长度(点数)为m(m为奇数),对其进行中值滤波,就是从输入序列中相继抽出m个数fi-v, , fi-1, fi, fi+1, , fi+v(其中fi为窗口中心点值,v=(m-1)2), 再将这m个点按其数值大小排序,取其序号为中心点的那个数作为滤波输出。用数学公式表示为: (41) 这样处理的特点是:周期小于m/2(窗口一半)的脉冲会被抑制,而周期大于m/2(窗口一半)的脉冲得到保留,在窗口内单调增加或单调减少的序列, 中值滤波输出信号仍保持输入信号不变(利用这个特点,可以使

3、中值滤波既能去除图象中的噪声,又能保持图象中一些物体的边缘)。同理,二维中值滤波可由下式表示: (42) 式中:A为窗口; fij为二维数据序列。这样处理的特点是:当在窗口内,被噪声污染的象素不超过滤波器区域的一半时,噪声会被抑制;当在窗口内,被噪声污染的象素超过滤波器区域的一半时,噪声会得到保留。二维中值滤波的窗口形状和尺寸对滤波效果影响较大,不同的图象内容和不同的应用要求,往往采用不同的窗口形状和尺寸。常用的二维中值滤波窗口有线状、十字形、方形等。窗口尺寸一般先用3×3,再取5×5逐渐增大, 直到滤波效果满意为止。就一般经验来讲,对于有缓变的较长轮廓线物体的图象,采用方

4、形窗口为宜。对于包含有尖顶物体的图象, 用十字形窗口; 而窗口大小则以不超过图象中最小有效物体的尺寸为宜。如果图象中点、线、尖角细节较多,则不宜采用中值滤波。对一些内容复杂的图象,可以使用复合型中值滤波,如中值滤波的线性组合,即将几种窗口尺寸大小和形状不同的中值滤波器复合使用,只要各窗口都与中心对称,滤波输出可保持几个方向上的边缘跳变,而且跳变幅度可调节;其线性组合方程如下: (43) 式中:ak为不同中值滤波的系数,Ak为窗口。三. 实验内容1. 分别对含有高斯噪声、瑞利噪声、椒盐噪声的图象进行中值滤波,采用多种窗口形状(线形、十字形、方形),窗口尺寸可变(先用3×3,再取5

5、15;5逐渐增大);2. 比较中值滤波对含有不同噪声的图象的平滑效果,讨论中值滤波最适用于平滑哪种噪声;3. 比较不同的窗口形状和窗口尺寸对整幅图象以及局部图象平滑效果的影响;4. 比较中值滤波和低通掩模法在平滑效果以及轮廓模糊程度上的差异;5. 尝试多种窗口线形组合的中值滤波。四. 实验程序清单主程序clear allI=(imread('cameraman.tif');J1=imnoise(I,'salt & pepper',0.02);J2=imnoise(I,'gaussian',0.02);J3=raylrnd(im2doubl

6、e(I);domain3ju=1 1 1 %domain需为n*n的窗口,形状可自己定义 1 1 1 1 1 1; K3j1=ord(J1,5,domain3ju); %ord函数中需传递窗口,及窗口采中值num的位置,此处为5, K3j2=ord(J2,5,domain3ju); %矩形窗num=(n*n+1)/2,十字窗num=4*(n-1)/2)*(n-1)/2)+n K3j3=ord(J3,5,domain3ju); %一字型窗num=2*(n-1)+(n+1)/2,其余自己推算 K301=LP(J1); x31=uint8(real(K301); K3=x31 K401=LP(J2)

7、; x32=uint8(real( K401); K4=x32 K5=LP(J3); figure(1) subplot(221),imshow(I) title('原图像') subplot(222),imshow(J1) title('加椒盐噪声') subplot(223),imshow(J2) title('加高斯噪声') subplot(224),imshow(J3) title('加瑞利噪声') figure(2) subplot(321),imshow(uint8( K3j1) title('加椒盐后滤波&#

8、39;) subplot(322),imshow(uint8( K3j2) title('加高斯后滤波') subplot(323),imshow( K3j3) title('加瑞利后滤波') subplot(324),imshow( K3) title('加椒盐butterworth低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) title('加瑞利butterworth低通滤波') doma

9、in3shi=0 1 0 1 1 1 0 1 0; K3s1=ord(J1,7,domain3shi); K3s2=ord(J2,7,domain3shi); K3s3=ord(J3,7,domain3shi); figure(3) subplot(321),imshow(uint8( K3s1) title('加椒盐后滤波') subplot(322),imshow(uint8( K3s2) title('加高斯后滤波') subplot(323),imshow( K3s3) title('加瑞利后滤波') subplot(324),imsho

10、w( K3) title('加椒盐butterworth低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) title('加瑞利butterworth低通滤波') domain3yi=0 0 0 1 1 1 0 0 0; K3y1=ord(J1,8,domain3yi); K3y2=ord(J2,8,domain3yi); K3y3=ord(J3,8,domain3yi); figure(4) subplot(321),imsho

11、w(uint8( K3y1) title('加椒盐后滤波') subplot(322),imshow(uint8( K3y2) title('加高斯后滤波') subplot(323),imshow( K3y3) title('加瑞利后滤波') subplot(324),imshow( K3) title('加椒盐butterworth低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) title(

12、'加瑞利butterworth低通滤波') domain5ju=1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ; K5j1=ord(J1,13,domain5ju); K5j2=ord(J2,13,domain5ju); K5j3=ord(J3,13,domain5ju); figure(5) subplot(321),imshow(uint8( K5j1) title('加椒盐后滤波') subplot(322),imshow(uint8( K5j2) title('加高斯后滤波') sub

13、plot(323),imshow( K5j3) title('加瑞利后滤波') subplot(324),imshow( K3) title('加椒盐butterworth低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) title('加瑞利butterworth低通滤波') domain5shi=0 0 1 0 0 0 0 1 0 0 1 1 1 1 1 0 0 1 0 0 0 0 1 0 0 ; K5s1=o

14、rd(J1,21,domain5shi); K5s2=ord(J2,21,domain5shi); K5s3=ord(J3,21,domain5shi); figure(6)subplot(321),imshow(uint8( K5s1) title('加椒盐后滤波') subplot(322),imshow(uint8( K5s2) title('加高斯后滤波') subplot(323),imshow( K5s3) title('加瑞利后滤波') subplot(324),imshow( K3) title('加椒盐butterwor

15、th低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) title('加瑞利butterworth低通滤波') domain5yi=0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 ; K5y1=ord(J1,23,domain5yi); K5y2=ord(J2,23,domain5yi); K5y3=ord(J3,23,domain5yi); figure(7)subplot(321),

16、imshow(uint8( K5y1) title('加椒盐后滤波') subplot(322),imshow(uint8( K5y2) title('加高斯后滤波') subplot(323),imshow( K5y3) title('加瑞利后滤波') subplot(324),imshow( K3) title('加椒盐butterworth低通滤波') subplot(325),imshow( K4) title('加高斯butterworth低通滤波') subplot(326),imshow( K5) t

17、itle('加瑞利butterworth低通滤波')中值滤波function w=ord(J,num,domain)c1,k1=size(J);n,k2=size(domain);A=zeros(c1+n-1,k1+n-1);for i=1:c1 %补零 for j=1:k1 A(i+(n-1)/2,j+(n-1)/2)=J(i,j); endendm=(n+1)/2;m0=(n-1)/2;B=zeros(n,n);for k=m:(c1+m-1) %窗口中心移动位置 for l=m:(k1+m-1) for p1=-m0:m0 for q1=-m0:m0 B(p1+m,q1+

18、m)=A(k+p1,l+q1); %根据窗口产矩阵 end end C=B.*domain; n2=n*n; D=reshape(C,1,n2) ; for x=1:n2-1 %冒泡排序 for y=1:n2-x if D(y)>D(y+1) temp=D(y); D(y)=D(y+1); D(y+1)=temp; end end end w(k-(n-1)/2,l-(n-1)/2)=D(num); endend低通滤波function x2=LP(I2)f=double(I2);g=fft2(f);g=fftshift(g);N1,N2=size(g);n=2;d0=50;n1=fix(N1/2);n2=fix(N2/2);for i=1:N1 for j=2:N2 d=sqrt(i-n1)2+(j-n2)2); h=1/(1+0.414*(d/d0)(2*n); s1(i,j)=h*g(i,j); if(g(i,j)>50); s2(i,j)=0; else s2(i,j)=g(i,j); end endends1=ifftshift(s1);s

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论