`

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;

}

分享到:
评论

相关推荐

    fft C语言实现.zip_FFT语言_c语言实现_c语言实现FFT_fft_fft c语言

    总结来说,"fft C语言实现.zip"包含的是一个关于如何用C语言实现快速傅里叶变换的教程或代码示例,可能详细解释了FFT的基本原理,提供了具体的C语言代码,并通过"fft C语言实现.txt"文件呈现这些内容。理解和掌握FFT...

    FFT.rar_FFT定点_c语言 fft_c语言实现FFT_fft的C语言实现_happen6x5

    标题中的"FFT.rar_FFT定点_c语言 fft_c语言实现FFT_fft的C语言实现_happen6x5"表明这是一个关于快速傅里叶变换(FFT)的C语言实现,特别是针对定点数运算的版本。在数字信号处理领域,FFT是一种非常重要的算法,用于将...

    快速傅里叶变换 fft C语言实现

    二、C语言实现FFT的关键步骤 1. 分配内存:首先需要为输入序列(原序列)和输出序列(频域序列)分配足够的内存空间。 2. 划分序列:将输入序列划分为偶数部分和奇数部分,分别进行处理。 3. 递归分解:对于较小...

    fft的c语言实现

    ### FFT的C语言实现 快速傅里叶变换(Fast Fourier Transform, FFT)是一种高效的计算离散傅里叶变换(Discrete Fourier Transform, DFT)及其逆变换的算法。FFT不仅在信号处理领域有着广泛的应用,而且在数据压缩...

    fft.rar_1024 FFT C语言_C 语 1024 FFT_C语言 FFT滤波_fft 1024

    总的来说,这个"fft.rar"压缩包提供了一个C语言实现的1024点FFT算法,对于学习和使用FFT技术的人来说是一个宝贵的资源。通过阅读和理解"fft.cpp"的代码,可以增强对数字信号处理的理解,特别是对快速傅里叶变换的...

    fft.rar_FFT c++ builder_fft_fft c语言_fft的C语言实现

    标题中的"fft.rar_FFT c++ builder_fft_fft c语言_fft的C语言实现"指的是一个关于快速傅里叶变换(FFT)的压缩包文件,其中包含了使用C++ Builder和C语言实现FFT算法的相关资料。FFT是一种在数字信号处理领域中常用的...

    fft.rar_fft_fft c语言_fft的C语言实现

    综上所述,"fft.rar_fft_fft c语言_fft的C语言实现"是一个关于使用C语言实现快速傅里叶变换的项目,涉及到数据结构设计、核心算法的实现、以及可能的应用场景和优化策略。通过理解这些知识点,开发者可以自行编写或...

    FFT C语言实现

    这里提到的C语言实现很可能是采用了radix-2 FFT,因为它更为简单且效率高,前提是输入序列长度必须为2的幂。 C代码实现FFT通常包括以下几个步骤: 1. **预处理**:检查输入序列长度是否为2的幂,如果不是,可能需要...

    c语言实现64点FFT

    本文将深入探讨如何使用C语言实现64点快速傅里叶变换(FFT),并结合提供的DIF.CPP源代码,解析其实现细节。快速傅里叶变换是数字信号处理领域中的一种核心算法,它能高效地计算离散傅里叶变换(DFT)及其逆变换...

    FFT说明.zip_FFT算法的C语言实现_fft_fft 谐波_谐波算法_谐波计算

    本资料包提供的是FFT算法的C语言实现,特别适用于理解和实践谐波计算。** **一、FFT算法概述** FFT是离散傅里叶变换(DFT)的一种高效算法,由Cooley和Tukey于1965年提出。它通过将大问题分解为小问题来减少计算量...

    一维数据FFT的C语言实现

    采用频域分解法的快速傅里叶变化(FFT)进行了C语言的实现,可用于频域分析(如电力中的电压电流谐波分析)。

    C语言实现FFT(快速傅里叶变换).zip_FFT C_c# fft_c语言 fft_fft c++_fft c语言

    本文将详细讲解C语言实现FFT的相关知识点,并基于提供的描述进行深入探讨。 首先,我们需要理解离散傅里叶变换(DFT)的基本概念。DFT是将一个复数序列转换到频域的数学工具,它将时域信号转化为频域表示,以便分析...

    数字信号处理 DIT-FFT和IFFT的 C语言程序实现

    数字信号处理dit-fft和ifft的c语言实现

    fft.rar_C语言 FFT_fft_fft c语言_fft.c

    标题"fft.rar_C语言 FFT_fft_fft c语言_fft.c"明确指出这是一个关于快速傅里叶变换(FFT)的C语言实现。FFT是一种在数字信号处理领域广泛应用的算法,它能够高效地计算离散傅里叶变换(DFT)。"fft.c"是C语言源代码文件...

    FFT算法C语言实现

    自己编写的,能够实现任意点数的FFT运算的函数 结果和用MATLAB计算结果一样

    FFT.rar_C语言FFT_FFT 128点_c语言 fft_fft_fft的C语言实现

    标题中的"FFT.rar"指的是一个压缩包文件,其中包含了关于快速傅里叶变换(Fast Fourier Transform,简称FFT)的C语言实现。FFT是一种高效的算法,用于计算离散傅里叶变换(Discrete Fourier Transform,DFT),在...

    实数FFT算法的设计及其C语言实现

    实数FFT算法的设计及其C语言实现 本资源摘要信息旨在介绍实数FFT算法的设计和C语言实现,通过对算法的推导和C语言函数的实现,旨在为读者提供一个实用的解决方案,能够直接应用于自己的系统中。 一、实数FFT算法的...

    C语言实现FFT变换

    标题中的"C语言实现FFT变换"指的是使用C编程语言来实现快速傅里叶变换(Fast Fourier Transform,简称FFT),这是一种在数字信号处理领域中广泛应用的算法,用于高效地计算离散傅里叶变换(DFT)及其逆变换。FFT能够...

    fft.rar_C语言 FFT_c语言 fft_fft c++_fft c语言_fft_ifft

    标题中的"fft.rar"指的是一个使用C语言实现快速傅里叶变换(FFT)的代码库,其中包含了C语言版本的FFT以及逆快速傅里叶变换(IFFT)。这个压缩包可能是一个开发项目或者学习资源,提供了详细的注释,便于理解和应用。 ...

Global site tag (gtag.js) - Google Analytics