- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
离散傅里叶变换及其快速算法.
上机实验一:离散傅里叶变换及其快速算法一、设计目的通过编写程序,深入理解快速傅里叶变换算法(FFT)的含义,完成FFT算法的软件实现。二、设计任务 利用时间抽取算法,编写基2的快速傅立叶变换(FFT)程序,并在FFT程序基础上编写快速傅立叶反变换(IFFT)。三、设计要求1、FFT和IFFT子程序相对独立、具有一般性,并加详细注释;2、验证例5-4,并能得到正确结果;四、设计条件C语言五、编程规则1)程序输入元素的数目为2的整数次幂,即N为幂,整个运算需要M级蝶形运算。 2)输入序列按二进制码位倒置排列,输出序列按自然顺序排列。 3)输出数据占用输入数据的存储单元。 4)每一级含N/2个基本蝶形运算。第L级中有N/个群,群与群间隔为。同一级中各个群的系数W分布相同。处于第L级的群的系数是.8)对于第L级的蝶形运算,输入数据的间隔为。根据上述要求,设计程序源代码如下所示:#includemath.h#includeiostream.h#includeiomanip.h#define swap(a,b) {float T; T=(a);(a)=b;(b)=T;}void fft(float A[],float B[],unsigned M) //蝶形运算程序,A存实部,B存虚部,M是级数{unsigned long N,I,J,K,L,LE,LE1,P,Q,R;float Wr,Wi,Wlr,Wli,WTr,WTi,theta,Tr,Ti;N=1M;//N=1M表示N=2^MJ=0;for (I=0;IN-1;I++)//for循环负责码位倒置存储{if(JI){swap(A[I],A[J]);swap(B[I],B[J]);}K=N1;// K=N1表示K=N/2while (K=2J=K)//while循环表示须向次高位进一位{J-=K;K=1;//K=1表示K=K/2}J+=K;}for(L=1;L=M;L++)//for循环为M级FFT运算,外层循环由级数L控制,执行M次{LE=1L;// LE=1L表示2^L,是群间隔LE1=LE/2; //每个群的系数W数目Wr=1.0;Wi=0.0;theta=(-1)*3.1415926536/LE1;Wlr=cos(theta);Wli=sin(theta);for(R=0;RLE1;R++)//中层循环由群系数控制{for(P=R;PN-1;P+=LE)//R是群系数的编号,P、Q是基本蝶形运算两个输入数据在数组中的编号,循环每次完成同一个系数的蝶形运算{Q=P+LE1;Tr=Wr*A[Q]-Wi*B[Q];Ti=Wr*B[Q]+Wi*A[Q];A[Q]=A[P]-Tr;B[Q]=B[P]-Ti;A[P]+=Tr;B[P]+=Ti;}WTr=Wr;WTi=Wi;Wr=WTr*Wlr-WTi*Wli;Wi=WTr*Wli+WTi*Wlr;}}return;}}void main()//主程序{int i,M,N,lb;cout请输入转换类别(FFT,请输入1;IFFT,请输入0)endl;//确定转换类别cinlb;cout请输入序列长度Nendl;cinN;float *A= new float[N];float *B= new float[N];M=log(N)/log(2);cout请输入序列的实部endl;//输入序列实部for(i=0;iN;i++){cinA[i];}cout请输入序列的虚部endl;//输入序列虚部for(i=0;iN;i++){cinB[i];}cout setiosflags(ios::fixed);//输出格式控制cout您输入的序列为endl;cout setiosflags(ios::fixed);for(i=0;iN;i++)coutA[i]+jB[i]endl;coutendl;if(lb==0){for(i=0;iN;i++){B[i]=B[i]*(-1);}fft(A,B,M);for(i=0;iN;i++){B[i]=B[i]*(-1);}for(i=0;iN;i++){A[i]=A[i]/N;B[i]=B[i]/N;}}if(lb==1)fft(A,B,M);cout转换后的序列为endl;//输出序列for(i=0;iN;i++)coutA[i]+j(B[i])endl;coutendl;delete []A;delete []B;}2.实例验证序列计算FFT得:X(0): 6.00000+j0.00000X(1): 2.00000+j2.00000X(2): -6.00000+j0.00000X(3): 2.00000+j-2.00000这与例题计算结果相同,表示快速傅利叶正变换成功。2.
您可能关注的文档
- 离心泵检修规程..doc
- 离心泵气蚀现象与允许吸上真空高度..doc
- 离心泵特性曲线实验..doc
- 离心泵特性曲线测定实验报告..docx
- 离心泵特性曲线的测定..docx
- 离心泵的基本知识..docx
- 离心泵的性能测定..doc
- 离心泵的构造..doc
- 关于健康生活专卖店项目书.doc
- 项目一猪品种识别.doc
- 2023-2024学年广东省深圳市龙岗区高二(上)期末物理试卷(含答案).pdf
- 2023-2024学年贵州省贵阳市普通中学高一(下)期末物理试卷(含答案).pdf
- 21.《大自然的声音》课件(共45张PPT).pptx
- 2023年江西省吉安市吉安县小升初数学试卷(含答案).pdf
- 2024-2025学年广东省清远市九校联考高一(上)期中物理试卷(含答案).pdf
- 广东省珠海市六校联考2024-2025学年高二上学期11月期中考试语文试题.pdf
- 2024-2025学年语文六年级上册第4单元-单元素养测试(含答案).pdf
- 2024-2025学年重庆八中高三(上)月考物理试卷(10月份)(含答案).pdf
- 安徽省安庆市潜山市北片学校联考2024-2025学年七年级上学期期中生物学试题(含答案).pdf
- 贵州省部分校2024-2025学年九年级上学期期中联考数学试题(含答案).pdf
文档评论(0)