fft数据处理如何才能到1024个数??2048个?
我用的是这个程序 刚开始我是设置128个数,能够对数据进行处理但是我改成 256个数之后 程序就不采集数了下面这个程序是 fft程序。。
// 函数名: 快速傅立叶变换(来源《C常用算法集》)
// 本函数测试OK,可以在TC2.0,VC++6.0,Keil C51测试通过。
// 如果你的MCS51系统有足够的RAM时,可以验证一下用单片机处理FFT有多么的慢。
//
// 入口参数:
// l: l = 0, 傅立叶变换; l = 1, 逆傅立叶变换
// il: il = 0,不计算傅立叶变换或逆变换模和幅角;il = 1,计算模和幅角
// n: 输入的点数,为偶数,一般为32,64,128,...,1024等
// k: 满足n=2^k(k>0),实质上k是n个采样数据可以分解为偶次幂和奇次幂的次数
// pr[]: l=0时,存放N点采样数据的实部
// l=1时, 存放傅立叶变换的N个实部
// pi[]: l=0时,存放N点采样数据的虚部
// l=1时, 存放傅立叶变换的N个虚部
//
// 出口参数:
// fr[]: l=0, 返回傅立叶变换的实部
// l=1, 返回逆傅立叶变换的实部
// fi[]: l=0, 返回傅立叶变换的虚部
// l=1, 返回逆傅立叶变换的虚部
// pr[]: il = 1,i = 0 时,返回傅立叶变换的模
// il = 1,i = 1 时,返回逆傅立叶变换的模
// pi[]: il = 1,i = 0 时,返回傅立叶变换的辐角
// il = 1,i = 1 时,返回逆傅立叶变换的辐角
// data: 2005.8.15,Mend Xin Dong
#include "DSP281x_Device.h"
#include "example_nonBIOS.h"
#include"math.h"
#include"fft1.h"
float wr,wi;
void FFT(float pr, float pi, float fr, float fi, int l, int il)
{
int it,m,is,i,j,nv,l0;
double p,q,s,vr,vi,poddr,poddi;
for (it=0; it<=ADSample-1; it++)
{
m = it;
is = 0;
for(i=0; i<=K-1; i++)
{
j = m/2;
is = 2*is+(m-2*j);
m = j;
}
fr = pr;
fi = pi;
}
//----------------------------
pr = 1.0;
pi = 0.0;
p = 6.283185306/(1.0*ADSample);
pr = cos(p);
pi = -sin(p);
if (l!=0)
pi=-pi;
for (i=2; i<=ADSample-1; i++)
{
p = pr*pr;
q = pi*pi;
s = (pr+pi)*(pr+pi);
pr = p-q;
pi = s-p-q;
}
for (it=0; it<=ADSample-2; it=it+2)
{
vr = fr;
vi = fi;
fr = vr+fr;
fi = vi+fi;
fr = vr-fr;
fi = vi-fi;
}
m = ADSample/2;
nv = 2;
for (l0=K-2; l0>=0; l0--)
{
m = m/2;
nv = 2*nv;
for(it=0; it<=(m-1)*nv; it=it+nv)
for (j=0; j<=(nv/2)-1; j++)
{
p = pr*fr;
q = pi*fi;
s = pr+pi;
s = s*(fr+fi);
poddr = p-q;
poddi = s-p-q;
fr = fr-poddr;
fi = fi-poddi;
fr = fr+poddr;
fi = fi+poddi;
}
}
if(il!=0)
{
for(i=0; i<=ADSample-1; i++)
{
wr = sqrt(fr*fr+fi*fi);
if(fabs(fr)<0.000001*fabs(fi))
{
if ((fi*fr)>0)
pi = 90.0;
else
pi = -90.0;
}
else
wi = atan(fi/fr)*360.0/6.283185306;
}
}
pr = 0;
return;
}
没看懂帮忙顶 zhangmangui 发表于 2013-8-12 12:21 static/image/common/back.gif
没看懂帮忙顶
是没看懂程序 还是没看懂我的意思? sunsundsp 发表于 2013-8-12 13:08 static/image/common/back.gif
是没看懂程序 还是没看懂我的意思?
程序没看懂 可以看看是不是存储空间不够。 XMUAC 发表于 2013-8-13 08:50 static/image/common/back.gif
可以看看是不是存储空间不够。
这个是在哪里看呢? 你放这段代码没用啊,不会是人家代码的问题。。。你是没采到256的点还是说采了256个点但是传输没成功。。。 diyudeshuidi 发表于 2013-8-13 09:34 static/image/common/back.gif
你放这段代码没用啊,不会是人家代码的问题。。。你是没采到256的点还是说采了256个点但是传输没成功。。。 ...
没有采到126个点 我看ad的结果寄存器中就没有采到值。恩 程序应该是木有问题
页:
[1]