- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
快速傅里叶变化算法及应用
快速傅里叶变化算法及应用
课 程 数字信号处理实验 系 (院) 物理与电子科学系 专 业 班 级 学生姓名 学 号
离散傅里叶变换的性质
离散傅里叶变换(DFT),是连续傅里叶变换在时域和频域上都离散的形式,将时域信号的采样变换为在离散时间傅里叶变换(DTFT)频域的采样。在形式上,变换两端(时域和频域上)的序列是有限长的,而实际上这两组序列都应当被认为是离散周期信号的主值序列。即使对有限长的离散信号作DFT,也应当将其看作经过周期延拓成为周期信号再作变换。在实际应用中通常采用快速傅里叶变换以高效计算DFT。
需将较短序列补零后,再按长序列的点数做DFT
循环位移(Circular shift of a sequence)
对称性 (symmetry)
周期共轭对称(Periodic conjugate symmetry)定义为
周期共轭反对称(Periodic conjugate antisymmetry)定义为
循环卷积定理
二、快速傅里叶变换的算法原理
1. 将长序列DFT分解为短序列的DFT
2. 利用旋转因子的周期性、对称性、可约性。将时域序列逐次分解为一组子序列,利用旋转因子的特性,由子序列的DFT来实现整个序列的DFT。
其中:快速傅里叶变换分为两种,分为基2时间抽取算法和基2频率抽取算法
基2时间抽取(Decimation in time)FFT算法
其中:r=0,1,2…
基2频率抽取(Decimation in frequency)FFT算法
三、FFT的特点和规律
FFT算法特点:()
(1)共需次迭代;
(2)第次迭代对偶结点的偶距为,因此一组结点覆盖的序号个数是。
(3)第次迭代结点的组数为。
(4)可以预先计算好,而且的变化范围是。
FFT算法流程:()
(1)初始化:;
(2)第次迭代:
(a)下标控制变量初始化;
(b)“结点对”的个数初始化;
(c)
四、蝶形运算的MATALAB的程序设计
下面以16点为例:
disp(请输入一个点序列);for ii=1:16?????????%自由输入序列x(ii) = input([x(,num2str(ii),)=]);
end
%整体运用原位计算m=nextpow2(x);N=2^m; % 求x的长度对应的2的最低幂次mif length(x)N
x=[x,zeros(1,N-length(x))]; % 若x的长度不是2的幂,补零到2的整数幂end
nxd=bin2dec(fliplr(dec2bin([1:N]-1,m)))+1; % 求1:2^m数列序号的倒序y=x(nxd); % 将x倒序排列作为y的初始值for mm=1:m % 将DFT作m次基2分解,从左到右,对每次分解作DFT运算,共做m级蝶形运算,每一级都有2^(mm-1)个蝶形结Nz=2^mm;u=1; % 旋转因子u初始化为WN^0=1WN=exp(-i*2*pi/Nz); % 本次分解的基本DFT因子WN=exp(-i*2*pi/Nz)for j=1:Nz/2 % 本次跨越间隔内的各次蝶形运算,在进行第mm级运算时需要2^(mm-1)个 蝶形for k=j:Nz:N % 本次蝶形运算的跨越间隔为Nz=2^mmkp=k+Nz/2; % 蝶形运算的两个因子对应单元下标的关系t=y(kp)*u; % 蝶形运算的乘积项y(kp)=y(k)-t; % 蝶形运算y(k)=y(k)+t; % 蝶形运算end
u=u*WN; % 修改旋转因子,多乘一个基本DFT因子WNend
end
y
y1=fft(x)
五、快速傅里叶变换MATALAB程序设计
function samples(f,Fs,M) N=2^M; % fft点数=取样总点数 Ts=1/Fs; % 取样时间间隔 T=N*Ts; % 取样总时间=取样总点数*取样时间间隔 n=0:N-1; t=n*Ts; Xn=cos(2*f*pi*t); subplot(2,1,1); stem(t,Xn); axis([0 T 1.1*min(Xn) 1.1*max(Xn)]); xlabel(t --); ylabel(Xn); Xk=abs(fft(Xn,N)); subplot(2,1,2); stem(n,Xk); axis([0 N 1.1*min(Xk) 1.1*max(Xk)]); xlabel(frequency --); ylabel(!Xk!);
六、用FFT对时域的离散信号进行频谱的分析
(1)对以下序列进行谱分析。
选择FFT的变换区间N为8和16 两种情况进行频谱分
文档评论(0)