首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

FFT的C语言兑现

2012-12-19 
FFT的C语言实现void fft(COMPLEX *x, int m){? COMPLEX *w?????????? /* used to store the w complex ar

FFT的C语言实现

void fft(COMPLEX *x, int m)
{

? COMPLEX *w;?????????? /* used to store the w complex array */
? int mstore = 0;?????? /* stores m for future reference */
? int n = 1;??????????? /* length of fft stored for future */

?COMPLEX u,temp,tm;
?COMPLEX *xi,*xip,*xj,*wptr;

?int i,j,k,l,le,windex;

?double arg,w_real,w_imag,wrecur_real,wrecur_imag,wtemp_real;

?if(m != mstore) {

??/* free previously allocated storage and set new m */

??if(mstore != 0) free(w);
??mstore = m;
??if(m == 0) return;?????? /* if m=0 then done */

??/* n = 2**m = fft length */

??n = 1 << m;
??le = n/2;

??/* allocate the storage for w */

??w = (COMPLEX *) calloc(le-1,sizeof(COMPLEX));
??if(!w) {
???printf("\nUnable to allocate complex W array\n");
???exit(1);
??}

??/* calculate the w values recursively */

??arg = 4.0*atan(1.0)/le;???????? /* PI/le calculation */
??wrecur_real = w_real = cos(arg);
??wrecur_imag = w_imag = -sin(arg);
??xj = w;
??for (j = 1 ; j < le ; j++) {
???xj->real = (float)wrecur_real;
???xj->imag = (float)wrecur_imag;
???xj++;
???wtemp_real = wrecur_real*w_real - wrecur_imag*w_imag;
???wrecur_imag = wrecur_real*w_imag + wrecur_imag*w_real;
???wrecur_real = wtemp_real;
??}
?}

?/* start fft */

?le = n;
?windex = 1;
?for (l = 0 ; l < m ; l++) {
??le = le/2;

??/* first iteration with no multiplies */

??for(i = 0 ; i < n ; i = i + 2*le) {
???xi = x + i;
???xip = xi + le;
???temp.real = xi->real + xip->real;
???temp.imag = xi->imag + xip->imag;
???xip->real = xi->real - xip->real;
???xip->imag = xi->imag - xip->imag;
???*xi = temp;
??}

??/* remaining iterations use stored w */

??wptr = w + windex - 1;
??for (j = 1 ; j < le ; j++) {
???u = *wptr;
???for (i = j ; i < n ; i = i + 2*le) {
????xi = x + i;
????xip = xi + le;
????temp.real = xi->real + xip->real;
????temp.imag = xi->imag + xip->imag;
????tm.real = xi->real - xip->real;
????tm.imag = xi->imag - xip->imag;
????xip->real = tm.real*u.real - tm.imag*u.imag;
????xip->imag = tm.real*u.imag + tm.imag*u.real;
????*xi = temp;
???}
???wptr = wptr + windex;
??}
??windex = 2*windex;
?}

?/* rearrange data by bit reversing */

?j = 0;
?for (i = 1 ; i < (n-1) ; i++) {
??k = n/2;
??while(k <= j) {
???j = j - k;
???k = k/2;
??}
??j = j + k;
??if (i < j) {
???xi = x + i;
???xj = x + j;
???temp = *xj;
???*xj = *xi;
???*xi = temp;
??}
?}

?

?free(w);
?w=NULL;

}

热点排行
Bad Request.