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;
}
分享到:
相关推荐
总结来说,"fft C语言实现.zip"包含的是一个关于如何用C语言实现快速傅里叶变换的教程或代码示例,可能详细解释了FFT的基本原理,提供了具体的C语言代码,并通过"fft C语言实现.txt"文件呈现这些内容。理解和掌握FFT...
标题中的"FFT.rar_FFT定点_c语言 fft_c语言实现FFT_fft的C语言实现_happen6x5"表明这是一个关于快速傅里叶变换(FFT)的C语言实现,特别是针对定点数运算的版本。在数字信号处理领域,FFT是一种非常重要的算法,用于将...
二、C语言实现FFT的关键步骤 1. 分配内存:首先需要为输入序列(原序列)和输出序列(频域序列)分配足够的内存空间。 2. 划分序列:将输入序列划分为偶数部分和奇数部分,分别进行处理。 3. 递归分解:对于较小...
### FFT的C语言实现 快速傅里叶变换(Fast Fourier Transform, FFT)是一种高效的计算离散傅里叶变换(Discrete Fourier Transform, DFT)及其逆变换的算法。FFT不仅在信号处理领域有着广泛的应用,而且在数据压缩...
总的来说,这个"fft.rar"压缩包提供了一个C语言实现的1024点FFT算法,对于学习和使用FFT技术的人来说是一个宝贵的资源。通过阅读和理解"fft.cpp"的代码,可以增强对数字信号处理的理解,特别是对快速傅里叶变换的...
标题中的"fft.rar_FFT c++ builder_fft_fft c语言_fft的C语言实现"指的是一个关于快速傅里叶变换(FFT)的压缩包文件,其中包含了使用C++ Builder和C语言实现FFT算法的相关资料。FFT是一种在数字信号处理领域中常用的...
综上所述,"fft.rar_fft_fft c语言_fft的C语言实现"是一个关于使用C语言实现快速傅里叶变换的项目,涉及到数据结构设计、核心算法的实现、以及可能的应用场景和优化策略。通过理解这些知识点,开发者可以自行编写或...
这里提到的C语言实现很可能是采用了radix-2 FFT,因为它更为简单且效率高,前提是输入序列长度必须为2的幂。 C代码实现FFT通常包括以下几个步骤: 1. **预处理**:检查输入序列长度是否为2的幂,如果不是,可能需要...
本文将深入探讨如何使用C语言实现64点快速傅里叶变换(FFT),并结合提供的DIF.CPP源代码,解析其实现细节。快速傅里叶变换是数字信号处理领域中的一种核心算法,它能高效地计算离散傅里叶变换(DFT)及其逆变换...
本资料包提供的是FFT算法的C语言实现,特别适用于理解和实践谐波计算。** **一、FFT算法概述** FFT是离散傅里叶变换(DFT)的一种高效算法,由Cooley和Tukey于1965年提出。它通过将大问题分解为小问题来减少计算量...
采用频域分解法的快速傅里叶变化(FFT)进行了C语言的实现,可用于频域分析(如电力中的电压电流谐波分析)。
本文将详细讲解C语言实现FFT的相关知识点,并基于提供的描述进行深入探讨。 首先,我们需要理解离散傅里叶变换(DFT)的基本概念。DFT是将一个复数序列转换到频域的数学工具,它将时域信号转化为频域表示,以便分析...
数字信号处理dit-fft和ifft的c语言实现
标题"fft.rar_C语言 FFT_fft_fft c语言_fft.c"明确指出这是一个关于快速傅里叶变换(FFT)的C语言实现。FFT是一种在数字信号处理领域广泛应用的算法,它能够高效地计算离散傅里叶变换(DFT)。"fft.c"是C语言源代码文件...
自己编写的,能够实现任意点数的FFT运算的函数 结果和用MATLAB计算结果一样
标题中的"FFT.rar"指的是一个压缩包文件,其中包含了关于快速傅里叶变换(Fast Fourier Transform,简称FFT)的C语言实现。FFT是一种高效的算法,用于计算离散傅里叶变换(Discrete Fourier Transform,DFT),在...
实数FFT算法的设计及其C语言实现 本资源摘要信息旨在介绍实数FFT算法的设计和C语言实现,通过对算法的推导和C语言函数的实现,旨在为读者提供一个实用的解决方案,能够直接应用于自己的系统中。 一、实数FFT算法的...
标题中的"C语言实现FFT变换"指的是使用C编程语言来实现快速傅里叶变换(Fast Fourier Transform,简称FFT),这是一种在数字信号处理领域中广泛应用的算法,用于高效地计算离散傅里叶变换(DFT)及其逆变换。FFT能够...
标题中的"fft.rar"指的是一个使用C语言实现快速傅里叶变换(FFT)的代码库,其中包含了C语言版本的FFT以及逆快速傅里叶变换(IFFT)。这个压缩包可能是一个开发项目或者学习资源,提供了详细的注释,便于理解和应用。 ...