找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2941|回复: 0
打印 上一主题 下一主题
收起左侧

本人所做的一些有关FFT的实验STM32源码

[复制链接]
跳转到指定楼层
楼主
ID:299814 发表于 2018-3-31 11:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本人所做的一些有关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)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表