专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
求助,做FFT只有第一次计算结果正确,后面的结果越来越大
2019-10-16 02:26
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
7282
15
1506
我的程序在C编译器上都很正常,但是移植到STM32上会出现问题。具体情况如下:
C编译器执行FFT程序很正常,结果也都正确;但是移植到STM32循环执行FFT,就只有复位后第一次的计算结果是正确的,后面的数据都是越来越大,我排查程序发现其中两条语句屏蔽掉后就不会出现计算结果越来越大的情况,但是这两条语句中也没出现数据没清零的情况。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
15条回答
cao651474007
1楼-- · 2019-10-16 05:15
精彩回答 2 元偷偷看……
加载中...
cao651474007
2楼-- · 2019-10-16 05:22
[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]
加载中...
cao651474007
3楼-- · 2019-10-16 10:26
二楼是代码,麻烦哪位可以帮忙看一下,找找原因
加载中...
shikihane
4楼-- · 2019-10-16 10:43
太难了
加载中...
cao651474007
5楼-- · 2019-10-16 11:07
刚刚一直运行发现,到后面会变成一个固定数值左右变化的情况,但是C编译器运行输出一直都是固定的值
加载中...
不吃鱼的老鼠
6楼-- · 2019-10-16 11:51
精彩回答 2 元偷偷看……
加载中...
1
2
3
下一页
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
{
#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]
一周热门 更多>