- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE
PAGE 7
※※※※※※※※※
※※※※※※※※※
※※
※※
※※
※※※※※※※※※
2007级数字通信
课程设计
数字通信课程设计报告书
课题名称
基于matlab的FFT算法程序设计
姓 名
学 号
院 系
物理与电信工程系
专 业
电子信息工程
指导教师
2010年 01
设计任务及要求:
进一步了解MATLAB软件,进一步熟悉MATLAB的语法规则和编辑方式,掌握傅里叶变换的含义和方法。掌握Fourier变换,解了关于MATLAB软件在数字信号处理方面的应用,熟悉MATLAB的语法规则和编程。用MATLAB实现快速Fourier变换。
指导教师签名:
2010年 01 月
指导教师评语:
指导教师签名:
2010年 月 日
三、成绩
验收盖章
2010年 月 日
基于matlab的FFT算法程序设计
一、设计目的
1.通过该设计,进一步了解MATLAB软件。
2.通过该设计,进一步熟悉MATLAB的语法规则和编辑方式。
3.通过该设计,掌握傅里叶变换的含义和方法。
二、设计的主要要求
掌握Fourier变换,解了关于MATLAB软件在数字信号处理方面的应用,熟悉MATLAB的语法规则和编程。用MATLAB实现快速Fourier变换。
三、整体设计方案 对信号x=sin(2*pi*f0*t)进行频谱分析,用MATLAB仿真。选取抽样频率为fs=100Hz,依照下列条件用MATLAB软件对信号xt进行傅里叶变换y=fft(xt,N)并绘制频谱图,观察所产生的六幅频谱图进行对比,并进行分析。
四、程序设计
fs=100;%设定采样频率
N=128;
n=0:N-1;
t=n/fs;
f0=10;%设定正弦信号频率
%生成正弦信号
x=sin(2*pi*f0*t);
figure(1);
subplot(321);
plot(t,x);%作正弦信号的时域波形
xlabel(t);
ylabel(y);
title(正弦信号y=2*pi*10t时域波形);
grid;
%进行FFT变换并做频谱图
y=fft(x,N);%进行fft变换
mag=abs(y);%求幅值
m=length(y);
f=(0:m/2-1)*fs/m;%进行对应的频率转换
figure(1);
subplot(322);
plot(f,mag(1:m/2));%做频谱图
axis([0,100,0,80]);
xlabel(频率(Hz));
ylabel(幅值);
title(正弦信号y=2*pi*10t幅频谱图N=128);
grid;
%求均方根谱
sq=abs(y);
figure(1);
subplot(323);
plot(f,sq(1:m/2));
xlabel(频率(Hz));
ylabel(均方根谱);
title(正弦信号y=2*pi*10t均方根谱);
grid;
%求功率谱
power=sq.^2;
figure(1);
subplot(324);
plot(f,power(1:m/2));
xlabel(频率(Hz));
ylabel(功率谱);
title(正弦信号y=2*pi*10t功率谱);
grid;
%求对数谱
ln=log(sq);
figure(1);
subplot(325);
plot(f,ln(1:m/2));
xlabel(频率(Hz));
ylabel(对数谱);
title(正弦信号y=2*pi*10t对数谱);
grid;
%用IFFT恢复原始信号
xifft=ifft(y);
magx=real(xifft);
ti=[0:length(xifft)-1]/fs;
figure(1);
subplot(326);
plot(ti,magx);
xlabel(t);
ylabel(y);
title(通过IFFT转换的正弦信号波形);
grid;
五、程序仿真
图5.1 基于matlab的FFT算法程序设计仿真图
六、设计总结与心得体会
快速傅氏变换 英文名是fast fourier transform,快速傅氏变换(FFT)是离散傅氏变换(DFT)的快速算法,它是根据离散傅氏变换的奇、偶、虚、实等特性,对离散傅立叶变换的算法进行改进获得的。快速傅里叶变换有广泛的应用,如数字信号处理、计算大整数乘法、求解偏微分方程等等。有各种快速算法。
对于复数序列,用离散傅里叶变换。快速傅里叶变换可以计算出与直接计算相同的结果,但只需要的计算复杂度。通常,快速算法要求n能被因数分解,但不是所有的
文档评论(0)