电子工程学院数字图像处理课程实验报告实验名称频域图像增强指导老师毕务忠班级信处实验日期实验地点学生信息(依次填入姓名、学号)张南卿成绩一、实验目的1•了解图像变换的意义和手段;2.熟悉傅里叶变换的基本性质;3.热练掌握FFT方法及应用;4.通过实验了解二维频谱的分布特点;5.通过本实验掌握利用MATLAB编程实现数字图像的傅立叶变换及滤波锐化和平滑处理;6.了解理想、巴特沃兹、高斯等不同滤波器的结构及滤波效果。二、实验原理1应用傅立叶变换进行图像处理傅里叶变换是线性系统分析的一个有力工具,它能够定量地分析诸如数字化系统、采样点、电子放大器、卷积滤波器、噪音和显示点等的作用。通过实验培养这项技能,将有助于解决大多数图像处理问题。对任何想在工作中有效应用数字图像处理技术的人来说,把时间用在学习和掌握博里叶变换上是很有必要的。傅立叶()变换的定义对于二维信号,二维变换定义为:F(u,v)=卜J®f(x,y)e-j2冗(似+vy)dxdy—g—gf(x,y)=JgJgF(u,v)ej2兀s+vy)dudvej=cos0+jsin0—g—g二维离散傅立叶变换为:F(u,v)=—SSf(x,y)e-j2兀s/M+vy/N)foru=0,1,2,...,M-1,v=0,1,2,...,N-1MNx=0y=0f(x,y)=££F(u,v)ej2冗(似/M+VY/N)forx=0,l,2,...,M-1,y=0,1,2,...,N-1u=0v=0图像的傅立叶变换与一维信号的傅立叶变换变换一样,有快速算法,具体参见参考书目,有关傅立叶变换的快速算法的程序不难找到。实际上,现在有实现傅立叶变换的芯片,可以实时实现傅立叶变换。巴特沃斯滤波器H(u,v)=11+[D(u,v)/D]2n0巴特沃斯lowpassfilterH(u,v)=11+[D/D(u,v)]2n0ButterworthhighpassfilterH(u,v)=e-D2(u,v)/2D02gaussianlowpassfilterH(u,v)=1—e-D2(u,v)/2D02gaussianhighpassfilterimshow(I);fftI=fft2(I);sfftI=fftshift(fftI);RR=real(sfftI);II=imag(sfftI);%显示原图像%二维离散傅立叶变换%直流分量移到频谱中心%取傅立叶变换的实部%取傅立叶变换的虚部3利用MATLAB软件实现数字图像傅立叶变换的程序:I=imread(‘原图像名.gif');%读入原图像文件figure;imshow(A);%归一化%设定窗口%显示原图像的频谱A=sqrt(RR.A2+II.A2);%计算频谱幅值A=(A-min(min(A)))/(max(max(A))-min(min(A)))*225;三、实验仪器与设备(包括实验平台、实验材料等)计算机;程序;移动式存储器(软盘、盘等)。记录用的笔、纸。四、实验内容(包括实验电路、实验步骤与流程、源程序代码、调试过程记录等,可另附页)1.打开计算机,安装和启动MATLAB程序;2.利用MatLab工具箱中的函数编制FFT频谱显示的函数;3.a).调入、显示图像;b)对图像做FFT并利用自编的函数显示其频谱;c)讨论不同的图像内容与FFT频谱之间的对应关系。4.对频谱分别进行巴特沃兹、高斯滤波(高通和低通),比较其锐化和平滑效果5.记录和整理实验报告。五、实验结果及分析(包括程序和数据的记录及分析、实验总结等,可另附页)i=imread('C:\picture\lena.bmp');%读入原图像文件figure(1);%设定窗口imshow(i);%显示原图像colorbar;%显示图像的颜色条title('原图像')%图像命名j=fft2(i);%二维离散傅立叶变换k=fftshift(j);%直流分量移到频谱中心l=log(abs(k));%数字图像的对数变换figure(2);%设定窗口imshow(l,[]);%显示原图像colorbar;%显示图像的颜色条title('经过二维快速傅立叶变换后的图像')%图像命名原图像经过二维快速傅立叶变换后的图像00000D00001D0离散傅立%理想低通滤波器J=imread('C:\picture\lena.bmp');figure(5);subpfigure(4);%设定窗口imshow(A);%显示原图像colorbar;%显示图像的颜色条title('离散傅立叶频谱');%图像命名经过二维快速傅立叶逆变换后的图像n=ifft2(j)/255;%逆二维快速傅里叶变换figure(3);%设定窗口imshow(n);%显示原图像colorbar;%显示图像的颜色条title('经过二维快速傅立叶逆变换后的图像')%图像命名m=fftshift(j);%直流分量移到频谱中心RR=real(m);%取傅立叶变换的实部II=imag(m);%取傅立叶变换的虚部A=sqrt(RR.A2+II.A2);%计算频谱幅值A=(A-min(min(A)))/(max(max(A))-min(min(A)))*225;%归一■化原图像悽立叶变换后的频谱通过理想滤波益I=imread('C:\picture\lena.bmp');%巴特沃斯低通滤波...