标题: 本人所做的一些有关FFT的实验STM32源码 [打印本页]

作者: zhuyun    时间: 2018-3-31 11:02
标题: 本人所做的一些有关FFT的实验STM32源码
本人所做的一些有关FFT的实验

单片机源程序如下:
  1. #include "fft.h"
  2. #include "math.h"


  3. u32 lBufInArray[NPT];
  4. u32 lBufOutArray[NPT];
  5. u32 lBufMagArray[NPT];
  6. float PI2=6.28318530717959;
  7. u32 Fs=192000;
  8. /******************************************************************
  9. 函数名称:InitBufInArray()
  10. 函数功能:模拟采样数据,采样数据中包含3种频率正弦波
  11. 参数说明:
  12. 备    注:在lBufInArray数组中,每个数据的高16位存储采样数据的实部,
  13.           低16位存储采样数据的虚部(总是为0)
  14. *******************************************************************/
  15. void InitBufInArray(void)
  16. {
  17.     unsigned short i;
  18.     float fx;
  19.     for(i=0; i<NPT; i++)
  20.     {
  21.         fx = 1000 * sin(PI2 * i * 1000.0 / Fs) +
  22.              3000 * sin(PI2 * i * 3000.0 / Fs) +
  23.              4000 * sin(PI2 * i * 5000.0 / Fs);
  24.         lBufInArray[i] = ((signed short)fx) << 16;
  25.     }
  26. }
  27. /******************************************************************
  28. 函数名称:GetPowerMag()
  29. 函数功能:计算各次谐波幅值
  30. 参数说明:
  31. 备  注:先将lBufOutArray分解成实部(X)和虚部(Y),然后计算幅值(sqrt(X*X+Y*Y)
  32. *******************************************************************/
  33. void GetPowerMag(void)
  34. {
  35.     signed short lX,lY;
  36.     float X,Y,Mag;
  37.     unsigned short i;
  38.     for(i=0; i<NPT/2; i++)
  39.     {
  40.         lX  = (lBufOutArray[i] << 16) >> 16;
  41.         lY  = (lBufOutArray[i] >> 16);
  42.         X = NPT * ((float)lX) / 32768;
  43.         Y = NPT * ((float)lY) / 32768;
  44.         Mag = sqrt(X * X + Y * Y) / NPT;
  45.         if(i == 0)
  46.             lBufMagArray[i] = (unsigned long)(Mag * 32768);
  47.         else
  48.             lBufMagArray[i] = (unsigned long)(Mag * 65536);
  49.     }
  50. }

复制代码

所有资料51hei提供下载:
FFT.rar (414.22 KB, 下载次数: 47)







欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1