OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6577|回复: 7

stm32f103 fft变换有老哥懂吗,求助求助!!!

[复制链接]

1

主题

3

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2018-9-25
在线时间
1 小时
发表于 2018-9-25 10:11:31 | 显示全部楼层 |阅读模式
1金钱
在网上看到了@依旧淡然的博客,有关用dsp库进行fft的,写得很好,但是不知道为什么我运算出来的结果跟博主的完全不一样的,还很奇怪
下面附上我的程序以及运算结果,希望有大神可以帮我解答一下
#include "led.h"
#include "delay.h"
#include "key.h"
#include "sys.h"
#include "lcd.h"
#include "usart.h"
#include "stm32_dsp.h"
#include "table_fft.h"
#include "stm32f10x.h"
#include "math.h"
unsigned long lBufOutArray[300];
unsigned long lBufInArray[300];
unsigned short int lBufMagArray[300];
float X[300],Y[300],Mag[300];
unsigned int NPT=256;
/******************************************************************
函数名称:InitBufInArray()
函数功能:模拟采样数据,采样数据中包含3种频率正弦波(350Hz,8400Hz,18725Hz)
参数说明:
备    注:在lBufInArray数组中,每个数据的高16位存储采样数据的实部,
          低16位存储采样数据的虚部(总是为0)
*******************************************************************/
void InitBufInArray()
{
  unsigned short i;
    float fx;
  int Fs;
  Fs=44800;
    for(i=0; i<NPT; i++)
    {
        fx = 1500 * sin(6.28318530717959* i * 350.0 / Fs) +2700 * sin(6.28318530717959* i * 8400.0 / Fs) +4000 * sin(6.28318530717959* i * 18725.0 / Fs);
   lBufInArray[i] = ((signed short)fx) << 16;
    }
}
/******************************************************************
函数名称:dsp_fft()
函数功能:调用DSP库函数进行FFT
参数说明:其中,参数pssOUT表示FFT输出数组指针,参数pssIN表示要进行FFT运算的输入数组指针,参数Nbin表示了点数。
备    注:lBufOutArray中每个元素的数据格式为;高16位存储虚部,低16位存储实部。
*******************************************************************/
void dsp_fft()
{
cr4_fft_256_stm32(&lBufOutArray, &lBufInArray, NPT);
}
/******************************************************************
函数名称:GetPowerMag()
函数功能:计算各次谐波幅值
参数说明:
备  注:先将lBufOutArray分解成实部(X)和虚部(Y),然后计算幅值(sqrt(X*X+Y*Y)
*******************************************************************/
void GetPowerMag()
{
  signed short lX,lY;
    unsigned short i;
    for(i=0; i<NPT/2; i++)
    {
        lX  = (lBufOutArray[i] << 16) >> 16;
        lY  = (lBufOutArray[i] >> 16);
        X[i]= NPT * ((float)lX) / 32768;
        Y[i]= NPT * ((float)lY) / 32768;
  Mag[i]=sqrt(X[i]* X[i]+ Y[i]* Y[i]) / NPT;
        if(i == 0)
            lBufMagArray[i] = (unsigned long)(Mag[i] * 32768);
        else
            lBufMagArray[i] = (unsigned long)(Mag[i] * 65536);
    }
}
/******************************************************************
函数名称:int main()
函数功能:将lBufMagArray数组中各次谐波的幅值(即各个频率分量的幅值)输出打印出来
参数说明:
备  注:
*******************************************************************/
int main(void)
{
int a;
int i[130],p[130];
delay_init();       //延时函数初始化   
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);  //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
uart_init(115200);   //串口初始化为115200

InitBufInArray();
cr4_fft_256_stm32(&lBufOutArray[0], &lBufInArray[0], NPT);
GetPowerMag();
  

  
  for(a=0;a<=127;a=a+1)
{
  i[a]=a;
}
for(a=0;a<=127;a=a+1)
{
  p[a]=a*175;
}

printf("\ti,\t\tp,\tmag,\t\tx,\t\ty\r\n");
for(a=0;a<=127;a++)
{
  printf("%12d,%12d,%12.7d,%12.7d,%12.7d\r\n",i[a],p[a],Mag[a],X[a],Y[a]);
}

while(1)
{   
// printf("i\tp\tmag\tx\ty\n");
// printf("\r\n");
// for(a=0;a<=127;a++)
// {
//  printf("%12d,%12d,%12d,%12d,%12d",i[a],p[a],Mag[a],X[a],Y[a]);
//  printf("\r\n");
// }
}
}




cba1e3f40dd3e310a53ff87b896ac7d.png
027178b880d716e99287aaf96e399be.png
a01e004db601f15a1cbb6a9f400d047.png

最佳答案

查看完整内容[请看2#楼]

没看过原作是怎么, 但这结果是正常的啊 如果说楼主想看到想要的结果, 你就把8400Hz 改为8960Hz, 18725Hz就别看了, 它太接近极限勉强也会损失精度
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

1907

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4105
金钱
4105
注册时间
2018-8-14
在线时间
696 小时
发表于 2018-9-25 10:11:32 | 显示全部楼层
没看过原作是怎么, 但这结果是正常的啊
如果说楼主想看到想要的结果, 你就把8400Hz 改为8960Hz,  18725Hz就别看了, 它太接近极限勉强也会损失精度
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2018-9-25
在线时间
1 小时
 楼主| 发表于 2018-9-25 22:12:18 | 显示全部楼层
https://www.cnblogs.com/menlsh/p/4154070.html
附上原博客链接
希望有大佬可以帮忙解决一下,感激不尽
回复

使用道具 举报

15

主题

866

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7371
金钱
7371
注册时间
2016-11-30
在线时间
632 小时
发表于 2018-9-26 11:04:06 | 显示全部楼层
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2018-9-25
在线时间
1 小时
 楼主| 发表于 2018-9-26 17:07:04 | 显示全部楼层
嘿嘿,完美解决
回复

使用道具 举报

9

主题

165

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
251
金钱
251
注册时间
2018-4-6
在线时间
31 小时
发表于 2018-9-26 21:26:25 | 显示全部楼层
膜拜,,,,
回复

使用道具 举报

2

主题

17

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2019-8-6
在线时间
28 小时
发表于 2020-2-11 18:29:48 | 显示全部楼层
怎么解决的 求教
回复

使用道具 举报

0

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
120
金钱
120
注册时间
2021-9-7
在线时间
31 小时
发表于 2022-5-8 11:41:55 | 显示全部楼层
怎么解决的 求教
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-27 07:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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