搜索
bottom↓
回复: 76

MSP430 FFT算法

  [复制链接]

出0入0汤圆

发表于 2010-12-23 16:36:01 | 显示全部楼层 |阅读模式
/*****************main   programe********************/
#include  <msp430x14x.h>

#include       <math.h>     
#include       <stdio.h>     
#include       <stdlib.h>     
#include      "typedef.h "
      

float       result[8];   
struct     compx   s[8];      
int       Num=8;
const   float   pp=3.141592653589793;

extern void FFT(struct   compx *s,int num);


double mpr[8],mpi[8],mfr[8],mfi[8];
int n,k,l,il;
extern void kbfft();
extern void FFT_dingdian();
main()
{

    //   ????
    int   i;
    FILE   *fin,*fout;
    if((fin=fopen( "indata.txt ", "r "))==NULL)
    {  
        printf( "can 't   open   infile ");
        exit(0);
    };
    for(i=0;i <Num;i++)
    {   
        //fscanf(fin, "%lf ",&s.real);
        s.real=cos(2*3.1415926*(30)*(i)/80.0);//
        s.imag=(double)0;
        mpr=s.real;
        mpi=0;        
        
    };
    fclose(fin);
    //////////////
      
    //FFT(s,Num);
   
    //n=8;k=3;l=0;il=0;
    //kbfft(mpr,mpi,n,k,mfr,mfi,l,il);

   
    FFT_dingdian();
      
    //????
    if((fout=fopen( "fftresult.txt ", "w "))==NULL)
    {
        printf( "can 't   open   outfile ");
        exit(0);
    };
   
    for(i=0;i <Num;i++)
    {
        // result=sqrt(pow(s.real,2)+pow(s.imag,2));
        fprintf(fout, "%lf+(%lf)i   ",s.real,s.imag);
    };
   
    fclose(fout);

}

出0入0汤圆

 楼主| 发表于 2010-12-23 16:37:15 | 显示全部楼层
//---定点---
#include  <msp430x14x.h>
#include "math.h"
#define NN 8
//************************余弦表**********************************
const  float  COS_tab[91]=
                  {1.0000,0.9998,0.9993,0.9986,0.9975,0.9962,0.9945,0.9925,0.9903,
                   0.9877,0.9848,0.9816,0.9781,0.9744,0.9703,0.9659,0.9614,0.9563,
                   0.9511,0.9455,0.9397,0.9336,0.9272,0.9205,0.9135,0.9063,0.8988,
                   0.8910,0.8829,0.8746,0.8660,0.8572,0.8480,0.8387,0.8290,0.8192,
                   0.8090,0.7986,0.7880,0.7771,0.7760,0.7547,0.7431,0.7314,0.7193,
                   0.7071,0.6947,0.6820,0.6691,0.6561,0.6428,0.6293,0.6157,0.6018,
                   0.5878,0.5736,0.5592,0.5446,0.5299,0.5150,0.5000,0.4848,0.4695,
                   0.4540,0.4384,0.4226,0.4067,0.3907,0.3746,0.3584,0.3420,0.3256,
                   0.3090,0.2924,0.2757,0.2588,0.2419,0.2250,0.2079,0.1908,0.1736,
                   0.1564,0.1392,0.1219,0.1045,0.0872,0.0698,0.0523,0.0349,0.0174,
                   0.0000};

char Re(char M,char k)
{
  char m=1;
  int n;
  while(M>0){m=m*2;M--;}//m==pow(2,M)
  n=360 * k /m;
  return n;
  
}

void FFT_dingdian( void )
{
    signed char flag1=1,flag2=1;
    char  i,j,k,R,I;
    char p,p1;
    //float i5,i6,i7,i8;   
    char   M,L;
    int    a,b,x=1,y=1,z=1;
    int    N1;
   
    struct comp
    {
      float re;
      float im;
    }aa[NN]={{1,0},{0,0},{-1,0},{0,0},{1,0},{0,0},{-1,0},{0,0}};//,{9,0},{10,0},
             //{11,0},{12,0},{13,0},{14,0},{15,0},{16,0}};//
   
    struct comp bb,bb1,bb2;
   

    L=0;
    N1=NN;
    while(N1>0)
    {N1=N1/2;L++;}// L=log(NN)/log(2);
    L=L-1;
   
   //输入变址
   for(i=0,j=0;i<NN;i++)
    {
      if(i>=j){k=NN/2;}
      else
      {
        k=NN/2;
        bb=aa;
        aa=aa[j];
        aa[j]=bb;
        
      }
      while(k<=j){j=j-k;k=k/2;
                  if(k==j)break;}
      
       j=j+k;  
    }  
  //变址结束
   

   
  //由下开始FFT计算     
   
    for(M=1;M<=L;M++)
    {
         x=M-1;
         a=1;
         while(x>0){a=a*2;x--;}//a==2的M-1次方
      for(k=0;k<a;k++)//a==2的M-1次方,即每一级有2的M-1次方个不同的旋转因子,步进值是1
                                      //---同时也是蝶形结两结点间距
        {
             y=M;
             b=1;
             while(y>0){b=b*2;y--;}//b==2的M次方
             //p=0;
          for(p=k;p<NN-1;p=p+b)//b==2的M次方----相同旋转因子的蝶形结间距
              {
               
               
               p1=p+a;//a==2的M-1次方
               
               R=Re(M,k);//----------------------=360*k/(2^M)--k最大为2^M-1
               I=Re(M,k);//Re(M,k)==Im(M,k)
           
               if(R>=0&&R<=90){flag1=1;}
               else if(R>90&&R<=180){ R=180-R;flag1=-1;}
               else if(R>180&&R<=270){ R=R-180;flag1=-1;}
               else if(R>270&&R<=360){ R=360-R;flag1=1;}
               
               
               if(I>=0&&I<=90){I=90-I;flag2=1;}   
               else if(I>90&&I<=180){I=I-90;flag2=1;}
               else if(I>180&&I<=270){I=270-I;flag2=-1;}
               else if(I>270&&I<=360){I=I-270;flag2=-1;}
           
              bb.re=aa[p].re;
              bb.im=aa[p].im;
              
           
              bb1.re=aa[p1].re*(flag1)*COS_tab[R];
              bb1.im=aa[p1].im*(flag2)*COS_tab[I];
              bb2.re=aa[p1].re*(flag2)*COS_tab[I];
              bb2.im=aa[p1].im*(flag1)*COS_tab[R];
           aa[p].re=bb.re+bb1.re  + bb1.im;
           aa[p].im=bb.im+bb2.im - bb2.re ;
           aa[p1].re=bb.re-bb1.re- bb1.im;
           aa[p1].im=bb.im-bb2.im + bb2.re ;
           }     
         }
      }   
   
  //FFT计算结束
   return;   
}

出0入0汤圆

发表于 2010-12-26 11:52:49 | 显示全部楼层
需要多长时间啊??

出0入0汤圆

发表于 2010-12-26 12:30:59 | 显示全部楼层
mark!!!

出0入0汤圆

发表于 2010-12-26 20:03:14 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-12-26 20:47:45 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-12-26 21:38:41 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-1-2 14:58:43 | 显示全部楼层
请问做一个FFT,430需要多长时间?
我现在在做一个水流量测速的玩意。
想用相位差法,但是不想用DSP这等高级玩意。这里看到楼主的帖子。很是兴奋!!

出0入0汤圆

发表于 2011-1-2 17:35:19 | 显示全部楼层
mark !MSP430 FFT算法.

出0入0汤圆

发表于 2011-1-3 02:15:29 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-4-14 15:26:05 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-4-14 15:51:00 | 显示全部楼层
学习了

出0入0汤圆

发表于 2011-4-14 17:04:42 | 显示全部楼层
楼主浮点运算用float?应该double更准吧。。。

出0入0汤圆

发表于 2011-4-14 18:34:50 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-4-15 21:20:34 | 显示全部楼层
MARK

出0入0汤圆

发表于 2011-4-15 22:47:00 | 显示全部楼层
标记 fft算法以后留着有用

出0入0汤圆

发表于 2011-5-4 10:19:30 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-5-7 22:25:49 | 显示全部楼层
记下,以后慢慢看

出0入0汤圆

发表于 2011-8-3 10:21:04 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-3 10:22:22 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-3 10:25:17 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-3 11:10:13 | 显示全部楼层
FFT
算法

出0入0汤圆

发表于 2011-8-5 11:08:56 | 显示全部楼层
学习。。。

出0入0汤圆

发表于 2011-8-7 15:31:11 | 显示全部楼层
马克一下

出0入0汤圆

发表于 2011-8-15 09:53:33 | 显示全部楼层
早看到这个就好了,实训的时候可以方便很多

出0入0汤圆

发表于 2011-8-19 00:27:54 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-20 15:07:43 | 显示全部楼层
这可是好东西。MARK~~

出0入0汤圆

发表于 2011-9-13 17:20:24 | 显示全部楼层
回复【12楼】lileistone 三块石头
-----------------------------------------------------------------------

430要避免DOUBLE运算,费时。8M的速度还是有点不快不慢的。。。

出0入0汤圆

发表于 2011-9-15 07:33:45 | 显示全部楼层
mark,看到很多程序都用这个,了解下

出0入0汤圆

发表于 2011-10-16 14:02:39 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-10-16 14:47:49 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-10-17 13:29:13 | 显示全部楼层
收藏。记住了

出0入0汤圆

发表于 2011-10-17 14:57:11 | 显示全部楼层
MARK!

出0入0汤圆

发表于 2011-11-1 19:25:03 | 显示全部楼层
感觉用整形的比较快

出0入0汤圆

发表于 2011-11-5 16:46:13 | 显示全部楼层
记得以前大学编的FFT在486/66上计算 256x256矩阵要1s
头像被屏蔽

出0入0汤圆

发表于 2012-3-8 09:04:15 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

出0入0汤圆

发表于 2012-3-9 22:27:46 | 显示全部楼层
Mark

出0入0汤圆

发表于 2012-3-10 07:06:24 | 显示全部楼层
看看

出0入0汤圆

发表于 2012-3-27 16:17:25 | 显示全部楼层
mark一記,非常感謝,很有用的東西~~~

出0入8汤圆

发表于 2012-3-29 23:09:54 | 显示全部楼层
MARK,我想知道需要多少时间,我用430,8M的晶振,做一次FIR滤波 需要20ms,32位的,不知道这个需要多久?

出0入0汤圆

发表于 2012-3-31 11:14:44 | 显示全部楼层
有时间放到我板上跑跑看。谢了。

出0入0汤圆

发表于 2012-4-13 09:35:47 | 显示全部楼层
谢谢分享,请问楼主这个算法用来多少时间?

出0入0汤圆

发表于 2012-4-13 11:03:06 | 显示全部楼层
记号记号

出0入0汤圆

发表于 2012-7-13 14:15:03 | 显示全部楼层
MSP430 FFT算法.

出0入0汤圆

发表于 2012-7-16 18:00:26 | 显示全部楼层
#include      "typedef.h "  ????
这个是什么函数????

出0入0汤圆

发表于 2012-7-17 12:47:26 | 显示全部楼层
mark

出0入0汤圆

发表于 2012-7-17 16:54:40 | 显示全部楼层
虽然 我还不知道FFT到底是什么 但是 感觉还是蛮有用的 所以感谢楼主咯 以后应该会用到~

出0入0汤圆

发表于 2012-7-29 21:00:06 | 显示全部楼层
强                 !!

出0入0汤圆

发表于 2012-7-29 23:57:39 | 显示全部楼层
dianyuan 发表于 2010-12-23 16:37
//---定点---
#include  
#include "math.h"

mark                      !!!

出0入0汤圆

发表于 2012-9-20 11:15:36 | 显示全部楼层
标记,有用

出0入0汤圆

发表于 2012-9-25 14:57:55 | 显示全部楼层

出0入0汤圆

发表于 2012-9-27 07:58:16 | 显示全部楼层
mark!!先记下

出0入0汤圆

发表于 2012-9-27 09:28:48 | 显示全部楼层
mark 一下,做个记号啊,做个记号

出0入0汤圆

发表于 2012-10-1 16:07:23 | 显示全部楼层
留着以后看~~~

出0入0汤圆

发表于 2012-11-7 20:21:58 | 显示全部楼层
额,楼主float最多7位有效数字...

出0入0汤圆

发表于 2012-11-8 12:53:21 | 显示全部楼层
cool                                          

出0入0汤圆

发表于 2012-11-30 09:20:17 | 显示全部楼层
楼主,你好!
   我现在正在研究MSP430的FF算法,我可以向您请教一下吗?1790485810,这是我的QQ。谢谢

出0入0汤圆

发表于 2012-11-30 22:49:40 | 显示全部楼层
mark !MSP430 FFT算法.

出0入0汤圆

发表于 2013-1-21 11:53:19 | 显示全部楼层
mark,mark,

出0入0汤圆

发表于 2014-8-2 20:20:44 | 显示全部楼层
mark

出0入0汤圆

发表于 2014-8-2 20:21:48 | 显示全部楼层
mark

出0入0汤圆

发表于 2014-8-22 17:51:32 | 显示全部楼层
mark...................

出0入0汤圆

发表于 2014-9-12 12:40:26 来自手机 | 显示全部楼层
不错,支持!

出0入0汤圆

发表于 2014-9-12 13:10:12 | 显示全部楼层
我现在正在研究MSP430的FF算法,我可以向您请教一下

出0入0汤圆

发表于 2014-9-12 17:25:45 | 显示全部楼层
路过,学习的

出0入0汤圆

发表于 2014-11-18 14:06:03 | 显示全部楼层
MARK,谢谢分享

出0入0汤圆

发表于 2014-11-24 11:36:28 | 显示全部楼层
真差劲,居然是浮点的,改成定点还差不多

出0入0汤圆

发表于 2014-11-24 11:38:49 | 显示全部楼层
看一下!

出0入0汤圆

发表于 2015-1-31 13:08:23 | 显示全部楼层
fft算法以后留着有用

出0入0汤圆

发表于 2015-3-8 21:03:46 | 显示全部楼层
Mark!!

出0入0汤圆

发表于 2015-4-12 23:47:11 | 显示全部楼层
谢谢分享.正需要
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-20 14:08

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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