?? fft.cpp
字號:
#include "stdafx.h"
#include <math.h>
#include < stdio.h>
#include "fft.h"
#define pi 3.14159265358979323846
COMPX EE(COMPX b1,COMPX b2)
{
COMPX b3;
b3.real=b1.real*b2.real-b1.imag*b2.imag;
b3.imag=b1.real*b2. imag +b1.imag*b2.real;
return(b3);
}
void FFT(COMPX *xin,int N)
{
int m,LH,nm,I,k,J,M,K;
float p,ps;
int B,N1;
COMPX w,T;
M=log10(N)/log10(2);
LH=N/2;
J=LH;
N1=N-2;
for(I=1;I<=N1;I++)
{
if(I<J)
{
T=xin[I];
xin[I]= xin[J];
xin[J]=T;
}
K=LH;
while(J>=K)
{
J=J-K;
K=K/2;
}
J=J+K;
}
for(m=1;m<=M;m++)
{
B=pow(2,m-1);
for(J=0;J<=B-1;J++)
{
p=pow(2,M-m)*J;
ps=2*pi/N*p;
w.real=cos(ps);
w.imag=-sin(ps);
for(k=J;k<=N-1;k=k+pow(2,m))
{
T=EE(xin[k+B],w);
xin[k+B].real=xin[k].real-T.real;
xin[k+B].imag=xin[k]. imag -T.imag;
xin[k].real=xin[k].real+T.real;
xin[k].imag=xin[k]. imag +T.imag;
}
}
}
}
void sine_generate(COMPX *xin,int N,float npp,float amplitude)
{
for(int i=0;i<N;i++)
xin[i].imag=0;
if(npp-2.00<0.00001)
{
for(i=0;i<N;i++)
xin[i].real=amplitude * pow(-1,i);
}
else
{
for(i=0;i<N;i++)
xin[i].real=amplitude * sin(2*pi*i/npp);
}
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -