sunsundsp 发表于 2013-8-12 10:13

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

没看懂帮忙顶

sunsundsp 发表于 2013-8-12 13:08

zhangmangui 发表于 2013-8-12 12:21 static/image/common/back.gif
没看懂帮忙顶

是没看懂程序 还是没看懂我的意思?

zhangmangui 发表于 2013-8-12 13:48

sunsundsp 发表于 2013-8-12 13:08 static/image/common/back.gif
是没看懂程序 还是没看懂我的意思?

程序没看懂

XMUAC 发表于 2013-8-13 08:50

可以看看是不是存储空间不够。

sunsundsp 发表于 2013-8-13 09:10

XMUAC 发表于 2013-8-13 08:50 static/image/common/back.gif
可以看看是不是存储空间不够。

这个是在哪里看呢?

diyudeshuidi 发表于 2013-8-13 09:34

你放这段代码没用啊,不会是人家代码的问题。。。你是没采到256的点还是说采了256个点但是传输没成功。。。

sunsundsp 发表于 2013-8-13 10:20

diyudeshuidi 发表于 2013-8-13 09:34 static/image/common/back.gif
你放这段代码没用啊,不会是人家代码的问题。。。你是没采到256的点还是说采了256个点但是传输没成功。。。 ...

没有采到126个点 我看ad的结果寄存器中就没有采到值。恩 程序应该是木有问题
页: [1]
查看完整版本: fft数据处理如何才能到1024个数??2048个?