版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> DSP原理及應(yīng)用課程設(shè)計(jì)報(bào)告</p><p> ——FFT的DSP實(shí)現(xiàn)</p><p><b> 一、設(shè)計(jì)目的</b></p><p> 1、加深對(duì)DFT算法原理和基本性質(zhì)的理解;</p><p> 2、了解并學(xué)習(xí)使用FFT算法,以及其在TMS320C54X上的運(yùn)用;</p>
2、<p> 3、學(xué)習(xí)DSP中FFT的設(shè)計(jì)和編程思想;</p><p> 4、練習(xí)使用CCS的探針和圖形工具來(lái)觀察器觀察波形和頻譜情況。</p><p><b> 二、設(shè)計(jì)內(nèi)容</b></p><p> 用C語(yǔ)言及匯編語(yǔ)言進(jìn)行編程,實(shí)現(xiàn)FFT運(yùn)算,對(duì)于C語(yǔ)言,實(shí)現(xiàn)8點(diǎn)和16點(diǎn)的FFT運(yùn)算,對(duì)于匯編語(yǔ)言,需調(diào)試出8點(diǎn)的FFT運(yùn)算結(jié)果
3、。</p><p><b> 三、設(shè)計(jì)原理</b></p><p> 快速傅里葉變換(FFT)是一種高效實(shí)現(xiàn)離散傅里葉變換(DFT)的快速算法,是數(shù)字信號(hào)處理中最為重要的工具之一,它在聲學(xué),語(yǔ)音,電信和信號(hào)處理等領(lǐng)域有著廣泛的應(yīng)用。</p><p> 1、離散傅里葉變換DFT</p><p> 對(duì)于長(zhǎng)度為N的有限
4、長(zhǎng)序列x(n),它的離散傅里葉變換(DFT)為</p><p><b> (1) </b></p><p> 式中, ,稱為旋轉(zhuǎn)因子或蝶形因子。</p><p> 從DFT的定義可以看出,在x(n)為復(fù)數(shù)序列的情況下,對(duì)某個(gè)k值,直接按(1)式計(jì)算X(k) 只需要N次復(fù)數(shù)乘法和(N-1)次復(fù)數(shù)加法。因此,對(duì)所有N個(gè)k值,共需要N2
5、次復(fù)數(shù)乘法和N(N-1)次復(fù)數(shù)加法。對(duì)于一些相當(dāng)大有N值(如1024點(diǎn))來(lái)說(shuō),直接計(jì)算它的DFT所需要的計(jì)算量是很大的,因此DFT運(yùn)算的應(yīng)用受到了很大的限制。</p><p> 2、快速傅里葉變換FFT</p><p> 旋轉(zhuǎn)因子WN 有如下的特性:</p><p><b> 對(duì)稱性: </b></p><p&g
6、t;<b> 周期性:</b></p><p> 利用這些特性,既可以使DFT中有些項(xiàng)合并,減少了乘法積項(xiàng),又可以將長(zhǎng)序列的DFT分解成幾個(gè)短序列的DFT。FFT就是利用了旋轉(zhuǎn)因子的對(duì)稱性和周期性來(lái)減少運(yùn)算量的。</p><p> FFT的算法是將長(zhǎng)序列的DFT分解成短序列的DFT。例如:N為偶數(shù)時(shí),先將N點(diǎn)的DFT分解為兩個(gè)N/2點(diǎn)的DFT,使復(fù)數(shù)乘法減少一半
7、:再將每個(gè)N/2點(diǎn)的DFT分解成N/4點(diǎn)的DFT,使復(fù)數(shù)乘又減少一半,繼續(xù)進(jìn)行分解可以大大減少計(jì)算量。最小變換的點(diǎn)數(shù)稱為基數(shù),對(duì)于基數(shù)為2的FFT算法,它的最小變換是2點(diǎn)DFT。</p><p> 一般而言,F(xiàn)FT算法分為按時(shí)間抽取的FFT(DIT FFT)和按頻率抽取的FFT(DIF FFT)兩大類(lèi)。DIF FFT算法是在時(shí)域內(nèi)將每一級(jí)輸入序列依次按奇/偶分成2個(gè)短序列進(jìn)行計(jì)算,而DIF FFT算法是在頻域內(nèi)
8、將每一級(jí)輸入序列依次奇/偶分成2個(gè)短序列進(jìn)行計(jì)算。兩者的區(qū)別是旋轉(zhuǎn)因子出現(xiàn)的位置不同,但算法是一樣的。在DIF FFT算法中,旋轉(zhuǎn)因子出現(xiàn)在輸入端,而在DIF FFT算法中它出現(xiàn)在輸入端。</p><p> 假定序列x(n)的點(diǎn)數(shù)N是2的冪,按照DIF FFT算法可將其分為偶序列和奇序列,記偶序列為 ,奇序列為,則x(n)的FFT表示為</p><p> 由于 ,則(3)式可表示為&l
9、t;/p><p> 式中, 和分別為和的N/2的DFT。</p><p><b> 由于對(duì)稱性,</b></p><p> 則。因此,N點(diǎn)可分為兩部分:</p><p> 前半部分: (4)</p><p> 后半部分: (5)</p><p>
10、; 從式(4)和式(5)可以看出,只要求出0~N/2-1區(qū)間和的值,就可求出0~N-1區(qū)間的N點(diǎn)值。</p><p> 以同樣的方式進(jìn)行抽取,可以求得N/4點(diǎn)的DFT,重復(fù)抽取過(guò)程,就可以使N點(diǎn)的DFT用上組2點(diǎn)的 DFT來(lái)計(jì)算,這樣就可以大減少運(yùn)算量。</p><p> 在基數(shù)為2的FFT中,設(shè)N=2M,共有M級(jí)運(yùn)算,每級(jí)有N/2個(gè)2點(diǎn)FFT蝶形運(yùn)算,因此,N點(diǎn)FFT總共有MN/2
11、個(gè)蝶形運(yùn)算。蝶形運(yùn)算如圖1所示。</p><p><b> 圖1 蝶形運(yùn)算</b></p><p> 設(shè)蝶形輸入為和,輸出為和,則有</p><p><b> ?。?)</b></p><p><b> ?。?)</b></p><p> 在基數(shù)為
12、2的FFT中,設(shè)N=2M,共有M級(jí)運(yùn)算,每級(jí)有N/2個(gè)2點(diǎn)FFT蝶形運(yùn)算,因此,N點(diǎn)FFT總共有個(gè)蝶形運(yùn)算。</p><p> 例如:基數(shù)為2的FFT,當(dāng)N=8時(shí),共需要3級(jí),12個(gè)基2 DIT FFT的蝶形運(yùn)算。其信號(hào)流程如圖2所示。</p><p> 圖2 8點(diǎn)基2 DIF FFT蝶形運(yùn)算</p><p> 從圖2可以看出,輸入是經(jīng)過(guò)比特反轉(zhuǎn)的倒位序列,稱
13、為位碼倒置,其排列順序?yàn)?。輸出是按自然順序排列,其順序?yàn)椤?lt;/p><p> 3、FFT運(yùn)算的實(shí)現(xiàn)</p><p> ?。?)實(shí)現(xiàn)輸入數(shù)據(jù)的比特反轉(zhuǎn)</p><p> 輸入數(shù)據(jù)的比特反轉(zhuǎn)實(shí)際上就是將輸入數(shù)據(jù)進(jìn)行碼位倒置,以便在整個(gè)運(yùn)算后輸出序列是一個(gè)自然序列。在用匯編指令進(jìn)行碼位倒置時(shí),使用位碼倒置尋址可以大大提高程序執(zhí)行速度和使用存儲(chǔ)器的效率。在這種尋址方式下
14、,AR0存放的整數(shù)N的FFT點(diǎn)的一半,一個(gè)輔助寄存器指向一個(gè)數(shù)據(jù)存放單元。當(dāng)使用位碼倒置尋址將AR0加到輔助寄存器時(shí),地址將以位碼倒置的方式產(chǎn)生。</p><p> ?。?)實(shí)現(xiàn)N點(diǎn)復(fù)數(shù)FFT</p><p> N點(diǎn)復(fù)數(shù)FFT算法的實(shí)現(xiàn)可分為三個(gè)功能塊,即第一級(jí)蝶形運(yùn)算、第二級(jí)蝶形運(yùn)算、第三級(jí)至log2N級(jí)蝶形運(yùn)算。隊(duì)以任何一個(gè)2的整數(shù)冪N=2^M,總可以通過(guò)M次分解后最后成為二點(diǎn)的DF
15、T運(yùn)算。通過(guò)這樣的M次分解,可以構(gòu)成M級(jí)迭代計(jì)算,每級(jí)由N/2個(gè)蝶形運(yùn)算完成。</p><p> ?。?)輸出FFT結(jié)果</p><p> FFT算法的程序流程圖如下圖所示。</p><p> 圖3 FFT運(yùn)算的程序流程圖</p><p> 四、基于C語(yǔ)言的FFT算法</p><p> 1、源程序FFT.c&l
16、t;/p><p> #include "myapp.h"</p><p> #include "ICETEK-VC5509-EDU.h"</p><p> #include "scancode.h"</p><p> #include <math.h></p&g
17、t;<p> #define PI 3.1415926</p><p> #define SAMPLENUMBER 16</p><p> void MakeWave();</p><p> int INPUT[SAMPLENUMBER];</p><p> struct compx{float real,imag;}
18、; </p><p> struct compx EE(struct compx,struct compx); </p><p> struct compx xin[SAMPLENUMBER];</p><p> struct compx fWave[SAMPLENUMBER];</p><p> float y[
19、SAMPLENUMBER],data[SAMPLENUMBER];</p><p> struct compx EE(struct compx b1,struct compx b2)</p><p><b> {</b></p><p> struct compx b3;</p><p> b3.real=b1.
20、real*b2.real-b1.imag*b2.imag; b3.imag=b1.real*b2.imag+b1.imag*b2.real; </p><p> return(b3);</p><p><b> }</b></p><p><b> main()</b></p>
21、<p><b> {</b></p><p><b> int i;</b></p><p> MakeWave();</p><p> for ( i=0;i<SAMPLENUMBER;i++ )</p><p><b> {</b></
22、p><p> fWave[i].real=INPUT[i];</p><p> fWave[i].imag=0.0f;</p><p> y[i]=0.0f;</p><p><b> }</b></p><p> FFT(fWave);</p><p> for
23、 ( i=0;i<SAMPLENUMBER;i++ )</p><p><b> {</b></p><p> data[i]=y[i];</p><p><b> }</b></p><p> while ( 1 );// break point</p><p&
24、gt;<b> }</b></p><p> void FFT(struct compx *xin)</p><p><b> {</b></p><p> int f,m,nv2,nm1,i,k,j=0,l;</p><p> struct compx v,w,t; <
25、;/p><p> nv2=SAMPLENUMBER/2; </p><p> f=SAMPLENUMBER;</p><p> for(m=1;(f=f/2)!=1;m++){;} </p><p> nm1=SAMPLENUMBER-1;</p><p> for(i=0;i<n
26、m1;i++) </p><p><b> {</b></p><p><b> if(i<j)</b></p><p><b> {</b></p><p><b> t=xin[j];</b></p><p&
27、gt; xin[j]=xin[i];</p><p><b> xin[i]=t;</b></p><p><b> } </b></p><p><b> k=nv2;</b></p><p> while(k<=j)</p><p&g
28、t;<b> {</b></p><p><b> j=j-k;</b></p><p><b> k=k/2;</b></p><p><b> }</b></p><p><b> j=j+k;</b></p>
29、;<p><b> }</b></p><p> {int le,lei,ip;</p><p> for(l=1;l<=m;l++) </p><p><b> {</b></p><p> le=2<<(l-1); </p><p
30、><b> lei=le/2;</b></p><p> v.real=1.0;v.imag =0.0; </p><p> w.real =cos(PI/lei);</p><p> w.imag =-sin(PI/lei); </p><p> for(j=0;j<=lei-1;j++)
31、 </p><p><b> {</b></p><p> for(i=j;i<=SAMPLENUMBER;i=i+le) </p><p><b> {</b></p><p><b> ip=i+lei;</b></p><p&g
32、t; t=EE(xin[ip],v);</p><p> xin[ip].real=xin[i].real-t.real; </p><p> xin[ip].imag =xin[i].imag-t.imag; </p><p> xin[i].real=xin[i].real+t.real;</p><p> xin[i].im
33、ag=xin[i].imag+t.imag;</p><p><b> }</b></p><p> v=EE(v,w); </p><p><b> }</b></p><p>
34、;<b> }</b></p><p><b> }</b></p><p> for ( i=0;i<SAMPLENUMBER;i++ )</p><p><b> { </b></p><p> y[i]=sqrt(xin[i].real*xin[i].re
35、al+xin[i].imag*xin[i].imag);</p><p><b> }</b></p><p><b> }</b></p><p> void MakeWave()</p><p><b> {</b></p><p><
36、b> int i;</b></p><p> for ( i=0;i<SAMPLENUMBER;i++ )</p><p><b> {</b></p><p> INPUT[i]=i+1;</p><p><b> }</b></p><p&g
37、t;<b> }</b></p><p> 2、鏈接命令文件ICETEK-VC5509-A.cmd</p><p><b> -w</b></p><p> -stack 500</p><p> -sysstack 500</p><p> -l rts55x.
38、lib</p><p><b> MEMORY </b></p><p><b> {</b></p><p> DARAM:o=0x100,l=0x7f00</p><p> VECT : o=0x8000,l=0x100</p><p> DARAM2:
39、 o=0x8100,l=0x7f00</p><p> SARAM: o=0x10000,l=0x30000</p><p> SDRAM:o=0x40000,l=0x3e0000</p><p><b> }</b></p><p><b> SECTIONS</b></p
40、><p><b> {</b></p><p> .text: {} > DARAM </p><p> .vectors: {} > VECT </p><p> .trcinit: {} > DARAM </p><p> .gblinit: {} > DA
41、RAM </p><p> frt: {} > DARAM </p><p> .cinit: {} > DARAM </p><p> .pinit: {} > DARAM </p><p> .sysinit: {} > DARAM </p><p> .bss:
42、 {} > DARAM2 </p><p> .far: {} > DARAM2 </p><p> .const: {} > DARAM2 </p><p> .switch: {} > DARAM2 </p><p> .sysmem: {} > DARAM2 </p>
43、;<p> .cio: {} > DARAM2 </p><p> .MEM$obj: {} > DARAM2 </p><p> .sysheap: {} > DARAM2 </p><p> .sysstack {} > DARAM2 </p><p> .stack: {} &
44、gt; DARAM2 </p><p><b> }</b></p><p> 3、FFT程序的使用方法</p><p> ?。?)根據(jù)N值,修改FFT.c中的中的常數(shù),如N=8,將#define SAMPLENUMBER 16語(yǔ)句中的“16”修改為8。</p><p> ?。?)編譯、匯編、鏈接,得到.out文件,
45、加載。</p><p> ?。?)將data加入觀察窗,可看到FFT運(yùn)算輸出結(jié)果。</p><p><b> 4、運(yùn)行結(jié)果</b></p><p> 8點(diǎn)的FFT運(yùn)算,且輸入為1、2、3、…、8時(shí),運(yùn)算結(jié)果如圖4所示,16點(diǎn)的FFT運(yùn)算,且輸入為1、2、3、…、16時(shí),運(yùn)算結(jié)果如圖5所示。</p><p> 圖4
46、8點(diǎn)FFT運(yùn)算結(jié)果</p><p> 圖5 16點(diǎn)FFT運(yùn)算結(jié)果</p><p> 五、基于匯編語(yǔ)言的FFT算法</p><p> 1、匯編源程序fft.asm </p><p> .title "fft.asm"</p><p><b> .mmregs</
47、b></p><p> .include "coeff.inc"</p><p> .include "in.inc"</p><p> .def start</p><p> sine: .usect "
48、;sine",512</p><p> sine1: .usect "sine1",512</p><p> cosine: .usect "cosine",512</p><p> cosine1: .usect
49、 "cosine1",512</p><p> fft_data: .usect "fft_data",1024</p><p> fft_out: .usect "fft_out",512 </p><p> ST
50、ACK .usect "STACK",10</p><p> K_DATA_IDX_1 .set 2</p><p> K_DATA_IDX_2 .set 4</p><p> K_DATA_IDX_3 .set 8</p><p> K_TWID
51、_TBL_SIZE .set 512</p><p> K_TWID_IDX_3 .set 128</p><p> K_FLY_COUNT_3 .set 4</p><p> K_FFT_SIZE .set 8 </p><p> K_
52、LOGN .set 3 </p><p> PA0 .set 0</p><p> .bss d_twid_idx,1</p><p> .bss d_data_idx,1</p><p>
53、 .bss d_grps_cnt,1</p><p> .sect "fft_prg"</p><p> ********************位碼倒置程序**************************</p><p> .asg AR2,REORDERED
54、 </p><p> .asg AR3,ORIGINAL_INPUT </p><p> .asg AR7,DATA_PROC_BUF </p><p> start: SSBX FRCT </p>
55、<p> STM #STACK+10,SP</p><p> STM #sine,AR1 </p><p> RPT #K_TWID_TBL_SIZE-1</p><p> MVPD #sine1,*AR1+</p><p&g
56、t; STM cosine,AR1 </p><p> RPT #K_TWID_TBL_SIZE-1</p><p> MVPD #cosine1,*AR1+</p><p> STM #d_input,ORIGINAL_INPUT </p>
57、<p> STM #fft_data,DATA_PROC_BUF </p><p> MVMM DATA_PROC_BUF,REORDERED </p><p> STM #K_FFT_SIZE-1,BRC </p><p> RPTBD bit_re
58、v_end-1 </p><p> STM #K_FFT_SIZE,AR0</p><p> MVDD *ORIGINAL_INPUT+,*REORDERED+ </p><p> MVDD *ORIGINAL_INPUT-,*REORDERED+</p><p&g
59、t; MAR *ORIGINAL_INPUT+0B </p><p> bit_rev_end:</p><p> *********************FFT CODE*********************************</p><p> .asg AR1,GROUP_COUNTER
60、 </p><p> .asg AR2,PX </p><p> .asg AR3,QX </p><p> .asg AR4,WR </p>&l
61、t;p> .asg AR5,WI </p><p> .asg AR6,BUTTERFLY_COUNTER </p><p> .asg AR7,STAGE_COUNTER </p><p> *****************
62、**第一級(jí)蝶形運(yùn)算stage1************************</p><p> STM #0,BK </p><p> LD #-1,ASM </p><p> STM #fft_data,PX <
63、/p><p> STM #fft_data+K_DATA_IDX_1,QX </p><p> STM K_FFT_SIZE/2-1,BRC</p><p> LD *PX,16,A </p><p> RPTBD stage1end-
64、1 </p><p> STM #K_DATA_IDX_1+1,AR0 </p><p> SUB *QX,16,A,B </p><p> ADD *QX,16,A </p&g
65、t;<p> STH A,ASM,*PX+ </p><p> ST B,*QX+ </p><p> ||LD *PX,A </p><p> SUB
66、 *QX,16,A,B </p><p> ADD *QX,16,A </p><p> STH A,ASM,*PX+0% </p><p> ST B,*QX+0%
67、 2</p><p> ||LD *PX,A </p><p> stage1end:</p><p> ******************第二級(jí)蝶形運(yùn)算stage2***************************</p><p> STM
68、 #fft_data,PX </p><p> STM #fft_data+K_DATA_IDX_2,QX </p><p> STM #K_FFT_SIZE/4-1,BRC</p><p> LD *PX,16,A &
69、lt;/p><p> RPTBD stage2end-1</p><p> STM #K_DATA_IDX_2+1,AR0</p><p> ;1st butterfly</p><p> SUB *QX,16,A,B </p><p
70、> ADD *QX,16,A </p><p> STH A,ASM,*PX+ </p><p> ST B,*QX+ </p><p> ||LD *PX,A
71、 </p><p> SUB *QX,16,A,B </p><p> ADD *QX,16,A </p><p> STH A,ASM,*PX+ </
72、p><p> STH B,ASM,*QX+ </p><p> ;2nd butterfly</p><p> MAR *QX+</p><p> ADD *PX,*QX,A </p><p&g
73、t; SUB *PX,*QX-,B </p><p> STH A,ASM,*PX+ </p><p> SUB *PX,*QX,A </p><p> ST B,*QX
74、 </p><p> ||LD *QX+,B </p><p> ST A,*PX </p><p> ||ADD *PX+0%,A <
75、/p><p> ST A,*QX+0% </p><p> ||LD *PX,A </p><p> stage2end:</p><p> ********************第三級(jí)至最后一級(jí)蝶形運(yùn)算******
76、******************</p><p> STM #K_TWID_TBL_SIZE,BK </p><p> ST #K_TWID_IDX_3,d_twid_idx </p><p> STM #K_TWID_IDX_3,AR0 </p&
77、gt;<p> STM #cosine,WR </p><p> STM #sine,WI </p><p> STM #K_LOGN-2-1,STAGE_COUNTER </p><p> ST
78、 #K_FFT_SIZE/8-1,d_grps_cnt </p><p> STM #K_FLY_COUNT_3-1,BUTTERFLY_COUNTER </p><p> ST #K_DATA_IDX_3,d_data_idx </p><p><b> stage:</b></p
79、><p> STM #fft_data,PX </p><p> LD d_data_idx,A</p><p> ADD *(PX),A</p><p> STLM A,QX </p>
80、;<p> MVDK d_grps_cnt,GROUP_COUNTER </p><p><b> group:</b></p><p> MVMD BUTTERFLY_COUNTER,BRC </p><p> RPTBD butterflyend-1&l
81、t;/p><p> LD *WR,T</p><p> MPY *QX+,A </p><p> MAC *WI+0%,*QX-,A </p><p> ADD *PX,16,A,B </p><p&
82、gt; ST B,*PX </p><p> ||SUB *PX+,B </p><p> ST B,*QX </p><p> ||MPY *QX+,A </p><p> MAS
83、 *QX,*WR+0%,A </p><p> ADD *PX,16,A,B </p><p> ST B,*QX+ </p><p> ||SUB *PX,B </p><p> LD
84、*WR,T </p><p> ST B,*PX+ </p><p> ||MPY *QX+,A </p><p> butterflyend:</p><p> PSHM AR0 </p>&l
85、t;p> MVDK d_data_idx,AR0</p><p> MAR *PX+0 </p><p> MAR *QX+0 </p><p> BANZD group,*GROUP_COUNTER-</
86、p><p> POPM AR0 </p><p> MAR *QX-</p><p> LD d_data_idx,A</p><p> SUB #1,A,B </p><p> STLM
87、 B,BUTTERFLY_COUNTER </p><p> STL A,1,d_data_idx </p><p> LD d_grps_cnt,A </p><p> STL A,ASM,d_grps_cnt </p>&
88、lt;p> LD d_twid_idx,A</p><p> STL A,ASM,d_twid_idx </p><p> BANZD stage,*STAGE_COUNTER-</p><p> MVDK d_twid_idx,AR0 </p>&
89、lt;p><b> fft_end:</b></p><p> ***********************計(jì)算功率譜</p><p> STM #fft_data,AR2</p><p> ; STM #fft_data,AR3</p><
90、p> STM #fft_out,AR4</p><p> STM #K_FFT_SIZE*2-1,BRC</p><p> RPTB power_end-1</p><p> SQUR *AR2+,A </p><p> S
91、QURA *AR2+,A </p><p> STH A,*AR4+</p><p> power_end:</p><p> STM #fft_out,AR4</p><p> RPT #K_FFT_SIZE-1</p&
92、gt;<p> PORTW *AR4+,PA0</p><p><b> NOP</b></p><p><b> NOP</b></p><p> here: B here</p><p><b> .e
93、nd</b></p><p> 2、鏈接命令文件fft.cmd</p><p> vector.obj</p><p> rfft_task.obj</p><p> -o rfft_task.obj</p><p> -m rfft_task.map</p><p>
94、-e rfft_task</p><p><b> MEMORY</b></p><p><b> {</b></p><p><b> PAGE0:</b></p><p> EPROM: org=0E000H len=1000H</p>&l
95、t;p> VECS: org=0FF80H len=0080H</p><p><b> PAGE1:</b></p><p> SPRAM: org=0060H len=0020H</p><p> DARAM: org=0400H len=0600H</p><p>
96、RAM: org=8000H len=1400H</p><p><b> }</b></p><p><b> SECTIONS </b></p><p><b> {</b></p><p> sine1 : > EPROM
97、 PAGE0</p><p> cosine1 : > EPROM PAGE0</p><p> fft_prg : > EPROM PAGE0</p><p> .bss : > SPRAM
98、 PAGE1</p><p> sine : align(512){}>DARAM PAGE1</p><p> cosine : align(512){}>DARAM PAGE1</p><p> d_input : > RAM
99、 PAGE1</p><p> fft_data : > RAM PAGE1</p><p> fft_out : > RAM PAGE1</p><p> STACK : > SPRAM
100、 PAGE1</p><p> .vectors : > VECS PAGE0</p><p><b> }</b></p><p> 3、FFT程序的使用方法</p><p> (1)根據(jù)N值,修改rfft_task.asm中的兩個(gè)常數(shù),如N=64.<
101、;/p><p> K_FFT_SIZE .set 64</p><p> K_LOGN .set 6</p><p> (2)準(zhǔn)備輸入數(shù)據(jù)文件in.dat。輸入數(shù)據(jù)按實(shí)部、虛部,實(shí)部、虛部,……順序存放。</p><p> ?。?)匯編、鏈接、仿真執(zhí)行,得到輸出數(shù)據(jù)文件out.dat。&l
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- dsp課程設(shè)計(jì)fft的dsp實(shí)現(xiàn)
- 基于dsp的fft實(shí)現(xiàn)設(shè)計(jì)報(bào)告
- dsp課程設(shè)計(jì)報(bào)告(fir濾波器的dsp實(shí)現(xiàn))
- fft的dsp實(shí)現(xiàn)
- dsp課程設(shè)計(jì)報(bào)告
- dsp課程設(shè)計(jì)---基于dsp的bios模塊設(shè)計(jì)實(shí)現(xiàn)
- dsp課程設(shè)計(jì)報(bào)告
- 基于dsp的fft實(shí)現(xiàn)
- dsp課程設(shè)計(jì)報(bào)告--dsp芯片應(yīng)用系統(tǒng)設(shè)計(jì)
- 利用dsp實(shí)現(xiàn)自適應(yīng)濾波dsp課程設(shè)計(jì)
- 基于dsp的fft實(shí)現(xiàn)3
- dsp課程設(shè)計(jì)---dsp芯片簡(jiǎn)介
- 基于dsp的fft設(shè)計(jì)
- 基于dsp的fft的實(shí)現(xiàn)
- 基于dsp的fft實(shí)現(xiàn)2
- dsp課程設(shè)計(jì)--dsp原理及應(yīng)用實(shí)驗(yàn)報(bào)告
- 現(xiàn)代信號(hào)通信課程設(shè)計(jì)---dft的快速算法分析及fft的dsp實(shí)現(xiàn)
- 基于dsp的圖像處理-dsp課程設(shè)計(jì)
- dsp課程設(shè)計(jì)
- dsp課程設(shè)計(jì)---基于dsp的實(shí)時(shí)fir濾波器的實(shí)現(xiàn)
評(píng)論
0/150
提交評(píng)論