1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.
#include<stdio.h>
#include<math.h>
#define nFFT 16
#define nFFT3_4 ((nFFT*3)/4)
double wn_FFT[nFFT3_4]; /* for twiddle factor */
short br_FFT[nFFT]; /* for bit reversal */
double xr[nFFT], xi[nFFT], yr[nFFT], yi[nFFT];
void fft_table(double wn_FFT[], short br_FFT[], int N_FFT);
void fft(double xr[], double xi[], double wn_FFT[], short br_FFT[], int N_FFT);
void swap(double *a, double *b);
/***************************/
/* Genarate tables for FFT */
/***************************/
void fft_table(double wn_FFT[], short br_FFT[], int N_FFT)
{
int i, n_half, ne, jp;
double arg;
/* Calculation of twiddle factor */
arg = 6.283185307f/N_FFT;
for (i=0; i<((N_FFT*3)>>2); i++) wn_FFT[i] = cos(arg*i);
/* Calculation of bit reversal table */
n_half = N_FFT>>1;
br_FFT[0] = 0;
for (ne=1; ne<N_FFT; ne=ne<<1)
{
for (jp=0; jp<ne; jp++) br_FFT[jp+ne] = br_FFT[jp] + n_half;
n_half = n_half>>1;
}
}
/**************************/
/* FFT for complex signal */
/**************************/
void fft(double xR[], double xI[], double wn_FFT[], short br_FFT[], int N_FFT)
{
double xtmpR, xtmpI;
int j, jnh, k, jxC, jxS, ne, n_half, n_half2;
n_half = N_FFT>>1;
for (ne=1; ne<N_FFT; ne=ne<<1)
{
n_half2 = n_half<<1;
for (k=0; k<N_FFT; k=k+n_half2)
{
jxC = 0;
jxS = N_FFT>>2;
for (j=k; j<(k+n_half); j++)
{
jnh = j + n_half;
/* beginning of butterfly operations */
xtmpR = xR[j];
xtmpI = xI[j];
xR[j] = xtmpR + xR[jnh];
xI[j] = xtmpI + xI[jnh];
xtmpR = xtmpR - xR[jnh];
xtmpI = xtmpI - xI[jnh];
xR[jnh] = xtmpR*wn_FFT[jxC] - xtmpI*wn_FFT[jxS];
xI[jnh] = xtmpR*wn_FFT[jxS] + xtmpI*wn_FFT[jxC];
/* end of butterfly operations */
jxC = jxC + ne;
jxS = jxS + ne;
}
}
n_half = n_half>>1;
}
/* Bit reverse */
for (j=0; j<N_FFT; j++)
if (j<br_FFT[j])
{
swap(&xR[j], &xR[br_FFT[j]]);
swap(&xI[j], &xI[br_FFT[j]]);
}
}
/* used in FFT procedure */
void swap(double *a, double *b)
{
double tmp;
tmp = *a;
*a = *b;
*b = tmp;
}
void main()
{
short i;
fft_table(wn_FFT, br_FFT, nFFT); /* ganarate tables for FFT */
/* genarate rectangular wave */
for (i=0; i<nFFT; i++)
{
xr[i] =sin(6.28*i/3);
}
for (i=0; i<nFFT; i++)
{
yr[i] = xr[i];
yi[i] = xi[i];
}
fft(yr, yi, wn_FFT, br_FFT, nFFT); /* FFT */
for(i=0;i<nFFT;i++)
{
printf("%f ",xr[i]);
}
printf("\n\n ");
for(i=0;i<nFFT;i++)
{
printf("%f ",yi[i]);
}
}