Time-selected base 2FFT and IFFT algorithm C language implementation

xiaoxiao2021-03-06  72

/ * Time Lift 2FFT and IFFT Algorithm C Language Realization * // * Author: Junyi Sun // * Copyright 2004-2005 * // * mail: ccnusjy@yahoo.com.cn * / # include #include #include #define n 1000 / * Defines the plural type * / typef struct {Double Real; Double Img;} complex;

Complex x [n], * w; / * Enter a sequence, transform core * / int size_x = 0; / * Enter the size of the sequence, only 2 power * / double pi; / * circumference * /

INT main () {Int i, method; void fft (); / * Fast Fourier transform * / void ifft (); voidin (); / * Initialization transformation nuclear * / void change (); / * index * / Void add (complex, complex *); / * complex addition * / void mul (complex, complex, complex *); / * complex multiplication * / void sub (complex, complex, complex *); / * complex Subtraction * / Void Divi (Complex, Complex, Complex *); / * Complex Different * / Void Output (); / * Output * / System ("CLS"); PI = Atan (1) * 4; Printf (" Please input the size of x: / n "); scanf ("% d ", & size_x); Printf (" "please input the data in x [n]: / n"); for (i = 0; i

/ * Fast Fourier Transform * / Void FFT () {INT i = 0, J = 0, K = 0, L = 0; COMPLEX Up, Down, Product; Change (); for (i = 0; i < LOG (size_x) / log (2); i ) {/ * first-class butterfly calculation * / l = 1 << i; for (j = 0; j

/ * Fast Fourier transform * / void ifft () {INT i = 0, J = 0, K = 0, L = Size_x; Complex Up, Down; For (i = 0; INT) (LOG (SIZE_X) / log (2)); i ) {/ * 1st butterfly calculation * / l / = 2; for (j = 0; j

/ * Calculation, X (N) code bits inverted * / void change () {complex temp; unsigned short i = 0, j = 0, k = 0; Double T; for (i = 0; i 0) {j = j << 1; j | = (k & 1); k = k >> 1;} IF (j> i) {TEMP = x [i]; x [i] = x [j]; x [j] = temp;}}}}}

/ * Results of Fourier Transform * / void Output () {INT I; Printf ("The Result is Follows / N"); for (i = 0; i = 0.0001) Printf (" %. 4fj / n ", x [i] .img); Else IF (Fabs (X [i ] .img) <0.0001) Printf ("/ n"); Else Printf ("%. 4fj / n", x [i] .img);}} Void Add (Complex A, Complex B, Complex * c) { C-> Real = a.real b.real; c-> img = a.img b.img;}

转载请注明原文地址:https://www.9cbs.com/read-111256.html

New Post(0)