OpenEdv-开源电子网

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

stm32上跑FFT 耗时50ms正常么

[复制链接]

10

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2013-6-20
在线时间
0 小时
发表于 2014-5-19 21:58:16 | 显示全部楼层 |阅读模式
5金钱

做的是512点的 不是us级的么 怎么我测出来都快50ms了,频率和幅值算得还算正常,难道要用库,求使用库做FFT的例程

void test (void) 
{
 u16 i=0;

  for(i=0;i<512;i++)
  {
   x11.real=(ADCDataTab[i+fft_j])*1.0;
   x11.img=0;
   x22.real=0;
   x22.img=0;  
  }

  FFT1();
}
int FFT1(void)
{
 complex c;
 x1=x11;
 x2=x22; 
 //蝶形运算
 for(kk=0;kk<power;kk++)
 {
  for(jj=0;jj<(1<<kk);jj++)
  {
   bfsize=1<<(power-kk);
   for(ii=0;ii<bfsize/2;ii++)
   { 
    pp=jj*bfsize;
    x2[ii+pp].real=x1[ii+pp].real+x1[ii+pp+bfsize/2].real;
    x2[ii+pp].img=x1[ii+pp].img+x1[ii+pp+bfsize/2].img;
    c.real=x1[ii+pp].real-x1[ii+pp+bfsize/2].real;
    c.img =x1[ii+pp].img-x1[ii+pp+bfsize/2].img;
    x2[ii+pp+bfsize/2].real=c.real*W[ii*(1<<kk)].real-c.img*W[ii*(1<<kk)].img;
    x2[ii+pp+bfsize/2].img =c.real*W[ii*(1<<kk)].img+c.img*W[ii*(1<<kk)].real;
   }
  }
  x=x1;
  x1=x2;
  x2=x;
 }
 for(jj=0;jj<count;jj++)
 {
  pp=0;
  for(ii=0;ii<power;ii++)
  {
   if (jj&(1<<ii)) pp+=1<<(power-ii-1);
  }
  x2[jj]=x1[pp];
 }
    for (ii=0;ii<256;ii++)
 {
  mag[ii]=sqrt(x2[ii].real*x2[ii].real+x2[ii].img*x2[ii].img);
  //mag[ii+128]=atan2(x2[ii].real,x2[ii].img)*180/pi;
 }
 return ii;
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

53

主题

608

帖子

0

精华

高级会员

Rank: 4

积分
890
金钱
890
注册时间
2013-3-29
在线时间
18 小时
发表于 2014-5-19 22:15:21 | 显示全部楼层
学电子,学音乐!!
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-5-19 23:31:28 | 显示全部楼层
代码要优化...
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

10

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2013-6-20
在线时间
0 小时
 楼主| 发表于 2014-5-21 09:16:23 | 显示全部楼层
回复【2楼】XINSI:
---------------------------------
103VET6
回复

使用道具 举报

10

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2013-6-20
在线时间
0 小时
 楼主| 发表于 2014-5-21 15:12:53 | 显示全部楼层
回复【3楼】正点原子:
---------------------------------
我用了库,256点还是ms,5ms

void  dsp_asm_init()
{
  u16 i=0;
  for(i=0;i<NPT;i++)
  {
lBUFIN = ((s16)ADCDataTab[i+fft_j])<<16 ; //转存DMA的AD采集
  }
}
void dsp_asm_powerMag(void)
{
  s16 lX,lY;
  u32 i;
  for(i=0;i<NPT/2;i++)
  {
    lX  = (lBUFOUT ><< 16) >> 16;
    lY  = (lBUFOUT >> 16);
    {
    float X    = NPT * ((float)lX) /32768;
    float Y    = NPT * ((float)lY) /32768;
    float Mag = sqrt(X*X + Y*Y)/NPT;
    lBUFMAG    = (u32)(Mag * 65536);
    }
  }
}

/*
*********************************************************************************************************
*   Test FFT,calculate powermag
*   进行FFT变换,并计算各次谐波幅值
*********************************************************************************************************
*/
void  dsp_asm_test()
{
// 根据预定义选择合适的FFT函数
#ifdef NPT_64
  cr4_fft_64_stm32(lBUFOUT, lBUFIN, NPT);
#endif

#ifdef NPT_256
  cr4_fft_256_stm32(lBUFOUT, lBUFIN, NPT);
#endif

#ifdef NPT_1024
  cr4_fft_1024_stm32(lBUFOUT, lBUFIN, NPT);
#endif

  // 计算幅值
  dsp_asm_powerMag();

}
主函数
  while(1)
  {  
 
PD8_H;
delay_ms(5);
PD8_L;

dsp_asm_init();
dsp_asm_test();
PD8_H;
delay_ms(10); 
PD8_L;
delay_ms(10);
}
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-5-21 22:26:42 | 显示全部楼层
回复【5楼】fqxwyf:
---------------------------------
快很多了...
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

25

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
429
金钱
429
注册时间
2019-5-15
在线时间
52 小时
发表于 2020-9-24 17:22:50 | 显示全部楼层
我用STM32F407VG ,跑4096点的FFT,用的DSP的函数,怎么耗时要4.9秒呢,哪位大神可以解释一下吗?
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-16 18:22

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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