- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数字图像处理报告
非线性平滑——中值滤波
实验目的
了解统计排序滤波器在数字图象处理中的作用;
理解中值滤波的原理、特点、适用对象;
掌握中值滤波的各种方法。
实验原理
中值滤波是一种非线性信号处理方法,与其对应的中值滤波器是一种统计排序滤波器,用象素邻域内各灰度级排序的中值来代替该象素的灰度级(用一个奇数点的移动窗口, 将窗口中心点的值用窗口内的中值代替),一定条件下,可以克服线性滤波器(如邻域平滑滤波等)所带来的图象细节模糊,而且对滤除脉冲干扰及图象扫描噪声最为有效(中值滤波的输出与输入噪声的密度分布有关,对随机噪声的抑制能力,中值滤波比平均值滤波要差一些;但对脉冲干扰,特别是脉冲宽度小于窗口一半、相距较远的窄脉冲干扰,中值滤波的效果较好)。
设有一个一维序列f1, f2, …, fn ,取窗口长度(点数)为m(m为奇数),对其进行中值滤波,就是从输入序列中相继抽出m个数fi-v, …, fi-1, fi, fi+1, …, fi+v(其中fi为窗口中心点值,v=(m-1)/2), 再将这m个点按其数值大小排序,取其序号为中心点的那个数作为滤波输出。用数学公式表示为:
(4—1)
这样处理的特点是:周期小于m/2(窗口一半)的脉冲会被抑制,而周期大于m/2(窗口一半)的脉冲得到保留,在窗口内单调增加或单调减少的序列, 中值滤波输出信号仍保持输入信号不变(利用这个特点,可以使中值滤波既能去除图象中的噪声,又能保持图象中一些物体的边缘)。
同理,二维中值滤波可由下式表示:
(4—2)
式中:A为窗口; {fij}为二维数据序列。这样处理的特点是:当在窗口内,被噪声污染的象素不超过滤波器区域的一半时,噪声会被抑制;当在窗口内,被噪声污染的象素超过滤波器区域的一半时,噪声会得到保留。
二维中值滤波的窗口形状和尺寸对滤波效果影响较大,不同的图象内容和不同的应用要求,往往采用不同的窗口形状和尺寸。常用的二维中值滤波窗口有线状、十字形、方形等。窗口尺寸一般先用3×3,再取5×5逐渐增大, 直到滤波效果满意为止。就一般经验来讲,对于有缓变的较长轮廓线物体的图象,采用方形窗口为宜。对于包含有尖顶物体的图象, 用十字形窗口; 而窗口大小则以不超过图象中最小有效物体的尺寸为宜。如果图象中点、线、尖角细节较多,则不宜采用中值滤波。对一些内容复杂的图象,可以使用复合型中值滤波,如中值滤波的线性组合,即将几种窗口尺寸大小和形状不同的中值滤波器复合使用,只要各窗口都与中心对称,滤波输出可保持几个方向上的边缘跳变,而且跳变幅度可调节;其线性组合方程如下:
(4—3)
式中:ak为不同中值滤波的系数,Ak为窗口。
实验内容
1. 分别对含有高斯噪声、瑞利噪声、椒盐噪声的图象进行中值滤波,采用多种窗口形状(线形、十字形、方形),窗口尺寸可变(先用3×3,再取5×5逐渐增大);
2. 比较中值滤波对含有不同噪声的图象的平滑效果,讨论中值滤波最适用于平滑哪种噪声;
3. 比较不同的窗口形状和窗口尺寸对整幅图象以及局部图象平滑效果的影响;
4. 比较中值滤波和低通掩模法在平滑效果以及轮廓模糊程度上的差异;
5. 尝试多种窗口线形组合的中值滤波。
实验程序清单
主程序
clear all
I=(imread(cameraman.tif));
J1=imnoise(I,salt pepper,0.02);
J2=imnoise(I,gaussian,0.02);
J3=raylrnd(im2double(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);
x32=uint8(real( K401));
K4=x32
K5=LP(J3);
figure(1)
subplot(221),imshow(I)
ti
原创力文档


文档评论(0)