matlab-光电图像处理实验(傅立叶变换)

合集下载

matlab中的傅里叶变换

matlab中的傅里叶变换

matlab中的傅里叶变换Matlab中的傅里叶变换是一种数学工具,用于将一个信号从时域转换到频域。

它是一种广泛应用于信号处理、图像处理、通信系统等领域的重要技术。

在Matlab中,傅里叶变换可以通过内置函数fft和ifft来实现。

fft函数用于计算离散傅里叶变换(DFT),而ifft函数用于计算离散傅里叶逆变换(IDFT)。

傅里叶变换在Matlab中的使用步骤如下:1. 准备信号数据,将待变换的信号存储在一个向量中,可以是时间域的信号序列。

2. 应用fft函数,使用fft函数对信号进行傅里叶变换,得到频域表示。

3. 可选操作,对频域表示进行幅度谱和相位谱的计算,以及其他的频谱分析操作。

4. 应用ifft函数,如果需要,可以使用ifft函数对频域表示进行逆变换,将信号恢复到时域。

需要注意的是,傅里叶变换得到的频域表示是对称的,通常只需要使用一半的频域数据进行分析。

此外,Matlab中还提供了其他相关的函数,如fftshift和ifftshift,用于对频域数据进行平移操作。

傅里叶变换在信号处理中有广泛的应用,例如:1. 频谱分析,可以通过傅里叶变换将信号从时域转换到频域,进而分析信号的频谱特性,如频率成分、频谱密度等。

2. 滤波器设计,可以在频域上设计滤波器,通过傅里叶变换将滤波器的频率响应转换到时域,实现对信号的滤波操作。

3. 图像处理,可以利用傅里叶变换对图像进行频域滤波、图像增强等操作,如去除噪声、边缘检测等。

总结起来,Matlab中的傅里叶变换是一种强大的信号处理工具,通过将信号从时域转换到频域,可以实现频谱分析、滤波器设计、图像处理等应用。

实验用MATLAB计算傅里叶变换

实验用MATLAB计算傅里叶变换

实验二 用MATLAB 计算傅立叶变换(2课时)一、实验目的1、掌握用MA TLAB 计算DTFT 及系统频率响应的方法。

2、掌握用MA TLAB 计算DFT 和IDFT 的方法。

3、掌握用DFT 计算圆周卷积和线性卷积的方法。

二、实验设备计算机一台,装有MATLAB 软件。

三、实验原理和基本操作1.用MA TLAB 计算DTFT对于序列x (n ),其离散时间傅立叶变换(DTFT )定义为:∑∞-∞=-=n n j e n x j X ωω)()( (1)序列的傅立叶变换(DTFT )在频域是连续的,并且以ω=2π为周期。

因此只需要知道jw X(e )的一个周期,即ω=[0,2π],或[-π,π]。

就可以分析序列的频谱。

用MA TLAB 计算DTFT ,必须在-π≤ω≤π范围内,把ω用很密的、长度很长的向量来近似,该向量中各个值可用下式表示: w=k*dw=k*K π2 (2) 其中:d ω=Kπ2 称为频率分辨率。

它表示把数字频率的范围2π均分成K 份后,每一份的大小,k 是表示频率序数的整数向量,简称为频序向量,它的取值可以有几种方法:通常在DTFT 中,频率取-π≤ω<л的范围,当K 为偶数时,取 k 12,,1,0,1,,12,2--+--=K K K 如果K 为奇数,则取 k 5.02,,1,0,1,,5.02--+-=K K 可以为奇偶两种情况综合出一个共同的确定频序向量k 的公式; k=12K -⎢⎥-⎢⎥⎣⎦ :12K -⎢⎥⎢⎥⎣⎦(3) 上式中⎢⎥⎣⎦表示向下取整。

在MA TLAB 中的向下取整函数为floor ,floor (x )的作用是把x 向下(向-∞方向)取整,所以与(3)式等价的MATLAB 语句为 k ))5.02(:)5.02((-+-=K K floor (4) 给定了输入序列(包括序列x 及其位置向量n ),又设定了频率分辨率d ω及频序向量k ,则DTFT 的计算式(1)可以用一个向量与矩阵相乘的运算来实现。

matlab实现傅里叶变换

matlab实现傅里叶变换

matlab实现傅里叶变换傅里叶变换是一种将一个连续时间函数(或离散时间函数)分解成基函数的超级工具。

它的用途非常广泛,例如在信号处理、音频处理、图像处理、机器学习等领域都有重要的应用。

在这篇文章中,我将介绍使用 MATLAB 实现傅里叶变换的基本步骤。

一、MATLAB 傅里叶变换函数在 MATLAB 中,我们可以使用 fft 函数实现傅里叶变换。

FFT 表示快速傅里叶变换,是一种高效的算法,可以在很短的时间内计算出信号的频域表示。

下面是 fft 函数的基本语法:X = fft(x)其中 x 是输入信号,X 是输出信号的频域表示。

由于傅里叶变换是一个复杂的计算过程,输入信号需要满足一些条件。

这些条件将在下一节中讨论。

在进行傅里叶变换之前,我们需要确保输入信号满足一些条件,以便 fft 函数可以正确地执行。

这些条件包括以下要求:1. 信号长度为 2 的正整数次幂在傅里叶变换中,信号长度通常是 2 的正整数次幂,例如 2、4、8、16、32 等等。

如果信号长度不是 2 的正整数次幂,则 fft 函数将自动进行填充。

2. 离散时间信号需要零填充如果输入信号是离散时间信号,我们需要使用零填充的方法将信号长度补齐至 2 的正整数次幂。

例如,如果我们的离散时间信号包含 100 个样本,我们需要将其补齐至128 个样本(下一个最小的 2 的正整数次幂)。

3. 连续时间信号需要采样如果输入信号是连续时间信号,我们需要对其进行采样,以便将其转换为离散时间信号。

采样频率需要高于信号的最高频率,这样才能避免混叠现象的发生。

下面是一个简单的示例,其中我将展示如何使用 MATLAB 实现傅里叶变换。

假设我们有一个正弦波信号,频率为 10 Hz,并将其采样为 100 个样本。

我们可以定义该信号如下:Fs = 100; % 采样频率T = 1/Fs; % 采样周期L = 100; % 信号长度t = (0:L-1)*T; % 时间向量f = 10; % 信号频率x = sin(2*pi*f*t); % 正弦波信号我们可以使用 plot 函数绘制该信号:plot(t,x)xlabel('Time (s)')ylabel('Amplitude')title('Original Signal')现在我们可以将该信号传递给 fft 函数,并将频域表示存储在 X 变量中:由于傅里叶变换输出的是一个复数数组,因此我们需要使用 abs 函数计算幅度谱并将其绘制出来:P2 = abs(X/L);P1 = P2(1:L/2+1);P1(2:end-1) = 2*P1(2:end-1);f = Fs*(0:(L/2))/L;plot(f,P1)xlabel('Frequency (Hz)')ylabel('Amplitude')title('Frequency Spectrum')幅度谱显示了信号在频域中的分布情况,显示了信号的频率成分及其振幅。

matlab光谱傅里叶变换提取相位

matlab光谱傅里叶变换提取相位

MATLAB光谱傅里叶变换提取相位1. 傅里叶变换的基本概念傅里叶变换是一种重要的数学工具,它可以将一个函数从时间或空间域转换到频率域。

在信号处理和图像处理领域,傅里叶变换被广泛应用于频谱分析、滤波、特征提取等任务中。

傅里叶变换分为傅里叶正变换和傅里叶逆变换,在MATLAB中,我们可以使用fft函数进行傅里叶变换。

2. MATLAB中的光谱分析光谱分析是一种常见的信号处理技术,它可以帮助我们理解信号的频域特性。

在MATLAB中,我们可以使用fft函数对信号进行傅里叶变换,从而得到信号的频谱信息。

对于频谱分析,我们可以通过傅里叶变换来提取信号的幅度和相位信息。

在信号处理中,相位信息同样重要,它包含了信号的时序特性和波形信息。

3. 提取相位信息的重要性在光谱分析中,提取相位信息是一项重要的任务。

相位信息包含了信号的周期性和波形的具体形状,它对信号的重建和波形恢复具有关键作用。

在处理周期性信号或波形重建的任务中,我们常常需要从傅里叶变换的结果中提取相位信息。

4. MATLAB中提取相位信息的方法在MATLAB中,我们可以使用angle函数来提取信号的相位信息。

angle函数可以计算复数的幅角,对于傅里叶变换得到的复数结果,我们可以利用angle函数来提取其相位信息。

我们还可以使用unwrap函数来对提取的相位信息进行展开,从而得到连续的相位曲线。

5. 示例分析:MATLAB光谱傅里叶变换提取相位假设我们有一个周期性正弦信号,我们需要对其进行光谱分析并提取其相位信息。

我们可以使用fft函数对信号进行傅里叶变换,得到其频谱信息。

我们可以使用angle函数提取频谱中每个频率点的相位信息,并利用unwrap函数对相位信息进行展开。

我们可以将提取的相位信息进行可视化,以便更直观地理解信号的相位特性。

6. 个人观点在光谱分析中,提取相位信息是一项重要而复杂的任务。

MATLAB提供了丰富的函数和工具来辅助我们进行相位信息的提取和分析。

MATLAB实验傅里叶分析

MATLAB实验傅里叶分析

实验七 傅里叶变换一、实验目的傅里叶变换是通信系统、图像处理、数字信号处理以及物理学等领域内的一种重要的数学分析工具。

通过傅里叶变换技术可以将时域上的波形分 布变换为频域上的分布,从而获得信号的频谱特性。

MA TLAB 提供了专门的函数fft 、ifft 、fft2(即2维快速傅里叶变换)、ifft2以及fftshift 用于实现对信号的傅里叶变换。

本次实验的目的就是练习使用fft 、ifft 以及fftshift 函数,对一些简单的信号处理问题能够获取其频谱特性(包括幅频和相频特性)。

二、实验预备知识1. 离散傅里叶变换(DFT)以及快速傅里叶变换(FFT)简介设x (t )是给定的时域上的一个波形,则其傅里叶变换为2()() (1)j ft X f x t e dt π∞--∞=⎰显然X ( f )代表频域上的一种分布(波形),一般来说X ( f )是复数。

而傅里叶逆变换定义为:2()() (2)j ft x t X f e df π∞-∞=⎰因此傅里叶变换将时域上的波形变换为频域上的波形,反之,傅里叶逆变换则将频域上的波形变换为时域上的波形。

由于傅里叶变换的广泛应用,人们自然希望能够使用计算机实现傅里叶变换,这就需要对傅里叶变换(即(1)式)做离散化处理,使之符合电脑计算的特征。

另外,当把傅里叶变换应用于实验数据的分析和处理时,由于处理的对象具有离散性,因此也需要对傅里叶变换进行离散化处理。

而要想将傅里叶变换离散化,首先要对时域上的波形x (t )进行离散化处理。

采用一个时域上的采样脉冲序列:δ (t -nT ), n = 0, 1, 2, …, N -1;可以实现上述目的,如图所示。

其中N 为采样点数,T 为采样周期;f s = 1/T 是采样频率。

注意采样时,采样频率f s 必须大于两倍的信号频率(实际是截止频率),才能避免混迭效应。

接下来对离散后的时域波形()()()()x t x t t nT x nT δ=-=的傅里叶变换()X f 进行离散处理。

图像处理之傅里叶变换matlab实现

图像处理之傅里叶变换matlab实现

傅里叶变换一.实验内容:1、傅里叶变换二.实验目的:1、理解傅里叶变换的原理2、掌握傅里叶变换的性质三.实验步骤:1.首先构造一幅黑白二值图像,在128×128的黑色背景中心产生一个4×4的白色方块,对其进行傅里叶变换;(Matlab 中用fft2实现2D 傅里叶变换)2.把低频分量移到图象中心,而把高频分量移到四个角上;(方法有两种:其一,在FT 以前对测试图象逐点加权(-1)^(i+j);其二,利用FFTSHIFT 函数);3.利用图象增强中动态范围压缩的方法增强2DFT ;(Y =C*log (1+abs (X)));4.构造一幅黑白二值图像,在128×128的黑色背景中令第32行至36行、第32列至第36列的值为1(即产生一个4×4的白色方块),对其进行傅里叶变换;5.将上图旋转300,再进行傅里叶变换 (imrotate )6.构造二幅黑白二值图像,在128×128的黑色背景中分别令第60行至68行、第60列至第68列的值为1,第64行至65行、第64列至第65列的值为1产生两幅图像,分别对这两幅图像进行傅里叶变换四、原理分析、技术讨论、回答问题1、对于第二幅图像(第一步与第四步图像的比较),说明FOURIER 变换具有以下性质:)//(20000),(),(N vy M ux j e v u F y y x x f +-⇔--π2、对于第三幅图像(第一步与第五步图像的比较),说明FOURIER 变换具有以下性质:θcos r x = θs i n r y = αωc o s =u αωs i n =v),(),(00θαωθθ+⇔+F r f3、对于第四幅图像(第一步与第六步图像的比较),说明FOURIER 变换具有以下性质:)/,/(||1),(b v a u F ab by ax f =五、结果如下六、M文件如下:a=zeros(128,128);a(63:66,63:66)=1;A=fft2(a);b=fftshift(A);for i=1:128for j=1:128B(i,j)=log(1+abs(A(i,j)));endendh=zeros(128,128);h(32:36,32:36)=1;H=fft2(h);h1=imrotate(h,30);H1=fft2(h1);i=zeros(128,128);i(60:68,60:68)=1;I=fft2(i);j=zeros(128);j(64:65,64:65)=1;J=fft2(j);figure;subplot(221),imshow(a);title('原图');subplot(222),imshow(A);title('FT');subplot(223),imshow(b);title('低中高角FT'); subplot(224),imshow(B);title('增强2DFT');figure;subplot(221);imshow(a);title('Step 1原图'); subplot(222);imshow(A);title('Step 1FT'); subplot(223);imshow(h);title('Step 4原图'); subplot(224);imshow(H);title('Step 4FT');figure;subplot(221),imshow(a);title('Step 1原图'); subplot(222),imshow(A);title('Step 1FT'); subplot(223),imshow(h1);title('Step 5原图'); subplot(224),imshow(H1);title('Step 5FT');figure;subplot(321);imshow(a);title('Step 1原图'); subplot(322);imshow(A);title('Step 1FT'); subplot(323),imshow(i);title('Step 6原图1'); subplot(324),imshow(I);title('Step 6原图1FT'); subplot(325),imshow(j);title('Step 6原图2'); subplot(326),imshow(J);title('Step 6原图2FT');。

matlab如何做傅里叶变换

matlab如何做傅里叶变换

matlab如何做傅里叶变换Matlab是一款高级的计算机可视化程序,具有强大的图形和数据处理功能。

它可以帮助你快速处理大量数据,并进行准确的分析。

Matlab中的傅里叶变换(FFT)是用于分析数字信号(如声音或图像)的有用工具,它将时域信号转换为频域信号。

FFT可以显示出信号中每一段的频率、幅度和相位,从而可以反映出信号的构成成分。

在Matlab中,可以使用fft()函数来计算信号的傅里叶变换。

假设要对一段持续时间为T的实信号X(t)做FFT变换,首先要定义变换的采样频率fs,然后构造一个长度为N(N>T*fs)的数组x,填充X(t)的采样点,其中x[k] = X(k/fs)。

在Matlab中,可以使用linspace()函数快速生成x。

之后使用fft()来计算X(t)的FFT:y = fft(x);在此调用后,y数组就会保存有X(t)的FFT结果,它的长度为N,其中y[k]表示X(t)在频率为k/T的Fourier系数。

对于对称的实信号,Matlab还提供了一种快速的FFT实现——fftshift()函数,它可以快速计算一维实信号的FFT,省去了上述步骤所需的构造数组和调用fft()函数的时间。

要使用fftshift(),只需要调用函数fftshift(X)即可,其中X是X(t)的采样点。

总之,Matlab中的FFT工具可用于快速分析信号,方法简单便捷。

可以通过fft()和fftshift()函数快速获得信号的频谱,其结果可以反映出信号的频率、幅度和相位。

Matlab中的FFT功能可以为你的信号处理工作带来很大的方便。

Matlab技术傅里叶变换

Matlab技术傅里叶变换

Matlab技术傅里叶变换引言傅里叶变换是一种在信号处理和图像处理领域广泛应用的数学工具。

通过傅里叶变换,我们可以将一个信号或图像分解为不同频率的分量,从而更好地理解信号或图像的特性。

在实际应用中,Matlab是一个功能强大的工具,用于实现傅里叶变换和信号处理。

本文将介绍Matlab中傅里叶变换的基本原理、实现方法以及一些实际应用案例。

一、傅里叶变换的基本原理傅里叶变换是一种将一个函数或信号表示为频率分量的工具。

它可以将一个时域函数转换为频域函数,从而得到不同频率分量的振幅和相位信息。

在数学上,傅里叶变换将一个函数f(t)表示为连续频谱的形式,即F(ω),其中ω为频率。

傅里叶变换的基本公式如下:F(ω) = ∫f(t)e^(-jωt)dt其中,F(ω)表示频域函数,f(t)表示时域函数,j表示虚数单位,ω表示频率,e 为自然对数的底。

二、Matlab中傅里叶变换的实现方法在Matlab中,傅里叶变换可以通过fft函数来实现。

fft函数是Fast Fourier Transform的缩写,是一种快速傅里叶变换算法。

使用fft函数,我们可以方便地进行信号的频域分析。

具体实现步骤如下:1. 准备输入信号数据。

在Matlab中,可以通过向量或矩阵的形式表示一个信号。

2. 调用fft函数进行傅里叶变换。

输入参数为信号数据,输出结果为频域函数。

3. 对频域函数进行处理和分析。

可以进行滤波、频谱分析等操作。

4. 反傅里叶变换。

如果需要将频域函数转换回时域函数,可以使用ifft函数。

通过以上步骤,我们可以方便地实现对信号的傅里叶变换和频域分析。

三、实际应用案例傅里叶变换在信号处理和图像处理领域有着广泛的应用。

下面将介绍几个实际案例,展示了傅里叶变换的实际应用。

1. 音频信号处理音频信号是一种由不同频率的声波组成的信号。

通过傅里叶变换,我们可以将音频信号分解为不同频率分量的振幅和相位。

这使得我们能够实现音频信号的滤波、频谱分析和降噪等操作。

MATLAB数字图像处理几何变换傅里叶变换

MATLAB数字图像处理几何变换傅里叶变换

Matlab数字图像处理实验指导实验目的:通过实验,深入理解和掌握图像处理的基本技术,提高动手实践能力。

实验环境:Matlab变成实验一图像的几何变换实验内容:设计一个程序,能够实现图像的各种几何变换。

实验要求:读入图像,打开图像,实现图像的平移变换、比例缩放、转置变换、镜像变换、旋转变换等操作。

实验原理:图像几何变换又称为图像空间变换,它将一幅图像中的坐标位置映射到另一幅图像中的新坐标位置。

学习几何变换的关键就是要确定这种空间映射关系,以及映射过程中的变化参数。

几何变换不改变图像的像素值,只是在图像平面上进行像素的重新安排。

一个几何变换需要两部分运算:首先是空间变换所需的运算,如平移、镜像和旋转等,需要用它来表示输出图像与输入图像之间的(像素)映射关系;此外,还需要使用灰度插值算法,因为按照这种变换关系进行计算,输出图像的像素可能被映射到输入图像的非整数坐标上。

设原图像f(x0,y0)经过几何变换产生的目标图像为g(x1,y1),则该空间变换(映射)关系可表示为:x1=s(x0,y0)y1=t(x0,y0)其中,s(x0,y0)和t(x0,y0)为由f(x0,y0)到g(x1,y1)的坐标换变换函数。

一、图像平移图像平移就是将图像中所有的点按照指定的平移量水平或者垂直移动。

二、图像镜像镜像变换又分为水平镜像和垂直镜像。

水平镜像即将图像左半部分和右半部分以图像竖直中轴线为中心轴进行对换;而竖直镜像则是将图像上半部分和下半部分以图像水平中轴线为中心轴进行对换。

三、图像转置图像转置是将图像像素的x坐标和y坐标呼唤。

图像的大小会随之改变——高度和宽度将呼唤。

四、图像的缩放图像缩放是指将图像大小按照指定的比率放大或者缩小。

图像缩放函数imresize();调用格式如下:B=imresize(A,Scale,method);参数A为要进行缩放的原始图像。

Scale为统一的缩放比例。

如果希望在x和y方向上以不同比例进行缩放,可用如下调用形式。

图像处理之傅里叶变换matlab实现

图像处理之傅里叶变换matlab实现

图像处理之傅里叶变换matlab实现傅里叶变换是一种将时域信号转换为频域信号的数学工具。

在图像处理中,傅里叶变换可以用于图像的频域分析和滤波,以及图像的压缩和增强等应用。

Matlab是一种功能强大的数值计算和图形化工具,它提供了丰富的函数和工具箱,可以方便地进行傅里叶变换的实现。

在Matlab中,可以使用fft2函数对图像进行二维傅里叶变换。

该函数的基本语法如下:Y = fft2(X)其中,X是输入的图像矩阵,Y是输出的频域图像矩阵。

Y的大小与X 相同,表示了图像在频域中的分布情况。

为了更好地理解傅里叶变换的过程,我们可以使用一幅灰度图像作为示例进行实现。

首先,我们需要读取图像并将其转换为灰度图像。

可以使用imread函数读取图像,并使用rgb2gray函数将图像转换为灰度图像:img = imread('image.jpg');gray_img = rgb2gray(img);接下来,我们可以对灰度图像进行傅里叶变换。

首先,我们需要将图像矩阵进行归一化操作,以避免频谱的幅度过大。

可以使用im2double函数将图像矩阵转换为双精度类型:normalized_img = im2double(gray_img);然后,我们可以使用fft2函数对归一化后的图像矩阵进行傅里叶变换:fft_img = fft2(normalized_img);得到的fft_img是一个复数矩阵,包含了图像在频域中的幅度和相位信息。

为了更好地可视化频域图像,可以使用fftshift函数将频域图像的零频率移到中心位置:shifted_fft_img = fftshift(fft_img);最后,我们可以使用abs函数计算频域图像的幅度谱,并使用matshow函数将其显示出来:amplitude_spectrum = abs(shifted_fft_img);imshow(amplitude_spectrum, []);通过以上步骤,我们就可以实现对图像的傅里叶变换,并显示出频域图像的幅度谱。

matlab-光电图像处理实验(傅立叶变换)

matlab-光电图像处理实验(傅立叶变换)

光学图像处理实验报告学生姓名:班级:学号:指导教师:日期:一、实验室名称:二、实验项目名称: 图像变换三、实验原理:傅立叶变换是信号处理领域中一个重要的里程碑,它在图像处理技术中同样起着十分重要的作用,被广泛的应用于图像特征提取、图像增强与恢复、噪声抑制、纹理分析等多个方面。

1、离散傅立叶变换(DFT ):要把傅立叶变换应用到数字图像处理当中,就必须处理离散数据,离散傅立叶变换的提出使得这种数学方法能够和计算机技术联系起来。

正变换:逆变换:幅度:相位角:功率谱:2、快速傅立叶变换(FFT ): 离散傅立叶变换运算量巨大,计算时间长,其运算次数正比于N^2,当N 比较大的时候,运算时间更是迅速增长。

二快速傅立叶变换的提出将傅立叶变换的复杂度由N^2下降到了NlgN/lg2,当N 很大时计算量可大大减少。

而快速傅立叶变换(FFT)需要进行基2或者基4的蝶形运算,算法上面较离散傅立叶变换困难。

∑∑-=-=+-=1010)//(2),(1),(M x N y N vy M ux j e y x f MN v u F π∑∑-=-=+=1010)//(2),(),(M x N y N vy M ux j e v u F y x f π3、离散余弦变换(DCT):为FT 的特殊形式,被展开的函数是实偶函数的傅氏变换,即只有余弦项。

变换核固定,利于硬件实现。

具有可分离特性,一次二维变换可分解为两次一维变换。

正变换:逆变换:其中:四、实验目的:1. 了解各种图像正交变换的作用和用途;2. 掌握各种图像变换的方法和原理;3. 熟练掌握离散傅立叶变换(DFT)、离散余弦变换(DCT)的原理、方法和实现流程,熟悉两种变换的性质,并能对图像傅立叶变换的结果进行必要解释;4. 熟悉和掌握利用Matlab 工具进行图像傅立叶变换及离散余弦变换的基本步骤、MATLAB 函数使用及具体变换处理流程;5. 能熟练应用Matlab 工具对图像进行FFT 及DCT 处理,并能根据需要进行必要的频谱分析和可视化显示。

大学matlab课程设计图像的傅里叶变换及其应用

大学matlab课程设计图像的傅里叶变换及其应用

课程名称: MATLAB及在电子信息课程中的应用实验名称:图像的傅里叶变换及其应用设计四图像的傅里叶变换及其应用一、设计目的通过该设计,掌握傅里叶变换的定义及含义。

二、设计内容及主要的MATLAB 函数1、图像的离散傅里叶变换假设),(n m f 是一个离散空间中的二维函数,则该函数的二维傅里叶变换定义为nj m j e e n m f f 21),()2,1(ωωωω--∞∞-∞∞-∑∑=其中21ωω和是频域变量,单位是弧度/采样单元。

函数),(21ωωf 为函数),(n m f 的频谱。

二维傅里叶反变换的定义为21212121),(),(ωωωωωωππωππωd d e e f n m f n j m j ⎰⎰-=-==因此,函数),(n m f 可以用无数个不同频率的复指数信号的和表示,在频率),(21ωω处复指数信号的幅度和相位为),(21ωωfMATLAB 提供的快速傅里叶变换函数1)fft2:用于计算二维快速傅里叶变换,其语法格式为b=fft2(I),返回图像I 的二维傅里叶变换矩阵,输入图像I 和输出图像B 大小相同;b=fft2(I,m,n),通过对图像I 剪切或补零,按用户指定的点数计算二维傅里叶变换,返回矩阵B 的大小为m ⨯n 。

很多MATLAB 图像显示函数无法显示复数图像,为了观察图像傅里叶变换后的结果,应对变换后的结果求模,方法是对变换结果使用abs 函数。

2)fftn :用于计算n 维快速傅里叶变换,其语法格式为b=fftn(I),计算图像的n 维傅里叶变换,输出图像B 和输入图像I 大小相同; b=fftn(I, size),通过对图像I 剪切或补零,按size 指定的点数计算n 维傅里叶变换,返回矩阵B 的大小为size 。

3) fftshift :用于将变换后的图像频谱中心从矩阵的原点移到矩阵的中心,其语法格式为b=fftshift(I),将变换后的图像频谱中心从矩阵的原点移到矩阵的中心。

数字图像处理及MATLAB实现实验四——图像变换

数字图像处理及MATLAB实现实验四——图像变换

数字图像处理及MATLAB实现实验四——图像变换1.图像的傅⾥叶变换⼀(平移性质)傅⾥叶变换的平移性质表明了函数与⼀个指数项相乘等于将变换后的空域中⼼移到新的位置,并且平移不改变频谱的幅值。

I=imread('1.bmp');figure(1)imshow(real(I));I=I(:,:,3);fftI=fft2(I);sfftI=fftshift(fftI); %求离散傅⾥叶频谱%对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置RRfdp1=real(sfftI);IIfdp1=imag(sfftI);a=sqrt(RRfdp1.^2+IIfdp1.^2);a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;figure(2)imshow(real(a));I=imread('2.bmp');figure(1)imshow(real(I));I=I(:,:,3);fftI=fft2(I);sfftI=fftshift(fftI); %求离散傅⾥叶频谱%对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置RRfdp1=real(sfftI);IIfdp1=imag(sfftI);a=sqrt(RRfdp1.^2+IIfdp1.^2);a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;figure(2)imshow(real(a));I=imread('3.bmp');figure(1)imshow(real(I));I=I(:,:,3);fftI=fft2(I);sfftI=fftshift(fftI); %求离散傅⾥叶频谱%对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置RRfdp1=real(sfftI);IIfdp1=imag(sfftI);a=sqrt(RRfdp1.^2+IIfdp1.^2);a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;figure(2)imshow(real(a));实验结果符合傅⾥叶变换平移性质2.图像的傅⾥叶变换⼆(旋转性质)%构造原始图像I=zeros(256,256);I(88:168,124:132)=1; %图像范围是256*256,前⼀值是纵向⽐,后⼀值是横向⽐imshow(I)%求原始图像的傅⾥叶频谱J=fft2(I);F=abs(J);J1=fftshift(F);figureimshow(J1,[550])%对原始图像进⾏旋转J=imrotate(I,90,'bilinear','crop');figureimshow(J)%求旋转后图像的傅⾥叶频谱J=fft2(I);F=abs(J);J2=fftshift(F);figureimshow(J2,[550])3.图像的离散余弦变换⼀%对cameraman.tif⽂件计算⼆维DCT变换RGB=imread('cameraman.tif');figure(1)imshow(RGB)I=rgb2gray(RGB);%真彩⾊图像转换成灰度图像J=dct2(I);%计算⼆维DCT变换figure(2)imshow(log(abs(J)),[])%图像⼤部分能量集中在左上⾓处figure(3);J(abs(J)<10)=0;%把变换矩阵中⼩于10的值置换为0,然后⽤idct2重构图像K=idct2(J)/255;imshow(K)4.图像的离散余弦变换⼆% I=imread('1.bmp');% figure(1)% imshow(real(I));% I=I(:,:,3);% fftI=fft2(I);% sfftI=fftshift(fftI); %求离散傅⾥叶频谱% %对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置% RRfdp1=real(sfftI);% IIfdp1=imag(sfftI);% a=sqrt(RRfdp1.^2+IIfdp1.^2);% a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;% figure(2)% imshow(real(a));% I=imread('2.bmp');% figure(1)% imshow(real(I));% I=I(:,:,3);% fftI=fft2(I);% sfftI=fftshift(fftI); %求离散傅⾥叶频谱% %对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置% RRfdp1=real(sfftI);% IIfdp1=imag(sfftI);% a=sqrt(RRfdp1.^2+IIfdp1.^2);% a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;% figure(2)% imshow(real(a));% I=imread('3.bmp');% figure(1)% imshow(real(I));% I=I(:,:,3);% fftI=fft2(I);% sfftI=fftshift(fftI); %求离散傅⾥叶频谱% %对原始图像进⾏⼆维离散傅⾥叶变换,并将其坐标原点移到频谱图中央位置% RRfdp1=real(sfftI);% IIfdp1=imag(sfftI);% a=sqrt(RRfdp1.^2+IIfdp1.^2);% a=(a-min(min(a)))/(max(max(a))-min(min(a)))*225;% figure(2)% imshow(real(a));% %构造原始图像% I=zeros(256,256);% I(88:168,124:132)=1; %图像范围是256*256,前⼀值是纵向⽐,后⼀值是横向⽐% imshow(I)% %求原始图像的傅⾥叶频谱% J=fft2(I);% F=abs(J);% J1=fftshift(F);figure% imshow(J1,[550])% %对原始图像进⾏旋转% J=imrotate(I,90,'bilinear','crop');% figure% imshow(J)% %求旋转后图像的傅⾥叶频谱% J=fft2(I);% F=abs(J);% J2=fftshift(F);figure% imshow(J2,[550])% %对cameraman.tif⽂件计算⼆维DCT变换% RGB=imread('cameraman.tif');% figure(1)% imshow(RGB)% I=rgb2gray(RGB);% %真彩⾊图像转换成灰度图像% J=dct2(I);% %计算⼆维DCT变换% figure(2)% imshow(log(abs(J)),[])% %图像⼤部分能量集中在左上⾓处% figure(3);% J(abs(J)<10)=0;% %把变换矩阵中⼩于10的值置换为0,然后⽤idct2重构图像% K=idct2(J)/255;% imshow(K)RGB=imread('cameraman.tif');I=rgb2gray(RGB);I=im2double(I); %转换图像矩阵为双精度型T=dctmtx(8); %产⽣⼆维DCT变换矩阵%矩阵T及其转置T'是DCT函数P1*X*P2的参数B=blkproc(I,[88],'P1*x*P2',T,T');maxk1=[ 1111000011100000110000001000000000000000000000000000000000000000 ]; %⼆值掩模,⽤来压缩DCT系数B2=blkproc(B,[88],'P1.*x',mask1); %只保留DCT变换的10个系数I2=blkproc(B2,[88],'P1*x*P2',T',T); %重构图像figure,imshow(T);figure,imshow(B2);figure,imshow(I2);RGB=imread('cameraman.tif');I=rgb2gray(RGB);I=im2double(I); %转换图像矩阵为双精度型T=dctmtx(8); %产⽣⼆维DCT变换矩阵%矩阵T及其转置T'是DCT函数P1*X*P2的参数B=blkproc(I,[88],'P1*x*P2',T,T');maxk1=[ 1111000011100000100000000000000000000000000000000000000000000000 ]; %⼆值掩模,⽤来压缩DCT系数B2=blkproc(B,[88],'P1.*x',mask1); %只保留DCT变换的10个系数I2=blkproc(B2,[88],'P1*x*P2',T',T); %重构图像figure,imshow(T);figure,imshow(B2);figure,imshow(I2);5.图像的哈达玛变换cr=0.5;I=imread('cameraman.tif');I=im2double(I)/255; %将读⼊的unit8类型的RGB图像I转换为double类型的数据figure(1),imshow(I);%显⽰%求图像⼤⼩[m_I,n_I]=size(I); %提取矩阵I的⾏列数,m_I为I的⾏数,n_I为I的列数sizi=8;snum=64;%分块处理t=hadamard(sizi) %⽣成8*8的哈达码矩阵hdcoe=blkproc(I,[sizi sizi],'P1*x*P2',t,t');%将图⽚分成8*8像素块进⾏哈达码变换%重新排列系数CE=im2col(hdcoe,[sizi,sizi],'distinct');%将矩阵hdcode分为8*8互不重叠的⼦矩阵,再将每个⼦矩阵作为CE的⼀列[Y Ind]=sort(CE); %对CE进⾏升序排序%舍去⽅差较⼩的系数,保留原系数的⼆分之⼀,即32个系数[m,n]=size(CE);%提取矩阵CE的⾏列数,m为CE的⾏数,n为CE的列数snum=snum-snum*cr;for i=1:nCE(Ind(1:snum),i)=0;end%重建图像re_hdcoe=col2im(CE,[sizi,sizi],[m_I,n_I],'distinct');%将矩阵的列重新组织到块中re_I=blkproc(re_hdcoe,[sizi sizi],'P1*x*P2',t',t);%进⾏反哈达码变换,得到压缩后的图像re_I=double(re_I)/64; %转换为double类型的数据figure(2);imshow(re_I);%计算原始图像和压缩后图像的误差error=I.^2-re_I.^2;MSE=sum(error(:))/prod(size(re_I));。

[经验]matlab完成傅里叶变换

[经验]matlab完成傅里叶变换

一、傅立叶变化的原理;(1)原理正交级数的展开是其理论基础!将一个在时域收敛的函数展开成一系列不同频率谐波的叠加,从而达到解决周期函数问题的目的。

在此基础上进行推广,从而可以对一个非周期函数进行时频变换。

从分析的角度看,他是用简单的函数去逼近(或代替)复杂函数,从几何的角度看,它是以一族正交函数为基向量,将函数空间进行正交分解,相应的系数即为坐标。

从变幻的角度的看,他建立了周期函数与序列之间的对应关系;而从物理意义上看,他将信号分解为一些列的简谐波的复合,从而建立了频谱理论。

当然Fourier积分建立在傅氏积分基础上,一个函数除了要满足狄氏条件外,一般来说还要在积分域上绝对可积,才有古典意义下的傅氏变换。

引入衰减因子e^(-st),从而有了Laplace变换。

(好像走远了)。

(2)计算方法连续傅里叶变换将平方可积的函数f(t)表示成复指数函数的积分或级数形式。

这是将频率域的函数F(ω)表示为时间域的函数f(t)的积分形式。

连续傅里叶变换的逆变换 (inverse Fourier transform)为即将时间域的函数f(t)表示为频率域的函数F(ω)的积分。

一般可称函数f(t)为原函数,而称函数F(ω)为傅里叶变换的像函数,原函数和像函数构成一个傅里叶变换对(transform pair)。

二、傅立叶变换的应用;DFT 在诸多多领域中有着重要应用,下面仅是颉取的几个例子。

需要指出的是,所有DFT 的实际应用都依赖于计算离散傅里叶变换及其逆变换的快速算法,即快速傅里叶变换(快速傅里叶变换(即FFT )是计算离散傅里叶变换及其逆变换的快速算法。

)。

(1)、频谱分析DFT 是连续傅里叶变换的近似。

因此可以对连续信号x(t)均匀采样并截断以得到有限长的离散序列,对这一序列作离散傅里叶变换,可以分析连续信号x(t)频谱的性质。

前面还提到DFT 应用于频谱分析需要注意的两个问题:即采样可能导致信号混叠和截断信号引起的频谱泄漏。

matlab编程实现傅里叶变换

matlab编程实现傅里叶变换

傅里叶变换是信号处理和图像处理中的重要数学工具,可以将一个信号或图像从时域转换到频域。

MATLAB作为一款强大的数学软件,可以方便地实现傅里叶变换并进行相应的分析和处理。

本文将介绍如何使用MATLAB编程实现傅里叶变换,并探讨其在信号处理和图像处理中的应用。

一、MATLAB中的傅里叶变换函数在MATLAB中,可以使用fft函数来进行一维离散傅里叶变换(DFT)的计算,使用fft2函数进行二维离散傅里叶变换(DFT)的计算。

这两个函数的基本语法如下:1. 一维离散傅里叶变换Y = fft(X)其中,X是输入的一维信号(向量),Y是输出的一维频谱(向量)。

2. 二维离散傅里叶变换Y = fft2(X)其中,X是输入的二维图像(矩阵),Y是输出的二维频谱(矩阵)。

除了fft和fft2函数外,MATLAB还提供了ifft和ifft2函数用于进行离散傅里叶逆变换。

通过这些函数,我们可以方便地实现傅里叶变换和逆变换的计算。

二、MATLAB中的傅里叶变换实例为了更好地理解MATLAB中的傅里叶变换实现,我们可以通过一个具体的实例来进行演示。

假设我们有一个包含两个正弦波的信号,我们首先可以使用MATLAB生成这个信号,并对其进行傅里叶变换。

生成信号fs = 1000; 采样频率为1000Hzt = 0:1/fs:1-1/fs; 时间范围为1秒f1 = 50; 第一个正弦波的频率为50Hzf2 = 120; 第二个正弦波的频率为120Hzx = 0.7*sin(2*pi*f1*t) + sin(2*pi*f2*t); 生成包含两个正弦波的信号进行傅里叶变换N = length(x); 信号的长度X = fft(x)/N; 进行离散傅里叶变换,并进行归一化处理f = (0:N-1)*(fs/N); 计算频率轴figure;subplot(2,1,1);plot(f,abs(X)); 绘制频谱幅度title('单边频谱');xlabel('频率/Hz');ylabel('幅度');subplot(2,1,2);plot(f,angle(X)); 绘制频谱相位title('频谱相位');xlabel('频率/Hz');ylabel('相位');通过上面的实例,我们可以看到,MATLAB可以很方便地实现最常见的傅里叶变换,并且提供了丰富的绘图功能来呈现变换结果。

MATLAB数字图像处理几何变换傅里叶变换.docx

MATLAB数字图像处理几何变换傅里叶变换.docx

Matlab数字图像处理实验指导实验目的:通过实验,深入理解和掌握图像处理的基本技术,提高动手实践能力。

实验环境:Matlab变成实验一图像的几何变换实验内容:设计一个程序,能够实现图像的各种几何变换。

实验要求:读入图像,打开图像,实现图像的平移变换、比例缩放、转宜变换、镜像变换、旋转变换等操作。

实验原理:图像儿何变换乂称为图像空间变换,它将一幅图像中的朋标位置映射到另一•幅图像中的新处标位査。

学习儿何变换的关键就是要确定这种空间映射关系,以及映射过程小的变化参数。

几何变换不改变图像的像素值,只是在图像平面上进行像素的重新安排。

一个几何变换需要两部分运算:首先是空间变换所盂的运算,如平移、镜像和旋转等,需要川它來表示输出图像与输入图像Z间的(像素)映射关系;此外,述需耍使用灰度插值算法,因为按照这种变换关系进行计算,输出图像的像索可能被映射到输入图像的非整数坐标上。

设原图像f(xO,yO)经过几何变换产生的口标图像为g(xlYL),则该空间变换(映射)关系可表示为:xl=s(xO,yO)yl=t(xO,yO)其中,s(xO,yO)和t(xO,yO)为由f(xO,yO)到g(xl,yl)的坐标换变换函数。

一、图像平移图像平移就是将图像屮所有-的点按照指定的平移最水平或者垂肓移动。

二、 图像镜像镜像变换又分为水平镜像和垂肓镜像。

水平镜像即将图像左半部分和右半部分以图像竖 直中轴线为中心轴进行对换;而竖直镜像则是将图像上半部分和下半部分以图像水平中轴线 为中心轴进行对换。

三、 图像转置图像转置是将图像像索的x 坐标和y 坐标呼唤。

图像的大小会随Z 改变——高度和宽度 将呼唤。

原图像 10015020025050100 150 200 250 50100 150 200 250 图像平移50 100 150 200 250原图像 水平镜像原图像图像转蛊四、 图像的缩放图像缩放是指将图像大小按照指定的比率放大或者缩小。

MAtlab-傅里叶变换-实验报告(最新-编写)

MAtlab-傅里叶变换-实验报告(最新-编写)

MAtlab-傅里叶变换-实验报告(最新-编写)一、实验目的1. 了解傅里叶变换的基本概念及其在信号处理中的应用;2. 掌握使用Matlab软件进行傅里叶变换的方法;3. 通过实验掌握傅里叶变换的计算与图像分析方法。

二、实验原理1. 傅里叶级数傅里叶级数是一类振幅、频率和相位相同的正弦(余弦)函数构成某一周期函数的和。

若函数f(t)可以表示为周期2π的函数,则有:f(t) = a0 + ∑[an*cos(nwt) + bn*sin(nwt)] (1)其中,a0、an、bn为常数,w=2π/T为角频率,T为周期。

傅里叶级数引入相位角,使得函数形态可以更加丰富,而且描述更加直观。

假设n=0时,a0是函数f(t)的常数项,且an、bn分别表示f(t)的奇、偶对称部分的振幅,即:a0 = (1/2π)∫[f(t)]dt,an = (1/π)∫[f(t)*cos(nwt)]dt,bn =(1/π)∫[f(t)*s in(nwt)]dt式中,*为乘积,∫为积分。

在时域中,傅里叶分析用来分析周期性信号的性质。

但是,在实际应用中,很少有真正的周期性信号,因此需要将傅里叶分析推广到非周期性信号上,即傅里叶变换。

原信号可以表示为一个函数f(t),其傅里叶变换可以表示为:F(w) = ∫[f(t)*e^(-jwt)]dt其中,j为虚数单位,w为角频率。

傅里叶变换将信号从时域变换到频域,通常使用复数表示幅值与相位。

同时,傅里叶变换也具有很高的线性性质。

即,若有两个函数f1(t)和f2(t),其傅里叶变换分别是F1(w)和F2(w),则下列变换同样成立:a1*f1(t) + a2*f2(t)的傅里叶变换为a1*F1(w) + a2*F2(w)其中,a1、a2为常数。

最后,傅里叶变换的性质包括线性、平移、频移、反褶和自相关性等,这些性质都对信号处理和分析具有实际意义。

三、实验内容本实验主要分为两个部分:1. 计算周期波形的傅里叶级数并绘制其频谱图和振幅谱图。

matlab对光谱作傅里叶变换

matlab对光谱作傅里叶变换

matlab对光谱作傅里叶变换简介:傅里叶变换是一种数学方法,用于分析和表示信号或数据的频率成分。

在光学领域,傅里叶变换常用于分析光谱。

MATLAB是一种强大的编程语言,可以帮助我们方便地实现这一过程。

步骤1. 导入数据首先,我们需要导入我们需要分析的光谱数据。

这可以是实验测量得到的光谱数据,也可以是模拟生成的光谱数据。

在MATLAB中,我们可以使用“load”函数来导入数据。

2. 预处理在傅里叶变换之前,我们可能需要对光谱数据进行一些预处理,例如去噪、归一化等。

在MATLAB中,我们可以使用“imnoise”函数去除噪声,使用“norm”函数进行归一化处理。

3. 计算傅里叶变换在MATLAB中,我们可以使用“fft”函数来计算傅里叶变换。

例如,如果我们有一个一维数组表示光谱数据,我们可以使用以下命令计算其傅里叶变换:```matlabspectrum_fft = fft(spectrum_data);```4. 分析结果傅里叶变换的结果是一个复数数组,表示光谱数据的频率成分。

我们可以通过以下命令计算其幅度谱和相位谱:```matlabamplitude_spectrum = abs(spectrum_fft);phase_spectrum = angle(spectrum_fft);```5. 反傅里叶变换如果我们想要将频率成分转换回原始的光谱数据,我们可以使用“ifft”函数进行反傅里叶变换。

例如:```matlabreconstructed_spectrum = ifft(spectrum_fft);```6. 结果可视化最后,我们可以使用MATLAB的绘图功能将处理后的光谱数据进行可视化。

例如,我们可以使用“plot”函数绘制幅度谱和相位谱,使用“semilogy”函数绘制对数幅度的光谱数据。

总结在MATLAB中,我们可以方便地实现光谱数据的傅里叶变换和反傅里叶变换。

通过这种技术,我们可以分析和表示光谱数据的频率成分,从而更好地理解光谱的特性。

运用Matlab实现光学中的几个傅立叶变换

运用Matlab实现光学中的几个傅立叶变换

运用Matlab 实现光学中的几个傅立叶变换摘要:光学中的傅立叶变换具有难度高,抽象性大的特点,而Matlab 却具有强大的信号处理功能,结合光学中傅立叶变换、傅立叶级数、卷积定理的内容,通过Matlab 程序来体现 光学中几个傅里叶调动的直观演示。

关键词:傅立叶变换 Matlab 程序 傅立叶光学1. 引言:傅立叶变换的原理由正交级数的展开来完成,是将一个在时域收敛的函数展开成一系列不同频率谐波的叠加,从而达到解决周期性函数问题的目的。

在此根底上实行变动,对非周期函数进行时频变更。

跟着科学技术的不停成长与发展,信号处理在人们生产生活中应允了越来越普遍的应用,其中,采用通信频域的方法比起经典的方法体现出越来越多的优点,当今,光学中傅立叶变换和信号处理成为信号分析与处理的一种非常重要的手段和工具。

Matlab 是数学计算过程中可以用到的一种数学工具,其中,电子计算机为应用数学管理实际问题创造了必不可少的物质条件,如今,在电子技术高度发达的数学领域,技术科学中最有研究价值的是数学研究领域,而数学领域中数值分析和数学建模成为了重点中的重点。

1. 光学傅立叶变换光学傅立叶变动是光学中信息处理的根底,其中所运用的道理便是通过光学中透镜来实现傅立叶的变换效应,相干光的照射会使透镜L 后焦面上光场的复振幅分布即是位于透镜物体前焦面的复振幅函数F(x,y)的立叶变换F(u,v)。

将两个傅立叶变换串联就构成了典型的4厂(厂为透镜焦距)光学处理系统:Ll 的前焦面称为输入平面或物平面,Ll 的后焦面与L2的前焦面重合,称为频谱面或傅立叶面,L2的后焦面为输出平面或像平面。

待处理的图像信号可以是胶片或干板,也可以是空间光学调制器。

相干光(激光)经准直后形成宽束平行光照射位于输入平面上振幅透过率为厂(x,y)的胶片(相当于灰度为厂(x,y)的图像),由于Ll 的傅立叶变换效应,在频谱面上形成图像的傅立叶空间频谱,经L2的再次变换(傅立叶逆变换)在像平面上则形成原图的反像。

matlab傅立叶变换及图像的频域处理

matlab傅立叶变换及图像的频域处理

实验六傅立叶变换及图像的频域处理一、实验目的1、理解离散傅立叶变换的基本原理;2、掌握应用MATLAB语言进行FFT及逆变换的方法;3、熟悉图像在频域中处理方法,应用MA TLAB语言作简单的低通滤波器。

二、实验原理1、傅立叶变换的基本知识2、MATLAB提供的快速傅立叶变换函数三、实验要求1、读取图像girl.bmp,显示这幅图像,对图像作傅立叶变换,显示频域振幅图像。

作傅立叶逆变换,显示图像,看是否与原图像相同。

A=imread('F:\1\girl.bmp','bmp');subplot(1,3,1),imshow(A);title('原图像');B=fftshift(fft2(A));subplot(1,3,2),imshow(log(abs(B)), [ ], 'notruesize');title('二维傅立叶变换');C= ifft2(B);subplot(1,3,3),imshow(log(abs(C)), [ ], 'notruesize');title('逆变换后图像');2、设计一个简单的理想低通滤波器(截止频率自选),对图像作频域低通滤波,再作反变换,观察不同的截止频率下反变换后的图像与原图像的区别。

A=imread('F:\1\girl.bmp','bmp');subplot(3,2,1),imshow(A);title('原图像');B=fftshift(fft2(A));E= ifft2(B);subplot(3,2,2),imshow(log(abs(E)), [ ], 'notruesize');title('未滤波的逆变换图像');[X,MAP]=imread('F:\1\girl.bmp','bmp');[m,n]=size(X);H1=zeros(m,n);H1(m/2:m, n/2:n)=1;LOWPASS1=B.* H1;C=ifft2(LOWPASS1);subplot(3,2,3),imshow(log(abs(LOWPASS1)), [ ], 'notruesize');title('低通1');subplot(3,2,4),imshow(log(abs(C)), [ ], 'notruesize');title('低通1逆变换图像');H2=zeros(m,n);H2(m/10:m, n/10:n)=1;LOWPASS2=B.* H2;D=ifft2(LOWPASS2);subplot(3,2,5),imshow(log(abs(LOWPASS2)), [ ], 'notruesize');title('低通2');subplot(3,2,6),imshow(log(abs(D)), [ ], 'notruesize');title('低通2逆变换图像');3、设计一个简单的理想高通滤波器(截止频率自选),对图像作频域高通滤波,再作反变换,观察不同的截止频率下反变换后的图像与原图像的区别。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

光学图像处理实验报告学生姓名:班级:学号:指导教师:日期:一、实验室名称:二、实验项目名称: 图像变换三、实验原理:傅立叶变换是信号处理领域中一个重要的里程碑,它在图像处理技术中同样起着十分重要的作用,被广泛的应用于图像特征提取、图像增强与恢复、噪声抑制、纹理分析等多个方面。

1、离散傅立叶变换(DFT ):要把傅立叶变换应用到数字图像处理当中,就必须处理离散数据,离散傅立叶变换的提出使得这种数学方法能够和计算机技术联系起来。

正变换:逆变换:幅度:相位角:功率谱:2、快速傅立叶变换(FFT ): 离散傅立叶变换运算量巨大,计算时间长,其运算次数正比于N^2,当N 比较大的时候,运算时间更是迅速增长。

二快速傅立叶变换的提出将傅立叶变换的复杂度由N^2下降到了NlgN/lg2,当N 很大时计算量可大大减少。

而快速傅立叶变换(FFT)需要进行基2或者基4的蝶形运算,算法上面较离散傅立叶变换困难。

∑∑-=-=+-=1010)//(2),(1),(M x N y N vy M ux j e y x f MN v u F π∑∑-=-=+=1010)//(2),(),(M x N y N vy M ux j e v u F y x f π3、离散余弦变换(DCT):为FT 的特殊形式,被展开的函数是实偶函数的傅氏变换,即只有余弦项。

变换核固定,利于硬件实现。

具有可分离特性,一次二维变换可分解为两次一维变换。

正变换:逆变换:其中:四、实验目的:1. 了解各种图像正交变换的作用和用途;2. 掌握各种图像变换的方法和原理;3. 熟练掌握离散傅立叶变换(DFT)、离散余弦变换(DCT)的原理、方法和实现流程,熟悉两种变换的性质,并能对图像傅立叶变换的结果进行必要解释;4. 熟悉和掌握利用Matlab 工具进行图像傅立叶变换及离散余弦变换的基本步骤、MATLAB 函数使用及具体变换处理流程;5. 能熟练应用Matlab 工具对图像进行FFT 及DCT 处理,并能根据需要进行必要的频谱分析和可视化显示。

五、实验内容:1、读取以下两幅图像,分别对其进行离散傅立叶变换(FFT)。

变换处理中,要求进行频谱原点平移到(0,0),并能分别显示出其2D 频谱图。

通过对变换结果的分析,可以看出变换结果满足傅立叶变换(FT )的什么性质。

2、任意读取一幅灰度图像,对其进行FFT 变换,变换结果要求分别展示其64×64、128×128、256×256 的频谱图(注:为便于分析,要求变换结果的频率原点移动到(0.0)),且对64×64 频谱图能进行3D 显示。

3、任意读取一幅灰度图像,对其进行DCT 变换。

变换处理过程要求利用正交变换矩阵法及matlab 的dct2()函数两种方法分别进行,并对变换结果进行比较和分析。

六、实验器材(设备、元件):()()()()⎪⎭⎫ ⎝⎛+⎪⎭⎫ ⎝⎛+=∑∑-=-=N y v N x u y x f v c u c v u F N x N y c 212cos 212cos ,)()(,1010ππ∑∑-=-=⎥⎦⎤⎢⎣⎡+⎥⎦⎤⎢⎣⎡+=10102)12(cos 2)12(cos ),()()(),(N u N v c N v y N u x F y c x c y x f ππυμ⎪⎩⎪⎨⎧-≤≤==11201)(N k N k N k c计算机,Matlab软件七、实验步骤:1、快速傅立叶变换(FFT):⑴打开计算机,进入Matlab程序。

⑵画出程序设计流程图(图一),在Matlab中输入代码读取各图像。

⑶将两图分别转换成灰度图像。

⑷FFT变换,并将中心平移。

⑸将平移后矩阵取实部,归一化显示在同一窗口中。

⑹记录下图像,并对结果进行分析。

图一图二图三2、64X64,128X128,256X256 FFT变换:⑴接着上一实验,画出程序设计流程图(图二),在Matlab中输入代码。

⑵读取一幅大小合适的灰度图像。

⑶对图像分别经行64X64,128X128,256X256 FFT变换,并将中心平移。

⑷将平移后图像取实部,归一化之后显示在同一窗口中。

⑸显示64X64的3D FFT图像,记录图像,并对结果进行分析。

3、DCT离散余弦变换:⑴画出程序设计流程图(图三),在Matlab中输入代码。

⑵读取一幅大小合适的灰度图像。

⑶对图像分别调用Matlab内函数进行DCT直接变换和用正交矩阵进行变换。

⑷分别显示变换后图像。

⑸记录图像,并对结果进行分析。

八、实验结果及分析1、快速傅立叶变换FFT:其源代码为:clear;>> oimg1=imread('cameraman.tif');>> oimg2=imread('coins.png');>> temp1=fft2(oimg1);>> temp2=fft2(oimg2);>> newimg1=fftshift(temp1);>> newimg2=fftshift(temp2);>> A1=double(real(newimg1));>> B1=double(imag(newimg1));>> A2=double(real(newimg2));>> B2=double(imag(newimg2));>> last1=sqrt(A1.^2+B1.^2);>> last2=sqrt(A2.^2+B2.^2);>> newimg1=(last1/max(max(last1)))*100;>> newimg2=(last2/max(max(last2)))*100;>> subplot(2,2,1)>> imshow(oimg1)>> subplot(2,2,2)>> imshow(newimg1)>> subplot(2,2,3)>> imshow(oimg2)>> subplot(2,2,4)>> imshow(newimg2)其显示的结果为:分析:将两幅图先转化为灰度图像,然后将其进行FFT变换,中心平移,取实部,归一化显示在同一窗口上,得结果如上。

2、64X64,128X128,256X256 FFT变换:其源代码为:clear;>> oimg3=imread('cameraman.tif');>>>> temp3=fft2(oimg3,64,64);>> newimg3=fftshift(temp3);>> A3=double(real(newimg3));>> B3=double(imag(newimg3));>> last3=sqrt(A3.^2+B3.^2);>> newimg6464=(last3/max(max(last3)))*255;>>>> temp3=fft2(oimg3,128,128);>> newimg3=fftshift(temp3);>> A3=double(real(newimg3));>> B3=double(imag(newimg3));>> last3=sqrt(A3.^2+B3.^2);>> newimg128128=(last3/max(max(last3)))*255;>>>> temp3=fft2(oimg3,256,256);>> newimg3=fftshift(temp3);>> A3=double(real(newimg3));>> B3=double(imag(newimg3));>> last3=sqrt(A3.^2+B3.^2);>> newimg256256=(last3/max(max(last3)))*255;>>>> figure,subplot(2,2,1)>> imshow(oimg3)>> subplot(2,2,2)>> imshow(newimg6464)>> subplot(2,2,3)>> imshow(newimg128128)>> subplot(2,2,4)>> imshow(newimg256256)>>>> [x,y]=meshgrid(-32:31,-32:31);>> figure,surf(x,y,newimg6464)其显示的结果为:分析:读取灰度图像,对图像分别经行64X64,128X128,256X256 FFT变换,并将中心平移。

将平移后图像取实部,归一化之后显示在同一窗口中。

然后再显示64X64的3D FFT图像,记录图像,3D图像的中间部分向上凸起,得结果如上。

3、DCT变换:其源代码为:clear>> B=imread('cameraman.tif');>> dct=dct2(B);>> figure, imshow(B);>> figure, imshow(dct);>> figure>> imshow(log(abs(dct)),[]),colormap(jet(64)),colorbar>> A=im2double(imread('cameraman.tif'));>> P=dctmtx(size(A,1));>> dct=P*A*P';>> figure>> imshow(dct)其显示的结果为:分析:读取灰度图像,对图像分别调用Matlab内函数进行DCT直接变换和用正交矩阵进行变换。

分别显示变换后图像。

得结果如上。

九、总结实验结论:将图像分别进行快速FFT变换、64X64,128X128,256X256 FFT变换、dct变换得结果如上,这三种变换方法在图像变换中是非常重要的变换方法。

十、思考题:1、图像的傅立叶变换有哪些性质,它在图像处理中有什么作用?答:图像的傅立叶变换能把图像从空域转变成频域,并把频谱显示出来。

相关文档
最新文档