OpenEdv-开源电子网

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

求助,做FFT只有第一次计算结果正确,后面的结果越来越大

[复制链接]

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
发表于 2016-10-20 13:06:37 | 显示全部楼层 |阅读模式
1金钱
我的程序在C编译器上都很正常,但是移植到STM32上会出现问题。具体情况如下:
C编译器执行FFT程序很正常,结果也都正确;但是移植到STM32循环执行FFT,就只有复位后第一次的计算结果是正确的,后面的数据都是越来越大,我排查程序发现其中两条语句屏蔽掉后就不会出现计算结果越来越大的情况,但是这两条语句中也没出现数据没清零的情况。

最佳答案

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

这个问题解决了,还是程序的问题:计算过程中,我将得到的相位放在了需补数组中,造成后面循环中的虚部部位零
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-20 13:06:38 | 显示全部楼层
这个问题解决了,还是程序的问题:计算过程中,我将得到的相位放在了需补数组中,造成后面循环中的虚部部位零
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-20 13:18:06 | 显示全部楼层
[mw_shl_code=c,true]void data_count( float re[64][12],float DATA_OUT[5][6])   
{
                                                                       
  
     #define pi 3.1415926
     #define n 64
     #define m 6
     #define Ntab 4
     unsigned int i,j,k,p,q,s,x,a;
    // u8 a=0;
     float tr,ti,vr,vi,rms,wr,wi;

for (a=0;a<1;a++)
//----------------------------------------------------------------------------------------------------
{

                                 i=n;
                                 for (j=0;j<n;j++)
                         {
                                 p=j;
                                 q=0;
                                 for (i=0;i<m;i++)
                                 {
                                         k=(p>>1);
                                         q=(q<<1)+(p-(k<<1));
                                         p=k;
                                 }
                                 if (q>j)
                                 {
                                         vr=re[j][a];
                                         re[j][a]=re[q][a];  
                                         re[q][a]=vr;
                                         vi=im[j][a];         
                                         im[j][a]=im[q][a];   
                                         im[q][a]=vi;
                                 }
                         }
       


                //----------------------------------?????????----------------------------------------------
                 for (i=0;i<m;i++)
                         {
                                 p=(1<<(i+1));
                                 q=(p>>1);
                                 for (j=0;j<q;j++)
                                 {       
                                         x=(1<<(m-i-1))*j*Ntab;
                                         vr=costab[x];
                                         vi=sintab[x];
                                         for (k=j;k<n;k+=p)
                                         {
                                                 s=k+q;
                                                 tr=re[a]*vr-im[a]*vi;
                                                 ti=re[a]*vi+im[a]*vr;
                                               
                                                 wr=re[k][a]-tr;
                                                 re[a]=wr;
               
                                                 wi=im[k][a]-ti;
                                                   im[a]=wi;
                                                 
//-------------------------------------------------------------------------------------                                       
                                    wr=re[k][a]+tr;
                                    re[k][a]=wr;
                                                              //这四行代码屏蔽掉就不出现结果越来越大的情况
                                    wi=im[k][a]+ti;
                                    im[k][a]=wi;            

//--------------------------------------------------------------------------------------                                                 
                                         }
                                 }
                         }
}[/mw_shl_code]
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-20 13:20:17 | 显示全部楼层
二楼是代码,麻烦哪位可以帮忙看一下,找找原因
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2016-10-20 14:21:54 | 显示全部楼层
太难了
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-20 15:41:24 | 显示全部楼层
刚刚一直运行发现,到后面会变成一个固定数值左右变化的情况,但是C编译器运行输出一直都是固定的值
回复

使用道具 举报

0

主题

183

帖子

0

精华

高级会员

Rank: 4

积分
684
金钱
684
注册时间
2016-1-27
在线时间
184 小时
发表于 2016-10-20 15:51:48 | 显示全部楼层
cao651474007 发表于 2016-10-20 15:41
刚刚一直运行发现,到后面会变成一个固定数值左右变化的情况,但是C编译器运行输出一直都是固定的值

单步调试
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-20 16:35:55 | 显示全部楼层

试了单步调试,但是循环嵌套太多,单步调后面自己就乱了
回复

使用道具 举报

44

主题

298

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
209
金钱
209
注册时间
2016-9-9
在线时间
84 小时
发表于 2016-10-20 17:41:58 | 显示全部楼层
请问你用FFT来做什么了?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-10-20 20:30:35 | 显示全部楼层
是不是你的数据数据发生了变化?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-22 16:17:24 | 显示全部楼层
dreamARM 发表于 2016-10-20 17:41
请问你用FFT来做什么了?

计算电压电流、谐波分析,算功率因数
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-10-22 16:18:52 | 显示全部楼层
正点原子 发表于 2016-10-20 20:30
是不是你的数据数据发生了变化?

应该不会的啊,我调试的时候,只要调用FFT,就都对序列循环赋同样的值。关键是C编译完全没问题啊
回复

使用道具 举报

44

主题

298

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
209
金钱
209
注册时间
2016-9-9
在线时间
84 小时
发表于 2016-10-22 16:20:38 | 显示全部楼层
cao651474007 发表于 2016-10-22 16:17
计算电压电流、谐波分析,算功率因数

谐波分析?   算功率普通的功率因数计算公式不行吗?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-10-22 19:21:25 | 显示全部楼层
cao651474007 发表于 2016-10-22 16:18
应该不会的啊,我调试的时候,只要调用FFT,就都对序列循环赋同样的值。关键是C编译完全没问题啊

将你所有的数据打印出来,分析原始数据的变化。

会比较麻烦,但是是可靠的办法。我就这么干过。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2016-11-25
在线时间
37 小时
发表于 2016-12-12 20:42:42 | 显示全部楼层
下次计算前  是不是要清零 输出数组?
回复

使用道具 举报

10

主题

56

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
323
金钱
323
注册时间
2016-10-20
在线时间
110 小时
 楼主| 发表于 2016-12-13 10:34:20 | 显示全部楼层
Mylittledonkey 发表于 2016-12-12 20:42
下次计算前  是不是要清零 输出数组?

嗯  ,就是这样吧 ,我要输出的数据放在了虚部数组里,影响了下次的计算
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-26 11:07

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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