数字图像处理第六次作业

上传人:l**** 文档编号:145337178 上传时间:2020-09-19 格式:DOC 页数:12 大小:642KB
返回 下载 相关 举报
数字图像处理第六次作业_第1页
第1页 / 共12页
数字图像处理第六次作业_第2页
第2页 / 共12页
数字图像处理第六次作业_第3页
第3页 / 共12页
数字图像处理第六次作业_第4页
第4页 / 共12页
数字图像处理第六次作业_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《数字图像处理第六次作业》由会员分享,可在线阅读,更多相关《数字图像处理第六次作业(12页珍藏版)》请在金锄头文库上搜索。

1、. . . 数字图像处理第六次作业摘要本次报告主要记录第六次作业中的各项任务完成情况。本次作业以Matlab 2013为平台,结合matlab函数编程实现对所给图像文件的相关处理:1.在测试图像上产生高斯噪声lena图-需能指定均值和方差;并用滤波器(自选)恢复图像;2.实现下边要求;(a) 实现模糊滤波器如方程Eq. (5.6-11) ;(b) 模糊lena图像:45度方向,T=1;(c) 在模糊的lena图像中增加高斯噪声,均值= 0 ,方差=10 pixels 以产生退化图像;(d)分别利用方程 Eq. (5.8-6)和(5.9-4),恢复图像。以上任务完成后均得到了预期的结果。1.在测

2、试图像上产生高斯噪声lena图-需能指定均值和方差;并用滤波器(自选)恢复图像;(1)实验原理与方法图像复原处理是建立在图像退化的数学模型基础上的,这个退化数学模型能够反映图像退化的原因。图像的退化过程可以理解为施加于原图像上的运算和噪声两者联合作用的结果,图像退化模型如图1所示,可以表示为:图1 图像退化模型高斯噪声是指它的概率密度函数服从高斯分布(即正态分布)的一类噪声。一个高斯随机变量z的PDF可表示为:其中z代表灰度,u是z的均值,是z的标准差。高斯噪声的灰度值多集中在均值附近。本文采用55模板的中值滤波器和高斯滤波器(=1.5)作业四中已经介绍过,中值滤波器是使用一个像素邻域中灰度级

3、的中值来替代该像素值,即, 。高斯滤波是一种根据高斯函数的形状来选择模板权值的线性平滑滤波方法,具体操作是:用一个模板(或称卷积)扫描图像中的每一个像素,用模板确定的邻域像素的加权平均灰度值去替代模板中心像素点的值。利用matlab中imnoise函数加入高斯噪声:g=imnoise(f,type,parameters) 调用格式: g = imnoise(I,type) g = imnoise(I,type,parameters) 参数Type对应的噪声类型如下: gaussian高斯白噪声 localvar0均值白噪声 poisson泊松噪声 salt & pepper盐椒噪声 speck

4、le乘性噪声滤波程序同作业四(2)处理结果(3)结果分析通过imnoise函数产生了被均值和方差可选的高斯噪声污染的图像。当高斯噪声均值不变为0时,随着方差增加,图像噪声越严重;当高斯噪声方差不变时,均值会影响到整个图像的灰度值,使整个图像变亮。与理论上均值和方差对图像的影响一致。分别使用高斯滤波器和中值滤波器对加噪图像进行恢复。两种方法在一定程度上都可以降低噪声。高斯滤波器降低噪声的同时保存的图像细节更丰富,亮度比原噪声图像和中值滤波后图像暗更接近原始图像,中值滤波后图像亮度基本与原噪声图像相同。2实现下边要求: (a) 实现模糊滤波器如方程Eq. (5.6-11). (b) 模糊lena图

5、像:45度方向,T=1; (c) 在模糊的lena图像中增加高斯噪声,均值= 0 ,方差=10 pixels 以产生退化图像;(d)分别利用方程 Eq. (5.8-6)和(5.9-4),恢复图像;(5.6-11)利用上式模糊lena图像:45度方向,T=1,即使a=b=0.1,T=1。对原始图像的图像矩阵做傅里叶变换并移至图像中心得到频域矩阵F,使H与F相乘后反傅里叶变换到空域得到变换后图像。维纳滤波综合了退化函数和噪声统计特性两个方面进行复原处理,其目标是寻找一个滤波器,使得复原后图像与原始图像的均方误差最小:因此维纳滤波器又称为最小均方误差滤波器,在频率中用下式表达:其中G(u,v)是退化

6、图像的傅里叶变换,H(u,v)是退化函数。 为噪声功率谱, 为未退化图像的功率谱。式5.8-6为属于维纳滤波式5.9-4为其中,是一个参数,必须对它进行调整以满足的条件,属于约束最小二层方滤波利用以上两式恢复图像的流程与对模糊原始图像的流程相似:对原始图像的图像矩阵做傅里叶变换并移至图像中心得到频域矩阵F,通过H得到,使与F相乘后反傅里叶变换到空域得到变换后图像。在实现5.9-4时借助matlab工具包以得到更好的效果。用fspecial和imnoise函数得到45度方向,T=1的模糊lena图像,并在此图像上实现维纳滤波和约束最小二乘方滤波。1)imfilter 功能:对任意类型数组或多维图

7、像进行滤波。 用法:B = imfilter(A,H) B = imfilter(A,H,option1,option2,.) 或写做g = imfilter(f, w, filtering_mode, boundary_options, size_options) 其中,f为输入图像,w为滤波掩模,g为滤波后图像。filtering_mode用于指定在滤波过程中是使用“相关”还是“卷积”。boundary_options用于处理边界充零问题,边界的大小由滤波器的大小确定。2)fspecial 功能:fspecial函数用于建立预定义的滤波算子。 用法:h = fspecial(type) h

8、 = fspecial(type,para) 其中type指定算子的类型,para指定相应的参数。(2)处理结果 (3)结果分析1.按照书上公式编写的模糊函数图像是斜向下45度运动模糊,matlab函数是斜向上45度运动模糊的,公式的程序得到图像棱角比较分明边界比较明显。 2.使用自己编写的函数进行维纳滤波,难点在于寻找令信噪比最大的K值,报告中显示了K=0.06时的滤波结果,从结果看,视觉上的效果并不是很理想,噪声依然很大,要想达到更好的效果可能需要寻找更加合适的K值或者直接使用matlab的deconvreg函数实现。 3.最后采用MATLAAB提供的deconvreg函数进行约束最小二乘

9、方滤波。从滤波后的结果看,约束最小二乘方滤波得到了比维纳滤波更好的结果,噪声基本消除,图像变得模糊但是平滑。 附录:参考文献:1 Rafael C. Gonzalez., et al. 数字图像处理(第三版), 电子工业, 2011.2 周品. MATLAB数字图像处理, 清华大学, 2012源代码:1.img1.m产生高斯噪声并用高斯滤波器和中值滤波器滤波I=imread(lena.bmp); figure(1);subplot(1,2,1)imshow(I); title(原始图像lena.bmp); imwrite(I,原始图像lena.bmp); I2=imnoise(I,gaussi

10、an,0.5,0.01); subplot(1,2,2)imshow(I2); title(加入gaussian噪声后的lena.bmp(u=0.5,s2=0.01); imwrite(I2,加入gaussian噪声后的lena.bmp(u=0.5,s2=0.01).bmp); figure(2);subplot(2,2,1)imshow(I); title(原始图像lena.bmp);subplot(2,2,2)imshow(I2); title(lena加入gaussian噪声后的(u=0.5,s2=0.01).bmp); n=5; a=ones(n,n); p=size(I2); x1=

11、double(I2);x2=x1; for i=1:p(1)-n+1 for j=1:p(2)-n+1 c=x1(i:i+(n-1),j:j+(n-1); e=c(1,:); for u=2:n e=e,c(u,:); end mm=median(e); x2(i+(n-1)/2,j+(n-1)/2)=mm; endendI3=uint8(x2);subplot(2,2,3)imshow(I3); title(中值滤波(5x5)); imwrite(I3,中值滤波(5x5).bmp); I2,map=imread(加入gaussian噪声后的lena.bmp(u=0.5,s2=0.01).bm

12、p);k=1.5; Img=double(I2); n=5; n1=floor(n+1)/2); for i=1:n for j=1:n b(i,j) =exp(-(i-n1)2+(j-n1)2)/(4*k)/(4*pi*k); endend Img1=conv2(Img,b,same); d=uint8(Img1); subplot(2,2,4); imshow(d,map); title(高斯滤波5x5) 2.img2.m运动模糊+高斯噪声、维纳滤波、约束最小二乘滤波I=imread(lena.bmp); figure(1);subplot(1,2,1)imshow(I); title(l

13、ena.bmp原始图像); imwrite(I,lena原始图像.bmp); f=double(I); F=fft2(f); F=fftshift(F); M,N=size(F); a=0.1;b=0.1;T=1; for u=1:M for v=1:N H(u,v)=(T/(pi*(u*a+v*b)*sin(pi*(u*a+v*b)*exp(-sqrt(-1)*pi*(u*a+v*b); G(u,v)=H(u,v)*F(u,v); endendG=ifftshift(G); g=ifft2(G); g=256.*g./max(max(g);g=uint8(real(g); subplot(1

14、,2,2); imshow(g); title(运动模糊化lena.bmp); imwrite(g,lena运动模糊的结果.bmp); figure(2)subplot(1,2,1); imshow(g); title(运动模糊化lena.bmp); imwrite(g, lena运动模糊的结果.bmp);I2=imnoise(g,gaussian,0,0.01); subplot(1,2,2)imshow(I2); title(模糊lena.bmp加入高斯噪声(u=0,s2=0.01); imwrite(I2,模糊lena.bmp加入高斯噪声(u=0,s2=0.01).bmp); figure(3)I

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 工作范文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号