C语言实现FFT.docVIP

  • 6
  • 0
  • 约 12页
  • 2016-08-31 发布于河南
  • 举报
C语言实现FFT

#include iom128.h #include intrinsics.h #includemath.h #define PI 3.1415926535897932384626433832795028841971 //定义圆周率值 #define FFT_N 128 //定义福利叶变换的点数 struct compx {float real,imag;}; //定义一个复数结构 struct compx s[FFT_N]; //FFT输入和输出:从S[1]开始存放,根据大小自己定义 /******************************************************************* 函数原型:struct compx EE(struct compx b1,struct compx b2) 函数功能:对两个复数进行乘法运算 输入参数:两个以联合体定义的复数a,b 输出参数:a和b的乘积,以联合体的形式输出 *******************************************************************/ struct compx EE(struct compx a,struct compx b) { struct compx c; c.real=a.real*b.real-a.imag*b.imag; c.imag=a.real*b.imag+a.imag*b.real; return(c); } /***************************************************************** 函数原型:void FFT(struct compx *xin,int N) 函数功能:对输入的复数组进行快速傅里叶变换(FFT) 输入参数:*xin复数结构体组的首地址指针,struct型 *****************************************************************/ void FFT(struct compx *xin) { int f,m,nv2,nm1,i,k,l,j=0; struct compx u,w,t; nv2=FFT_N/2; //变址运算,即把自然顺序变成倒位序,采用雷德算法 nm1=FFT_N-1; for(i=0;inm1;i++) { if(ij) //如果ij,即进行变址 { t=xin[j]; xin[j]=xin[i]; xin[i]=t; } k=nv2; //求j的下一个倒位序 while(k=j) //如果k=j,表示j的最高位为1 { j=j-k; //把最高位变成0 k=k/2; //k/2,比较次高位,依次类推,逐个比较,直到某个位为0 } j=j+k; //把0改为1 } { int le,lei,ip; //FFT运算核,使用蝶形运算完成FFT运算 f=FFT_N; for(l=1;(f=f/2)!=1;l++) //计算l的值,即计算蝶形级数 ; for(m=1;m=l;m++) // 控制蝶形结级数 { //m表示第m级蝶形,l为蝶形级总数l=log(2)N le=2(m-1); //le蝶形结距离,即第m级蝶形的蝶形结相距le点 lei=le/2; //同一蝶形结中参加运算的两点的距离 u.real

文档评论(0)

1亿VIP精品文档

相关文档