版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 畢業(yè)設(shè)計(jì)報(bào)告(論文)</p><p> 報(bào)告(論文)題目:分段卷積的MATLAB仿真 </p><p> 與DSP實(shí)現(xiàn) </p><p> 作者所在系部: 電子工程系 </p><p> 作者所在專(zhuān)業(yè): 通信 </p>
2、<p> 作者所在班級(jí): </p><p> 作 者 姓 名 : </p><p> 作 者 學(xué) 號(hào) : </p><p> 指導(dǎo)教師姓名: </p><p> 完 成 時(shí) 間 : 2012年
3、6月15日 </p><p> 畢業(yè)設(shè)計(jì)(論文)任務(wù)書(shū)(理工類(lèi))</p><p><b> 北華航天工業(yè)學(xué)院</b></p><p> 本科生畢業(yè)設(shè)計(jì)(論文)原創(chuàng)性及知識(shí)產(chǎn)權(quán)聲明</p><p> 是本人在指導(dǎo)教師的指導(dǎo)下,獨(dú)立進(jìn)行研究工作取得的成果。除文中已經(jīng)注明引用的內(nèi)容外,本設(shè)計(jì)(論文)不含任何其
4、他個(gè)人或集體已經(jīng)發(fā)表或撰寫(xiě)過(guò)的作品或成果。對(duì)本設(shè)計(jì)(論文)的研究做出重要貢獻(xiàn)的個(gè)人和集體,均已在文中以明確方式標(biāo)明。因本畢業(yè)設(shè)計(jì)(論文)引起的法律結(jié)果完全由本人承擔(dān)。</p><p> 本畢業(yè)設(shè)計(jì)(論文)成果歸北華航天工業(yè)學(xué)院所有。本人遵循北華航天工業(yè)學(xué)院有關(guān)畢業(yè)設(shè)計(jì)(論文)的相關(guān)規(guī)定,提交畢業(yè)設(shè)計(jì)(論文)的印刷本和電子版本。本人同意北華航天工業(yè)學(xué)院有權(quán)保存畢業(yè)設(shè)計(jì)(論文)的印刷本和電子版,并提供目錄檢索與閱覽
5、服務(wù);可以采用影印、縮印、數(shù)字化或其它復(fù)制手段保存論文;在不以營(yíng)利為目的的前提下,可以公布非涉密畢業(yè)設(shè)計(jì)(論文)的部分或全部?jī)?nèi)容。</p><p><b> 特此聲明</b></p><p> 畢業(yè)設(shè)計(jì)(論文)作者: 指導(dǎo)教師: </p><p> 年 月 日
6、年 月 日</p><p><b> 摘 要</b></p><p> 常用的線性卷積方法要求兩個(gè)輸入序列的持續(xù)時(shí)間相同,但在實(shí)際工程中經(jīng)常會(huì)遇到某個(gè)輸入序列具有較長(zhǎng)持續(xù)時(shí)間的情況,從而無(wú)法達(dá)到信號(hào)實(shí)時(shí)處理的要求。在這種情況下,分段卷積是一種有效的解決方案。本論文設(shè)計(jì)了分段卷積的快速算法模塊,分段卷積又可以用兩種方法實(shí)現(xiàn),即重疊相加法和重疊保留法。每
7、種方法先對(duì)輸入序列進(jìn)行分段,再將各段進(jìn)行快速傅里葉變換,接著進(jìn)行傅里葉逆變換得到各段輸出,將輸出結(jié)果進(jìn)行處理就得到了最終結(jié)果。</p><p> 在DSP中采用流水線結(jié)構(gòu)進(jìn)行實(shí)時(shí)處理。經(jīng)檢驗(yàn)該方法正確且能很好地滿(mǎn)足對(duì)信號(hào)進(jìn)行實(shí)時(shí)處理的要求。</p><p> 關(guān)鍵詞 分段卷積 重疊相加法 重疊保留法 快速傅里葉變換</p><p><b&
8、gt; Abstract</b></p><p> Duration of the linear convolution method requires two input sequences, but in practical engineering often encounter an input sequence has a longer duration, thus unable to s
9、ignal real-time processing requirements. In this case, piecewise convolution is an effective solution. Designed a segmented fast convolution algorithm module, piecewise convolution of two ways, ie, overlap-add method and
10、 overlap save method. Each method first segment of the input sequence, then the paragraphs fast Fourier tr</p><p> Key words partition convolution overlap- add method overlap- save method FFT</p>
11、;<p><b> 目 錄</b></p><p><b> 第1章 緒論1</b></p><p> 1.1 課題背景及國(guó)內(nèi)外研究概況1</p><p> 1.2 MATLAB軟件概述1</p><p> 1.2.1 MATLAB軟件介紹1</p>
12、;<p> 1.2.2 MATLAB軟件應(yīng)用2</p><p> 1.3 DSP技術(shù)介紹及應(yīng)用2</p><p> 1.4 課題的建立以及本文完成的主要工作2</p><p> 第2章 分段卷積技術(shù)4</p><p> 2.1 利用FFT計(jì)算線性卷積原理及步驟4</p><p>
13、2.2 重疊相加法原理及流程圖4</p><p> 2.2.1 重疊相加法算法原理4</p><p> 2.2.2 流程圖5</p><p> 2.3 重疊保留法原理及流程圖6</p><p> 2.3.1 原理6</p><p> 2.3.2 流程圖8</p><p>&
14、lt;b> 2.4 小結(jié)8</b></p><p> 第3章 MATLAB仿真10</p><p> 3.1 重疊相加法10</p><p> 3.2 重疊保留法10</p><p> 3.3 操作步驟11</p><p> 3.4 程序源代碼及結(jié)果分析15</p>
15、;<p><b> 3.5 小結(jié)20</b></p><p> 第4章 CCS軟件概況21</p><p> 4.1 CCS軟件簡(jiǎn)介21</p><p> 4.1.1 軟件概況22</p><p> 4.1.2 CCS軟件的使用22</p><p> 4.2
16、程序源代碼24</p><p><b> 4.3 小結(jié)27</b></p><p> 第5章 課題特點(diǎn)28</p><p> 5.1 MATLAB仿真和DSP實(shí)現(xiàn)28</p><p> 5.2 采用時(shí)域卷積和FFT變換兩種方案28</p><p> 5.3 C語(yǔ)言和匯編語(yǔ)言混
17、合編程28</p><p> 第6章 結(jié)論29</p><p><b> 致 謝30</b></p><p><b> 參考文獻(xiàn)31</b></p><p><b> 附錄32</b></p><p> 分段卷積的MATLAB
18、仿真與DSP實(shí)現(xiàn)</p><p><b> 第1章 緒論</b></p><p> 1.1 課題背景及國(guó)內(nèi)外研究概況</p><p> 由于 Matlab 具有計(jì)算快速準(zhǔn)確和使用方便等優(yōu)點(diǎn),已經(jīng)逐漸成為數(shù)字信號(hào)處理(DSP)應(yīng)用中分析和設(shè)計(jì)的主要仿真工具。常用的線性卷積方法要求兩個(gè)輸入序列的持續(xù)時(shí)間相同, 但在實(shí)際工程中經(jīng)常會(huì)遇到某個(gè)輸
19、入序列具有較長(zhǎng)持續(xù)時(shí)間的情況,理論上可以將整個(gè)波形存儲(chǔ)起來(lái),利用快速線性卷積方法進(jìn)行處理。但是利用快速線性卷積變換存在以下問(wèn)題:(1)需要對(duì)那個(gè)短序列補(bǔ)充很多零點(diǎn),從而導(dǎo)致計(jì)算量和需要的存儲(chǔ)空間無(wú)謂的增加;(2)需要獲得所有的輸入序列,并完全進(jìn)行處理后,輸出序列才是有效的,因此整個(gè)系統(tǒng)必然存在較大的延時(shí),不能符合實(shí)時(shí)處理的要求;(3)實(shí)際上,當(dāng)兩個(gè)序列長(zhǎng)度差距較大時(shí),快速卷積的優(yōu)勢(shì)并不能體現(xiàn)出來(lái),從而無(wú)法達(dá)到信號(hào)實(shí)時(shí)處理的要求。在這種情
20、況下,分段卷積是一種有效的解決方案。</p><p> 分段卷積快速算法模塊,在DSP中采用流水線結(jié)構(gòu)進(jìn)行實(shí)時(shí)處理,經(jīng)檢驗(yàn)該方法正確且能很好地滿(mǎn)足對(duì)信號(hào)進(jìn)行實(shí)時(shí)處理的要求。</p><p> 1.2 MATLAB軟件概述</p><p> 1.2.1 MATLAB軟件介紹</p><p> MATLAB是由美國(guó)mathworks公司發(fā)
21、布的主要面對(duì)科學(xué)計(jì)算、可視化以及交互式程序設(shè)計(jì)的高科技計(jì)算環(huán)境。它將數(shù)值分析、矩陣計(jì)算、科學(xué)數(shù)據(jù)可視化以及非線性動(dòng)態(tài)系統(tǒng)的建模和仿真等諸多強(qiáng)大功能集成在一個(gè)易于使用的視窗環(huán)境中,為科學(xué)研究、工程設(shè)計(jì)以及必須進(jìn)行有效數(shù)值計(jì)算的眾多科學(xué)領(lǐng)域提供了一種全面的解決方案,并在很大程度上擺脫了傳統(tǒng)非交互式程序設(shè)計(jì)語(yǔ)言(如C、Fortran)的編輯模式,代表了當(dāng)今國(guó)際科學(xué)計(jì)算軟件的先進(jìn)水平。</p><p> Matlab和
22、Mathematica、Maple并稱(chēng)為三大數(shù)學(xué)軟件。它在數(shù)學(xué)類(lèi)科技應(yīng)用軟件中在數(shù)值計(jì)算方面首屈一指。MATLAB可以進(jìn)行矩陣運(yùn)算、繪制函數(shù)和數(shù)據(jù)、實(shí)現(xiàn)算法、創(chuàng)建用戶(hù)界面、連接MATLAB開(kāi)發(fā)工作界面、連接其他編程語(yǔ)言的程序等,主要應(yīng)用于工程計(jì)算、控制設(shè)計(jì)、信號(hào)處理與通訊、圖像處理、信號(hào)檢測(cè)、金融建模設(shè)計(jì)與分析等領(lǐng)域。</p><p> MATLAB的基本數(shù)據(jù)單位是矩陣,它的指令表達(dá)式與數(shù)學(xué)、工程中常用的形式十
23、分相似,故用MATLAB來(lái)解算問(wèn)題要比用C,F(xiàn)ORTRAN等語(yǔ)言完成相同的事情簡(jiǎn)捷得多,并且MATLAB也吸收了像Maple等軟件的優(yōu)點(diǎn),使MATLAB成為一個(gè)強(qiáng)大的數(shù)學(xué)軟件。在新的版本中也加入了對(duì)C,F(xiàn)ORTRAN,C++ ,JAVA的支持??梢灾苯诱{(diào)用,用戶(hù)也可以將自己編寫(xiě)的實(shí)用程序?qū)氲組ATLAB函數(shù)庫(kù)中方便自己以后調(diào)用,此外許多的MATLAB愛(ài)好者都編寫(xiě)了一些經(jīng)典的程序,用戶(hù)可以直接進(jìn)行下載就可以使用。</p>
24、<p> MATLAB具有以下特點(diǎn):</p><p> 1.高效的數(shù)值計(jì)算及符號(hào)計(jì)算功能,能使用戶(hù)從繁雜的數(shù)學(xué)運(yùn)算分析中解脫出來(lái);</p><p> 2.具有完備的圖形處理功能,實(shí)現(xiàn)計(jì)算結(jié)果和編程的可視化;</p><p> 3.友好的用戶(hù)界面及接近數(shù)學(xué)表達(dá)式的自然化語(yǔ)言,使學(xué)者易于學(xué)習(xí)和掌握;</p><p> 4.功能
25、豐富的應(yīng)用工具箱,為用戶(hù)提供了大量方便實(shí)用的處理工具。.</p><p> 1.2.2 MATLAB軟件應(yīng)用</p><p> MATLAB 產(chǎn)品族可以用來(lái)進(jìn)行以下各種工作: </p><p> ?。?) 數(shù)值分析 </p><p> (2)數(shù)值和符號(hào)計(jì)算 </p><p> ?。?)工程與科學(xué)繪圖
26、 </p><p> ?。?)控制系統(tǒng)的設(shè)計(jì)與仿真 </p><p> ?。?)數(shù)字圖像處理 技術(shù) </p><p> ?。?)數(shù)字信號(hào)處理 技術(shù) </p><p> ?。?)通訊系統(tǒng)設(shè)計(jì)與仿真 </p><p> ?。?)財(cái)務(wù)與金融工程 </p><p> MATLAB 的
27、應(yīng)用范圍非常廣,包括信號(hào)和圖像處理、通訊、控制系統(tǒng)設(shè)計(jì)、測(cè)試和測(cè)量、財(cái)務(wù)建模和分析以及計(jì)算生物學(xué)等眾多應(yīng)用領(lǐng)域。附加的工具箱(單獨(dú)提供的專(zhuān)用 MATLAB 函數(shù)集)擴(kuò)展了 MATLAB 環(huán)境,以解決這些應(yīng)用領(lǐng)域內(nèi)特定類(lèi)型的問(wèn)題。</p><p> 1.3 DSP技術(shù)介紹及應(yīng)用</p><p> 數(shù)字信號(hào)處理是利用計(jì)算機(jī)或?qū)S锰幚碓O(shè)備,以數(shù)字的形式對(duì)信號(hào)進(jìn)行分析、采集、合成、變換、濾波、
28、估算、壓縮、識(shí)別等加工處理,以便提取有用的信息并進(jìn)行有效的傳輸與應(yīng)用。與模擬信號(hào)處理相比,數(shù)字信號(hào)處理具有精確、靈活、抗干擾能力強(qiáng)、可靠性高、體積小、易于大規(guī)模集成等優(yōu)點(diǎn)。</p><p> DSP是一種特別適合于進(jìn)行數(shù)字信號(hào)處理運(yùn)算的微處理器,主要用于實(shí)時(shí)快速實(shí)現(xiàn)各種數(shù)字信號(hào)處理的算法。</p><p> 1.4 課題的建立以及本文完成的主要工作</p><p&g
29、t; 利用FFT實(shí)現(xiàn)線性卷積方法要求兩個(gè)輸入序列的長(zhǎng)度基本相同,但在實(shí)際工程中經(jīng)常會(huì)遇到某個(gè)輸入序列具有較長(zhǎng)持續(xù)時(shí)間的情況,而另一序列較短,理論上可以將輸入序列(長(zhǎng)序列)存儲(chǔ)起來(lái),利用快速線性卷積方法進(jìn)行處理,但無(wú)法達(dá)到信號(hào)“實(shí)時(shí)”處理的要求。在這種情況下,分段卷積是一種有效的解決方案。</p><p> 本文主要包括以下內(nèi)容:</p><p> 1.基于matlab完成分段卷積,并
30、以圖形方式演示分段卷積過(guò)程;</p><p> 2.基于DSP編程實(shí)現(xiàn)分段卷積;</p><p> 3.采用重疊相加法和重疊保留法兩種方法實(shí)現(xiàn)。</p><p> 第2章 分段卷積技術(shù)</p><p> 2.1 利用FFT計(jì)算線性卷積原理及步驟</p><p> 設(shè)輸入信號(hào)分別為x(n)和y(n),分別對(duì)其
31、進(jìn)行FFT運(yùn)算,進(jìn)而求出Y(k),利用逆FFT得到y(tǒng)(n)。計(jì)算步驟如下:</p><p> a.計(jì)算X(k)=FFT[x(n)]</p><p> b. 求H(k)=FFT[h(n)]</p><p> c. 求Y(k)=H(k)X(k) k=0~L-1</p><p> d. 求y(n)=IFFT[Y(k)]
32、 n=0~L-1</p><p> 上述結(jié)論適用于x(n)、h(n)兩序列長(zhǎng)度比較接近或相等的情況,如果x(n)、h(n)長(zhǎng)度相差較多,例如:h(n)為某濾波器的單位脈沖響應(yīng),長(zhǎng)度有限,用來(lái)處理一個(gè)很長(zhǎng)的輸入信號(hào)x(n),或者處理一個(gè)連續(xù)不斷的信號(hào),按上述方法,h(n)要補(bǔ)許多零再進(jìn)行計(jì)算,計(jì)算量有很大的浪費(fèi),或者根本不能實(shí)現(xiàn)。為了保持快速卷積法的優(yōu)越性,可將x(n)分為許多段后處理,每小段的長(zhǎng)與h(n
33、)接近,其處理方法有兩種:即重疊相加法和重疊保留法。</p><p> 2.2 重疊相加法原理及流程圖</p><p> 2.2.1 重疊相加法算法原理</p><p> 重疊相加法是將輸入序列x(n)進(jìn)行分段,每段長(zhǎng)度為N,分段的結(jié)果與h(n)(長(zhǎng)度為M)進(jìn)行卷積,且N不小于M,如圖2-1所示。</p><p> 圖2-1 重疊相
34、加法中x(n)分段圖</p><p> 將分段結(jié)果代入式(2-1):</p><p><b> (2-1)</b></p><p> 其中,的長(zhǎng)度為N+M-1,有效區(qū)間為[lN,(l+1)N+M-2]。</p><p> 為了提高運(yùn)算效率,可以用N+M-1點(diǎn)的循環(huán)卷積來(lái)完成的計(jì)算,如圖2-2所示。</p&g
35、t;<p> 圖2-2 重疊相加法中yl(n)之間關(guān)系圖</p><p><b> 2.2.2 流程圖</b></p><p> 重疊相加法流程圖如圖2-3所示。</p><p> 圖2-3 重疊相加法流程圖</p><p> 2.3 重疊保留法原理及流程圖</p><p>
36、;<b> 2.3.1 原理</b></p><p> 對(duì)序列y(n)進(jìn)行分段,每段長(zhǎng)度為N,則,分段結(jié)果如式(2-2):</p><p> 其他 (2-2) </p><p> 重疊保留法中yl(n)的分段結(jié)果如圖2-4所示,</p><p> 圖2-4 重疊保留
37、法中yl(n)分段圖</p><p> 因h(n)為因果序列且長(zhǎng)度為M,由線性卷積的物理含義可知,從點(diǎn)(lN-M+1)到點(diǎn)[(l+1)N-1]范圍內(nèi)的輸入將唯一決定序列yl(n)的取值,所以根據(jù)輸出序列y(n)的分段結(jié)果可確定輸入序列x(n)的分段方式,如式(2-3)所示,</p><p> 其他 (2-3)</p><p> 式中l(wèi)=1,2..
38、..</p><p> 重疊保留法中xl(n)各段間的關(guān)系如圖2-5所示。</p><p> 圖2-5 重疊保留法中xl(n)之間關(guān)系圖</p><p><b> 2.3.2 流程圖</b></p><p> 重疊保留法流程圖如圖2-6所示。</p><p><b> 否<
39、;/b></p><p><b> 是</b></p><p> 圖2-6 重疊保留法流程圖</p><p><b> 2.4 小結(jié)</b></p><p> 重疊相加法和重疊保留法都是應(yīng)用DFT求線性卷積的方法,之所以會(huì)改進(jìn)直接計(jì)算線性卷積的時(shí)間復(fù)雜度,就是因?yàn)镈FT的快速算法。兩種
40、算法都是對(duì)原序列進(jìn)行分組,進(jìn)行循環(huán)卷積后再組合,有相同的時(shí)間復(fù)雜度,但在執(zhí)行過(guò)程和應(yīng)用范圍上還是有一定的區(qū)別。重疊相加法是對(duì)已知的有限長(zhǎng)序列進(jìn)行分段后與系統(tǒng)序列循環(huán)卷積,組合時(shí)去掉每段后面重疊的部分;重疊保留法是通過(guò)對(duì)輸出序列進(jìn)行分段后導(dǎo)出的一種線性卷積方法,分段前對(duì)原序列前面進(jìn)行添零,分段循環(huán)卷積后將每段后面未重疊的一部分保留后組合。</p><p> 兩個(gè)程序在分段上有差異,但都是對(duì)截?cái)嗟男蛄羞M(jìn)行循環(huán)卷積,
41、因而有一定的通用性。在進(jìn)行本實(shí)驗(yàn)的編程上,最主要的是理解兩種方法實(shí)現(xiàn)的過(guò)程,在對(duì)數(shù)據(jù)處理時(shí)要注意各個(gè)數(shù)據(jù)的含義和數(shù)組的組合過(guò)程。</p><p> 在編程過(guò)程中,我曾多次遇到數(shù)據(jù)長(zhǎng)度不匹配的提醒,通常是數(shù)組長(zhǎng)度后少添了或多添了常數(shù),這種錯(cuò)誤必須比對(duì)方法的定義耐心仔細(xì)的尋找。在數(shù)組的組合上本人認(rèn)為是很有技巧的,力求明確簡(jiǎn)單,必須經(jīng)過(guò)多次的嘗試才能得出較為理想的方式。</p><p> 第
42、3章 MATLAB仿真</p><p><b> 3.1 重疊相加法</b></p><p> MATLAB實(shí)現(xiàn)重疊相加法流程圖如圖3-1所示。</p><p> 圖3-1 MATLAB實(shí)現(xiàn)重疊相加法流程圖</p><p><b> 3.2 重疊保留法</b></p><
43、;p> MATLAB實(shí)現(xiàn)重疊相加法流程圖如圖3-2所示。</p><p> 圖3-2 MATLAB實(shí)現(xiàn)重疊保留法圖</p><p><b> 3.3 操作步驟</b></p><p><b> 一、重疊相加法</b></p><p> 1.建立一個(gè)新文件,名為cdxj.m,如圖3-
44、3所示。</p><p> 圖3-3 重疊相加法建立新文件圖</p><p><b> 2.輸入程序代碼</b></p><p> 輸入重疊相加法程序代碼過(guò)程如圖3-4所示。</p><p> 圖3-4 重疊相加法輸入程序代碼圖</p><p> 3.保存文件并運(yùn)行,結(jié)果如圖3-5、3-
45、6所示。</p><p> 圖3-5 重疊相加法保存運(yùn)行文件圖</p><p> 圖3-6 重疊相加法保存運(yùn)行文件圖</p><p><b> 4.仿真結(jié)果</b></p><p> 仿真結(jié)果如圖3-7所示。</p><p> 圖3-7 重疊相加法仿真結(jié)果圖</p><
46、;p> 運(yùn)算結(jié)果如圖3-8所示。</p><p> 圖3-8 重疊相加法運(yùn)算結(jié)果圖</p><p><b> 重疊保留法</b></p><p> 程序代碼及保存文件如圖3-9、3-10所示。</p><p> 圖3-9 重疊保留法程序代碼圖</p><p> 圖3-10 重疊保
47、留法保存文件圖</p><p> 仿真結(jié)果及運(yùn)行結(jié)果如圖3-11、3-12所示。</p><p> 圖3-11 重疊保留法仿真結(jié)果圖</p><p> 圖3-12 重疊保留法運(yùn)行結(jié)果圖</p><p> 3.4 程序源代碼及結(jié)果分析</p><p><b> 1.重疊相加法</b><
48、;/p><p> function [] =cdj(xe,h,N)</p><p> h=[1 0 -1];xe=[1:10];N=6;</p><p> k=length( xe );%輸入序列長(zhǎng)度</p><p> t=length(h);%有限長(zhǎng)序列長(zhǎng)度</p><p> g=N+t-1;%進(jìn)行循環(huán)卷積的長(zhǎng)
49、度</p><p> m=ceil(k/N);%將xe分段</p><p> p=m*N+t-1;%序列卷積后的總長(zhǎng)度</p><p> yn=zeros(1,p);</p><p> x=[xe,zeros(1,m*N-k)];%補(bǔ)零</p><p> for j=0:m-1</p><
50、p> xj=x(N*j+1:N*(j+1));%xe中每段卷積的元素</p><p> xak=fft(xj,g);</p><p> hk=fft(h,g);</p><p> yn1=ifft(xak.*hk); %每段的卷積結(jié)果</p><p> temp=zeros(1,p);</p><p>
51、 temp(N*j+1:N*j+g)=yn1;</p><p> yn=yn+temp;%將每段的卷積結(jié)果加到y(tǒng)n中</p><p><b> end;</b></p><p> yn %輸出卷積后的結(jié)果</p><p><b> n=0:p-1;</b></p>&
52、lt;p><b> figure(1)</b></p><p> subplot(2,1,1);</p><p> stem(n,yn);</p><p> xlabel('n');ylabel('y(n)');</p><p> title('h(n)與xe(n)
53、的線性卷積的時(shí)域波形—重疊相加法');</p><p> subplot(2,1,2);</p><p> stem(n,abs(fft(yn)));</p><p> xlabel('k');ylabel('Y(k)');</p><p> axis([0,6*p/5,0,sum(ceil(a
54、bs(yn)))]);</p><p> title('h(n)與xe(n)的線性卷積的頻域特性—重疊相加法');</p><p><b> 運(yùn)行結(jié)果</b></p><p> h=[1 0 -1];</p><p> xe=[1:10];</p><p><b>
55、; N=6</b></p><p> 經(jīng)過(guò)重疊相加法求得線性卷積結(jié)果為</p><p><b> yn =</b></p><p> Columns 1 through 11</p><p> 1.0000 2.0000 2.0000 2.0000 2.0000 2.0
56、000 2.0000 2.0000 2.0000 2.0000 -9.0000</p><p> Columns 12 through 14</p><p> -10.0000 -0.0000 -0.0000</p><p> 仿真圖形如圖3-14:</p><p> 圖3-13 重疊相加法仿真結(jié)果
57、圖</p><p> 可以看出仿真結(jié)果與運(yùn)算結(jié)果相同。用以上算法,對(duì)長(zhǎng)為k的序列x(n)進(jìn)行分段,每段長(zhǎng)度為N,可分為[K/N]段,每段的結(jié)果與h(n)(長(zhǎng)度為M)進(jìn)行卷積,</p><p> 通過(guò)FFT運(yùn)算可以減少運(yùn)算量,復(fù)乘[K/N](N+M-1)log2(N+M-1)次,復(fù)加2[K/N](N+M-1)log2(N+M-1)次如圖3-14所示:</p><p&g
58、t; 圖3-14 重疊相加法結(jié)果分析圖</p><p><b> 2.重疊保留法</b></p><p> function [] =cdbl(xe,h,N)</p><p> xe=[1:10];h=[1 0 -1];N=4;</p><p> k=length(xe);%輸入序列長(zhǎng)度</p>
59、<p> M=length(h);%有限長(zhǎng)序列長(zhǎng)度</p><p> g=N+M-1;%進(jìn)行循環(huán)卷積的長(zhǎng)度</p><p> m=ceil(k/N);%將xe分段</p><p> p=m*N+M-1;%序列卷積后的總長(zhǎng)度</p><p> xe1=zeros(1,M-1);</p><p> x
60、=[xe1,xe,zeros(1,g-(k-(m-1)*N)+M-1)];%在xe前面添(M-1)個(gè)零,后面添足零為g的整數(shù)倍</p><p> yn=zeros(1,p);</p><p> for j=0:m-1</p><p> xj=x(N*j+1:N*(j+1)+M-1);%xe中每段卷積的元素</p><p> xak=f
61、ft(xj,g);</p><p> hk=fft(h,g);</p><p> yn1=ifft(xak.*hk); %每段的卷積結(jié)果</p><p> temp=zeros(1,p);</p><p> temp(N*j+1:N*(j+1))=yn1(M:g)</p><p> yn=yn+temp;%將
62、每段的卷積結(jié)果加到y(tǒng)n中</p><p><b> end;</b></p><p> yn %輸出卷積后的結(jié)果</p><p><b> n=0:p-1;</b></p><p><b> figure(2)</b></p><p>
63、 subplot(2,1,1);</p><p> stem(n,yn);</p><p> xlabel('n');ylabel('y(n)');</p><p> title(' xc(n)與xe(n)的線性卷積的時(shí)域波形—重疊保留法');</p><p> subplot(2,1,
64、2);</p><p> stem(n,abs(fft(yn)));</p><p> xlabel('k');ylabel('Y(k)');</p><p> axis([0,6*p/5,0,sum(ceil(abs(yn)))]);</p><p> title('xc(n)與xe(n)的線
65、性卷積的幅頻特性—重疊保留法');</p><p><b> end</b></p><p><b> % 測(cè)試序列</b></p><p> % xe=[1:10];</p><p> % h=[1 0 -1];</p><p> % N=4;cdbl(x
66、e,h,N)</p><p><b> 運(yùn)行結(jié)果</b></p><p><b> 測(cè)試序列</b></p><p> xe=[1:10];</p><p> h=[1 0 -1];</p><p><b> N=4;</b></p>
67、;<p><b> 結(jié)果為:</b></p><p><b> yn =</b></p><p> Columns 1 through 11</p><p> 1.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2
68、.0000 2.0000 2.0000 -9.0000</p><p> Columns 12 through 14</p><p> -10.0000 0 0</p><p> 仿真如圖3-16所示。</p><p> 圖3-15 重疊保留法仿真結(jié)果圖</p><p
69、> 重疊保留法和重疊相加法是有相同的運(yùn)算過(guò)程,如圖3-16所示:</p><p> 圖3-16 結(jié)果分析圖</p><p> 因而也是進(jìn)行了復(fù)乘[K/N](N+M-1)log2(N+M-1)次,復(fù)加2[K/N](N+M-1)log2(N+M-1)次。</p><p><b> 3.5 小結(jié) </b></p><
70、p> 重疊相加法和重疊保留法都是應(yīng)用DFT求線性卷積的方法,之所以會(huì)改進(jìn)直接計(jì)算線性卷積的時(shí)間復(fù)雜度,就是因?yàn)镈FT的快速算法。兩種算法都是對(duì)原序列進(jìn)行分組,進(jìn)行循環(huán)卷積后再組合,有相同的時(shí)間復(fù)雜度,但在執(zhí)行過(guò)程和應(yīng)用范圍上還是有一定的區(qū)別。重疊相加法是對(duì)已知的有限長(zhǎng)序列進(jìn)行分段后與系統(tǒng)序列循環(huán)卷積,組合時(shí)去掉每段后面重疊的部分;重疊保留法是通過(guò)對(duì)輸出序列進(jìn)行分段后導(dǎo)出的一種線性卷積方法,分段前對(duì)原序列前面進(jìn)行添零,分段循環(huán)卷積
71、后將每段后面未重疊的一部分保留后組合。</p><p> 兩個(gè)程序在分段上有差異,但都是對(duì)截?cái)嗟男蛄羞M(jìn)行循環(huán)卷積,因而有一定的通用性。在進(jìn)行本設(shè)計(jì)的編程上,最主要的是理解兩種方法實(shí)現(xiàn)的過(guò)程,在對(duì)數(shù)據(jù)處理時(shí)要注意各個(gè)數(shù)據(jù)的含義和數(shù)組的組合過(guò)程。</p><p> 第4章 CCS軟件概況</p><p> 4.1 CCS軟件簡(jiǎn)介</p><p
72、> CCS(Code Composer Studio數(shù)據(jù)設(shè)計(jì)工作室)代碼調(diào)試器是一種合成開(kāi)發(fā)環(huán)境。 它是一種針對(duì)標(biāo)準(zhǔn)TMS320調(diào)試器接口的交互式方法。CCS目前有CCS1.1, CCS1.2 和CCS2.0等三個(gè)不同時(shí)期的版本,又有CC2000 ( 針對(duì)C2XX ),CCS5000 ( 針對(duì)C54XX )和CCS6000 (針對(duì)C6X )三個(gè)不同的型號(hào)。我們所使用的是CCS50002.0的版本。</p><
73、p> CCS5000具有以下特性:</p><p> TI編譯器的完全集成的環(huán)境:CCS5000目標(biāo)管理系統(tǒng),內(nèi)建編輯器,所有的調(diào)試和分析能力集成在一個(gè)Windows環(huán)境中。</p><p> 對(duì)C和DSP匯編文件的目標(biāo)管理:目標(biāo)編輯器保持對(duì)所有文件及相關(guān)內(nèi)容的跟蹤。它只對(duì)最近一次編譯中改變過(guò)的文件重新編譯,以節(jié)省編譯時(shí)間。</p><p> 高集成的
74、編輯器調(diào)整C和DSP匯編代碼:CCS5000的內(nèi)建編輯器支持C和匯編文件的動(dòng)態(tài)語(yǔ)法加亮顯示。使用戶(hù)能很容易地閱讀代碼和當(dāng)場(chǎng)發(fā)現(xiàn)語(yǔ)法錯(cuò)誤。</p><p> 編輯和調(diào)試時(shí)的后臺(tái)編輯:用戶(hù)在使用編譯器和匯編器時(shí)沒(méi)有必要退出系統(tǒng)到DOS環(huán)境中,因?yàn)镃CS5000會(huì)自動(dòng)將這些工具裝載在它的環(huán)境中。在其窗口中,錯(cuò)誤會(huì)加亮顯示只要雙擊錯(cuò)誤就可以直接到達(dá)出錯(cuò)處。</p><p> 在含有浮點(diǎn)并行調(diào)試
75、管理器(PDM)的原有的MS窗口下支持多處理器CCS5000在 Windows95和Windows-me中支持多處理。PDM(調(diào)試管理器)允許將命令傳播給所有的或所選擇的處理器。</p><p> 在任何算法點(diǎn)觀察信號(hào)的圖形窗口探針:圖形顯示窗口使用戶(hù)能夠觀察時(shí)域或頻域內(nèi)的信號(hào)。對(duì)于頻域圖,F(xiàn)FT(快速傅立葉變換)在主機(jī)內(nèi)執(zhí)行,這樣就可以觀察所感興趣的部分而無(wú)須改變它的DSP代碼。圖顯示也可以同探針連接,當(dāng)前顯
76、示窗口被更新時(shí),探針被指定,這樣當(dāng)代碼執(zhí)行到達(dá)該點(diǎn)時(shí),就可以迅速地觀察到信號(hào)。</p><p> 文件探針在算法處通過(guò)文件提取或加入信號(hào)或數(shù)據(jù):CCS5000允許用戶(hù)從PC機(jī)讀或?qū)懶盘?hào)流。而不是實(shí)時(shí)的讀信號(hào),這就可以用已知的例子來(lái)仿真算法。</p><p> 圖形分析:CCS5000的圖形分析能力在其環(huán)境中是集成的。</p><p> 在后臺(tái)(系統(tǒng)命令)執(zhí)行用
77、戶(hù)的DOS程序:</p><p> 用戶(hù)可以執(zhí)行CCS5000中的DOS程序,并將其輸出以流水方式送到CCS5000的輸出窗口。且允許用戶(hù)將應(yīng)用程序集成到CCS5000。</p><p> 技術(shù)狀態(tài)觀察窗口:CCS5000的可視窗口允許用戶(hù)進(jìn)入C表達(dá)式及相關(guān)變量。結(jié)構(gòu)、數(shù)組、指針都能很簡(jiǎn)單地遞歸擴(kuò)展和減少,以便進(jìn)入復(fù)雜結(jié)構(gòu)。</p><p> 代數(shù)分解窗口:允
78、許用戶(hù)選擇查看寫(xiě)成代數(shù)表達(dá)式的C格式,提高可讀性 。</p><p> 目標(biāo)DSP上的幫助:DSP結(jié)構(gòu)和寄存器上的在線幫助可以使用戶(hù)不必查看技術(shù)手冊(cè)。</p><p> 用戶(hù)擴(kuò)展:擴(kuò)展語(yǔ)言(GEL)使得用戶(hù)可以將自己的菜單項(xiàng)加到CCS5000的菜單欄中。</p><p> 主要操作流程如圖4-1所示。</p><p> 圖4-1 主要
79、操作流程圖 </p><p> 4.1.1 軟件概況</p><p> CCS提供了環(huán)境配置、源文件編譯、程序調(diào)試、跟蹤和分析等工具??梢詭椭脩?hù)在一個(gè)軟件環(huán)境下完成編譯、編譯鏈接、調(diào)試和數(shù)據(jù)分析等工作。與TI提供的早期軟件開(kāi)發(fā)工具相比,利用CCS能夠加快軟件開(kāi)發(fā)進(jìn)程,提高工作效率:CCS一般工作在兩種模式:軟件仿真器和與硬件開(kāi)發(fā)板相結(jié)合的在線編程。前者可以脫離DSP芯片,在PC機(jī)上模
80、擬DSP的指令集與工作機(jī)制,主要用于前期算法實(shí)現(xiàn)和調(diào)試;后者實(shí)時(shí)運(yùn)行在DSP芯片上??梢栽诰€編制和調(diào)試應(yīng)用程序。一般的,一種CCS只適用于一種系列的DSP芯片。例如CCS5000適用于C5000系列DSP芯片,包括C54x和C55x。用戶(hù)只需要在CCS配置程序中設(shè)定DSP的類(lèi)型和開(kāi)發(fā)平臺(tái)類(lèi)型即可。</p><p> 4.1.2 CCS軟件的使用</p><p> 打開(kāi)CCS5000主程
81、序,打開(kāi)的主界面如圖4-2所示。</p><p> 圖4-2 CCS54xx軟件界面</p><p><b> 1.新建工程文件</b></p><p> 文件復(fù)制完成以后,啟動(dòng)CCS,在主菜單中單擊“Project”(設(shè)計(jì)),會(huì)有“new”和“open”選項(xiàng),創(chuàng)建新工程使用“new”選項(xiàng)。程序會(huì)提問(wèn)新建工程的名字以及保存位置,指定后單擊
82、“確定”即可,如圖4-3所示。</p><p> 圖4-3 新建工程圖 </p><p> 可以使用兩種方式向工程添加源文件、CMD文件和庫(kù)文件添加源文件。</p><p> 在主菜單中單擊“Project”,選擇“Add Files to Project”命令,在彈出的添加文件對(duì)話框中找到目錄“a”,選擇文件“a.c”,單擊“打開(kāi)”按鈕,如下面左圖所示。&l
83、t;/p><p> 另一個(gè)方法是在工程名“a.pjt”上單擊鼠標(biāo)右鍵,選擇“Add Files”命令。在彈出的添加文件的對(duì)話框中,找到目錄“a”,再在添加文件對(duì)話框中單擊“文件類(lèi)型”,選擇“C Source Files(*.c;*.ccc)”,這樣在添加文件對(duì)話框里就只顯示指定類(lèi)型的文件。同時(shí)選擇“l(fā)oad.asm”和“vectors.asm”,單擊“打開(kāi)”按鈕,如圖4-4所示。</p><p&
84、gt; 圖4-4 添加文件方式圖 </p><p> ?。?)接著添加必需的內(nèi)存定位文件“*.cmd”,使用上述任一方式,向工程里添加“a.cmd”,注意在添加文件對(duì)話框的“文件類(lèi)型”下拉列表中要選擇“Link Command File(*.cmd)”,該文件定義了各代碼段和數(shù)據(jù)段在存儲(chǔ)器中的位置。</p><p> ?。?)因?yàn)楸緦?shí)驗(yàn)工程是基于C語(yǔ)言編寫(xiě)的,因此還需要添加運(yùn)行時(shí)支持庫(kù)(
85、Run-Time-Support Library)。使用上述任何一種方式,向工程添加“rts.lib”文件,該文件存放在CCS的安裝目錄“\c5400\cgtools\lib”下。注意在添加文件對(duì)話框的“文件類(lèi)型”下拉列表中要選擇“Object Library Files(*.o*,*.l*)”。</p><p> ?。?)添加頭文件。在工程名“a.pjt”上單擊鼠標(biāo)右鍵,選擇“Scan All Dependen
86、cies”,這樣a.c文件所包含的頭文件“a.h”將出現(xiàn)在工程瀏覽窗中的“Iclude”文件夾中。頭文件實(shí)際不用人工添加,在Build工程時(shí),CCS本身就會(huì)自動(dòng)完成掃描。</p><p><b> 建造和運(yùn)行程序</b></p><p> 建造(Building)在這里指編譯、匯編、鏈接三個(gè)獨(dú)立步驟按順序聯(lián)合運(yùn)行。在主菜單中單擊“Project”,選擇“Rebui
87、ld All”,或者單擊工具條圖標(biāo),CCS將重新對(duì)工程中所有文件進(jìn)行編譯、匯編、鏈接,并同步在底部窗口中顯示編譯連接信息。連接完畢,CCS生成一個(gè)“.out”文件,默認(rèn)存放在目錄“a”下的“debug”(除錯(cuò))目錄中。</p><p> 建造完畢后,再完成裝載程序的步驟:在主菜單中單擊“File”,選擇“Load Program”,在彈出對(duì)話框中,找到目錄“a”下的“debug”目錄,選擇“a.out”,并打開(kāi)
88、。</p><p> 在主菜單中單擊“Debug”,選擇“Run”,或單擊工具條圖標(biāo),讓程序全速運(yùn)行。如果能在底部的stdout標(biāo)準(zhǔn)輸出窗口看到程序運(yùn)行的輸出信息“a started”,證明程序能夠正常運(yùn)行。在主菜單中單擊“Debug”,選擇“Run”,或單擊工具條圖標(biāo),讓程序停止運(yùn)行。</p><p> 2.多種觀察窗口幫助調(diào)試</p><p> 查看寄存器
89、:在 CCS中選擇View菜單中的CPU Registers命令。</p><p> 查看數(shù)據(jù):選擇View菜單中的Memory…命令,彈出設(shè)置窗口,按實(shí)際需要指定其中的參數(shù),如起始地址等,就可以觀察到數(shù)據(jù)單元中的值,該值可以以多種格式表示。</p><p> 查看程序中變量的當(dāng)前值:可以在程序中用光標(biāo)選中變量名,在鼠標(biāo)右鍵菜單中選擇Add to Watch Window命令就可以把該
90、變量添加到Watch窗口。隨著程序的運(yùn)行,可以在Watch窗口看到該變量的值的變化。</p><p> 顯示圖形:如果要觀察的變量太多,例如要觀察一個(gè)數(shù)組的值,那么可以用一種更直觀的方法,就是把數(shù)據(jù)用圖形的方式表現(xiàn)出來(lái)。選擇View菜單中的Graph命令,會(huì)有不同類(lèi)型的圖形可供選擇。常用的是時(shí)域/頻域波形,即Time/Frequency…項(xiàng)。在彈出的Graph Property對(duì)話框中,可以設(shè)定圖形的標(biāo)題、數(shù)據(jù)
91、的起始地址、采集緩沖區(qū)的大小、顯示數(shù)據(jù)的大小、數(shù)據(jù)類(lèi)型等屬性。</p><p><b> 4.2 程序源代碼</b></p><p> 根據(jù)課題要實(shí)現(xiàn)的功能及要求,CCS軟件進(jìn)行分段卷積編程部分C語(yǔ)言源程序:</p><p><b> 1.重疊相加法</b></p><p> #includ
92、e<stdio.h></p><p><b> main()</b></p><p><b> {</b></p><p> static float y[600],z[600];</p><p> int m,n,L,i,j,k,s,t,t1,p,M;
93、 </p><p> float x[10]={1,2,3,4,5,6,7,8,9,10};</p><p> float v[3]={1,0,-1};</p><p> M=6;m=10;n=3;</p><p><b> L=M+n-1;</b></p><p><b
94、> t=m/M;</b></p><p> if (m%M==0)</p><p><b> t1=t;</b></p><p> else t1=t+1; </p><p> for (p=0;p<=t1-1;p++)</p><p><b> {&
95、lt;/b></p><p> for(i=p*L;i<=(p+1)*L-1;i++)</p><p><b> {</b></p><p><b> s=0;</b></p><p> for (j=0;j<=M-1;j++)</p><p>&l
96、t;b> {k=i-j;</b></p><p> s+=x[p*M+j]*v[k-p*L];</p><p><b> y[i]=s;}</b></p><p><b> }}</b></p><p> for(p=0;p<=t1-1;p++) </p>
97、;<p><b> {</b></p><p> for(i=p*L;i<=(p+1)*L-1;i++)</p><p> {if(i==0||(0<i<M-1))</p><p> z[i]=y[i];</p><p> if((L+p*M-n<i<=L+p*M-1
98、)&&(i>M-1))</p><p> z[i]=y[i+p*(n-1)]+y[i+(p+1)*(n-1)];</p><p> if((p*L-1<i<=p*L+M-n)&&(i>=L))</p><p> z[i]=y[i+p*(n-1)];</p><p> return
99、(z[i]);}</p><p><b> } </b></p><p><b> }</b></p><p><b> 2.重疊保留法</b></p><p> #include<stdio.h></p><p><b>
100、 main()</b></p><p><b> {</b></p><p> static float y[600],x1[600],h1[300],h2[300];</p><p> int M,N,L,Lx,i,j,k,s,t,t1,p; </p><p>
101、 float x[10]={1,2,3,4,5,6,7,8,9,10};</p><p> float h[3]={1,0,-1};</p><p> Lx=10;M=3;N=6;</p><p><b> L=M+N-1;</b></p><p><b> t=Lx/N;</b><
102、/p><p> if (Lx%N==0)</p><p><b> t1=t;</b></p><p> else t1=t+1; </p><p> for(j=M;j<L;j++)</p><p><b> h[j]=0;</b></p><
103、;p> for(i=M-1;i<=Lx+M-2;i++)</p><p> x1[i]=x[i-M+1];</p><p> for(i=0;i<M-1;i++)</p><p><b> x1[i]=0;</b></p><p> h1[0]=h[0];</p><p&g
104、t; for(j=1;j<L;j++)</p><p> h1[j]=h[L-j];</p><p> for(p=0;p<t1;p++)</p><p><b> {</b></p><p> for(i=p*L;i<(p+1)*L;i++)</p><p><
105、b> {s=0;</b></p><p> for(j=0;j<L;j++)</p><p> s+=x1[j+p*N]*h1[j];</p><p><b> y[i]=s;</b></p><p> for (k=0;k<L;k++) </p><p>
106、<b> {</b></p><p> h2[k]=h1[k];</p><p> h1[0]=h2[L-1];}</p><p> for(k=1;k<L;k++)</p><p> h1[k]=h2[k-1];</p><p><b> }</b><
107、;/p><p><b> }</b></p><p> for(p=0;p<t1;p++)</p><p><b> {</b></p><p> for(i=p*N;i<(p+1)*N;i++)</p><p> {y[i]=y[i+(p+1)*(M-1)
108、];</p><p> Return(y[i]);}</p><p><b> }</b></p><p><b> }</b></p><p><b> 3.鏈接文件</b></p><p><b> MEMORY</b>
109、;</p><p><b> {</b></p><p> PAGE 0: EPROG: origin = 0x1400, len = 0x7c00</p><p> VECT: origin = 0xff80, len = 0x80</p><p> PAGE
110、1: USERREGS: origin = 0x60, len = 0x1c</p><p> BIOSREGS: origin = 0x7c, len = 0x4</p><p> IDATA: origin = 0x80, len = 0x1380</p><p> EDATA:
111、 origin = 0x1400, len = 0x8000</p><p> EDATA1: origin = 0x9400, len = 0x4c00</p><p><b> }</b></p><p><b> SECTIONS</b></p><p
112、><b> {</b></p><p> .vectors: {} > VECT PAGE 0</p><p> .sysregs: {} > BIOSREGS PAGE 1</p><p> .trcinit: {} > EPROG PAGE 0</p><p> .gblinit:
113、{} > EPROG PAGE 0</p><p> frt: {} > EPROG PAGE 0</p><p> .text: {} > EPROG PAGE 0</p><p> .cinit: {} > EPROG PAGE 0</p><p> .pinit: {} > E
114、PROG PAGE 0</p><p> .sysinit: {} > EPROG PAGE 0</p><p> .bss: {} > IDATA PAGE 1</p><p> .far: {} > IDATA PAGE 1</p><p> .const: {} > IDATA PAG
115、E 1</p><p> .switch: {} > IDATA PAGE 1</p><p> .sysmem: {} > IDATA PAGE 1</p><p> .cio: {} > IDATA PAGE 1</p><p> .MEM$obj: {} > IDATA PAGE 1</
116、p><p> .sysheap: {} > IDATA PAGE 1</p><p> .stack: {} > IDATA PAGE 1</p><p><b> }</b></p><p><b> 4.3 小結(jié)</b></p><p> 重疊相加法
117、和重疊保留法計(jì)算分段卷積與線性卷積完全相同,且能很好的解決實(shí)際工程中利用快速線性卷積變換經(jīng)常會(huì)遇到的以下問(wèn)題:(1)需要對(duì)那個(gè)短序列補(bǔ)充很多零點(diǎn),從而導(dǎo)致計(jì)算量和需要的存儲(chǔ)空間無(wú)謂的增加;(2)需要獲得所有的輸入序列,并完全進(jìn)行處理后,輸出序列才是有效的,因此整個(gè)系統(tǒng)必然存在較大的延時(shí),不能符合實(shí)時(shí)處理的要求;(3)實(shí)際上,當(dāng)兩個(gè)序列長(zhǎng)度差距較大時(shí),快速卷積的優(yōu)勢(shì)并不能體現(xiàn)出來(lái),從而無(wú)法達(dá)到信號(hào)實(shí)時(shí)處理的要求。分段卷積快速算法模塊,在D
118、SP中采用流水線結(jié)構(gòu)進(jìn)行實(shí)時(shí)處理,經(jīng)檢驗(yàn)該方法正確且能很好地滿(mǎn)足對(duì)信號(hào)進(jìn)行實(shí)時(shí)處理的要求。</p><p><b> 第5章 課題特點(diǎn)</b></p><p> 5.1 MATLAB仿真和DSP實(shí)現(xiàn)</p><p> MATLAB將一個(gè)優(yōu)秀軟件的易用性與可靠性、通用性與專(zhuān)業(yè)性 、一般目的的應(yīng)用與高深的科學(xué)技術(shù)應(yīng)用有機(jī)的相結(jié)合。MATLA
119、B是一種直譯式的高級(jí)語(yǔ)言,比其它程序設(shè)計(jì)語(yǔ)言容易。它集科學(xué)計(jì)算、圖象處理;聲音處理于一身,并提供了豐富的Windows圖形界面設(shè)計(jì)方法。</p><p> MATLAB語(yǔ)言是功能強(qiáng)大的計(jì)算機(jī)高級(jí)語(yǔ)言,它以超群的風(fēng)格與性能風(fēng)靡全世界,成功地應(yīng)用于各工程學(xué)科的研究領(lǐng)域。</p><p> 在具體編程實(shí)現(xiàn)某個(gè)DSP算法之前,一般首先需要對(duì)其進(jìn)行模擬仿真。MATLAB目前已經(jīng)成為非常優(yōu)秀的仿真
120、工具、現(xiàn)行的版本已經(jīng)包含了許多強(qiáng)大的工具軟件包。被各個(gè)學(xué)科廣泛使用。單獨(dú)使用MATLAB語(yǔ)言就可以實(shí)現(xiàn)C、FORTRAN等語(yǔ)言的許多功能,并且實(shí)現(xiàn)起來(lái)更加簡(jiǎn)潔方便,同時(shí)它也提供同C語(yǔ)言的接口。</p><p> 5.2 采用時(shí)域卷積和FFT變換兩種方案</p><p> 為了解決在實(shí)際過(guò)程中線性卷積會(huì)遇到的無(wú)法滿(mǎn)足實(shí)時(shí)性要求的問(wèn)題,可采用分段卷積方案,分段卷積可采用兩種方案:(1)采用
121、是與直接卷積方法;(2)采用FFT變換得到Y(jié)(K),再進(jìn)行IFFT得到y(tǒng)(n)。</p><p> 5.3 C語(yǔ)言和匯編語(yǔ)言混合編程</p><p> 用C語(yǔ)言開(kāi)發(fā)DSP程序不僅使DSP開(kāi)發(fā)的速度大大加快,而且開(kāi)發(fā)出來(lái)的DSP程序的可讀性和可移植性都大大增加,程序修改也極為方便。雖然C編譯器的優(yōu)化功能可以使C代碼的效率大大增加,但在某些情況下,C代碼的效率還是無(wú)法與手工編寫(xiě)的匯編代碼的
122、效率相比,如FFT程序。此外,用C語(yǔ)言實(shí)現(xiàn)DSP芯片的某些硬件控制也不如匯編程序方便,有些甚至無(wú)法用C語(yǔ)言實(shí)現(xiàn)。因此,在很多情況下,DSP應(yīng)用程序往往需要用C語(yǔ)言和匯編語(yǔ)言的混合編程方法來(lái)實(shí)現(xiàn),以達(dá)到最佳地利用DSP芯片軟硬件資源的目的。</p><p> 用C語(yǔ)言和匯編語(yǔ)言的混合編程方法主要有以下三種:</p><p> 獨(dú)立編寫(xiě)C程序和匯編程序,分開(kāi)編譯或匯編形成各自的目標(biāo)代碼模塊
123、,然后用鏈接器將C模塊和匯編模塊鏈接起來(lái)。</p><p> 直接在C語(yǔ)言程序的相應(yīng)位置嵌入?yún)R編語(yǔ)句;</p><p> 對(duì)C程序進(jìn)行編譯生成相應(yīng)的匯編程序,然后對(duì)匯編程序進(jìn)行手工優(yōu)化和修改。</p><p> 本設(shè)計(jì)采用第一種方法。</p><p><b> 第6章 結(jié)論</b></p><
124、;p> 分段卷積方法是實(shí)際數(shù)字信號(hào)處理中經(jīng)常用到的方法。它能夠靈活的計(jì)算長(zhǎng)輸入序列對(duì)IIR的濾波響應(yīng),并且不會(huì)引入很大的延時(shí),通常可以節(jié)約%50的計(jì)算時(shí)間,因此是一種很有效的方法。</p><p> 利用重疊相加法和重疊保留法計(jì)算分段卷積的結(jié)果不但與線性卷積結(jié)果相同。而且很好地解決了常用的線性卷積方法要求兩個(gè)輸入序列的持續(xù)時(shí)間相同, 但在實(shí)際工程中經(jīng)常會(huì)遇到某個(gè)輸入序列具有較長(zhǎng)持續(xù)時(shí)間的情況,從而無(wú)法達(dá)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 畢業(yè)設(shè)計(jì)----基于matlab的qpsk系統(tǒng)仿真設(shè)計(jì)與實(shí)現(xiàn)
- 電流保護(hù)matlab仿真畢業(yè)設(shè)計(jì)
- 利用matlab軟件設(shè)計(jì)實(shí)現(xiàn)信號(hào)仿真系統(tǒng)畢業(yè)設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)---基于matlab的dpll設(shè)計(jì)與仿真
- 畢業(yè)設(shè)計(jì)---基于matlab的卷積碼的分析與應(yīng)用
- 畢業(yè)設(shè)計(jì)--基于matlab的rf電路設(shè)計(jì)與仿真
- 畢業(yè)設(shè)計(jì)--基于matlab的rf電路設(shè)計(jì)與仿真
- 畢業(yè)設(shè)計(jì)--基于matlab實(shí)現(xiàn)的ct重建算法仿真比較研究
- dc-dc-ac仿真matlab畢業(yè)設(shè)計(jì)
- matlab實(shí)現(xiàn)卷積碼編譯碼畢業(yè)論文
- 畢業(yè)設(shè)計(jì)---基matlab的人臉識(shí)別系統(tǒng)設(shè)計(jì)與仿真
- 畢業(yè)設(shè)計(jì)(論文)-基于matlab的液壓系統(tǒng)的設(shè)計(jì)與仿真
- 畢業(yè)設(shè)計(jì)(論文)基于matlab的rf電路設(shè)計(jì)與仿真
- 同步發(fā)電機(jī)matlab仿真同步電機(jī)模型的matlab仿真畢業(yè)設(shè)計(jì)
- 調(diào)制解調(diào)的matlab實(shí)現(xiàn)畢業(yè)設(shè)計(jì)
- 畢業(yè)設(shè)計(jì) ---基于matlab仿真的數(shù)字調(diào)制與解調(diào)設(shè)計(jì)
- dtmf信號(hào)系統(tǒng)的matlab仿真畢業(yè)設(shè)計(jì)
- 新型pid控制技術(shù)的matlab仿真畢業(yè)設(shè)計(jì)
- 【畢業(yè)設(shè)計(jì)】基于matlab車(chē)牌識(shí)別系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)
- 基于matlab的fir濾波器設(shè)計(jì)與仿真_畢業(yè)設(shè)計(jì)論文
評(píng)論
0/150
提交評(píng)論