ti 的FFT 算法库,里面有PDF的理论基础,和算法库,很齐全,很有参考价值.

源代码在线查看: fftrd.c

软件大小: 763 K
上传用户: futianxiang0419
关键词: FFT 算法库 ti
下载地址: 免注册下载 普通下载 VIP

相关代码

				/* ==============================================================================
				
				System Name:    Real FFT - Software Test Bench (STB)
				
				File Name:      FFTRD.C
				
				Description:    Primary System file for demonstrating the Real FFT module
				
				Originator:     Advanced Embeeded Control (AEC) - Texas Instruments
				
				Target dependency:  x28x
				
				Description:
				============
				
				*/
				
				
				#include 
				#include 
				
				/* Create an instance of Signal generator module    */
				SGENTI_1 sgen = SGENTI_1_DEFAULTS;
				
				/* Create an instance of DATALOG Module             */
				DLOG_4CH dlog=DLOG_4CH_DEFAULTS;      
				    
				/* Create an Instance of FFT module                 */
				#define     TWO_N   512 
				#pragma DATA_SECTION(ipcb, "FFTipcb");
				#pragma DATA_SECTION(mag, "FFTmag");
				
				RFFT32  fft=RFFT32_512P_DEFAULTS;     
				long ipcb[TWO_N+2];
				long mag[TWO_N/2+1];  
				
				/* Define window Co-efficient Array  and place the
				.constant section in ROM memory				*/
				const long win[TWO_N/2]=HAMMING512;   
				
				/* Create an instance of FFTRACQ module             */
				RFFT32_ACQ  acq=FFTRACQ_DEFAULTS;     
				    
				int xn,yn;
				void main()
				{    
				
				/* DATALOG module initialisation                    */        
				       dlog.iptr1=&xn;
				       dlog.iptr2=&yn;
				       dlog.trig_value=0x800;
				       dlog.size=0x400;         /* Can log 1024 Samples                      */
				       dlog.init(&dlog);
				
				/* Signal Generator module initialisation           */ 
				       sgen.offset=0;
				       sgen.gain=0x7fff;        /* gain=1 in Q15                              */
				       sgen.freq=10000;         /* freq = (Required Freq/Max Freq)*2^15       */
				                                /*      = (931/3051.7)*2^15 = 10000           */         
				       sgen.step_max=10000;     /* Max Freq= (step_max * sampling freq)/65536 */
				                                /* Max Freq = (10000*20k)/65536 = 3051.7      */
				
				/* Initialize acquisition module                    */
				        acq.buffptr=ipcb;
				        acq.tempptr=ipcb;
				        acq.size=TWO_N;
				        acq.count=TWO_N;
				        acq.acqflag=1;
				
				/* Initialize FFT module                            */
				        fft.ipcbptr=ipcb;
				        fft.magptr=mag;  
				        fft.winptr=(long *)win;
				        fft.init(&fft);  
				
				/*---------------------------------------------------------------------------
				    Nothing running in the background at present           
				----------------------------------------------------------------------------*/
				
				        while(1) 
				        {
				            sgen.calc(&sgen);
				            xn=sgen.out;
				            yn=sgen.out;
				            dlog.update(&dlog);
				
				            acq.input=((unsigned long)xn)				            acq.update(&acq);   
				
				            if (acq.acqflag==0)     // If the samples are acquired      
				            {   
				                RFFT32_brev(ipcb,ipcb,TWO_N);
				                RFFT32_brev(ipcb,ipcb,TWO_N);  // Input samples in Real Part
				
				                fft.win(&fft); 
				                RFFT32_brev(ipcb,ipcb,TWO_N);
				                RFFT32_brev(ipcb,ipcb,TWO_N);  // Input after windowing 
				    
				                fft.calc(&fft);
				                fft.split(&fft);
				                fft.mag(&fft); 
				                acq.acqflag=1;      // Enable the next acquisition          
				            }
				
				        }       
				
				} /* End: main() */
				
				             
				
				
							

相关资源