課程設(shè)計(jì)---基于重疊相加法圓周卷積的實(shí)現(xiàn)_第1頁
已閱讀1頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  課程設(shè)計(jì)任務(wù)書</b></p><p>  題 目:基于重疊相加法圓周卷積的實(shí)現(xiàn)</p><p><b>  初始條件:</b></p><p>  具備數(shù)字信號(hào)處理的理論知識(shí);</p><p>  具備Matlab編程能力;</p><p&g

2、t;  分析重疊相加法的圓周卷積的原理;</p><p>  提供編程所需要的計(jì)算機(jī)一臺(tái)</p><p>  要求完成的主要任務(wù):(包括課程設(shè)計(jì)工作量及其技術(shù)要求,以及說明書撰寫等具體要求)</p><p>  1、獨(dú)立編寫程序?qū)崿F(xiàn)基于重疊相加法的圓周卷積</p><p>  2、用Matlab驗(yàn)證程序結(jié)果,并分析重疊相加法的圓周卷積的原理&

3、lt;/p><p>  3、完成符合學(xué)校要求的設(shè)計(jì)說明書</p><p><b>  時(shí)間安排:</b></p><p>  一周,其中3天程序設(shè)計(jì),2天程序調(diào)試</p><p>  指導(dǎo)教師簽名: 年 月 日</p><p>  系主任(或責(zé)任

4、教師)簽名: 年 月 日</p><p><b>  目錄</b></p><p><b>  摘要I</b></p><p><b>  1 軟件基礎(chǔ)1</b></p><p>  1.1 MATLAB介紹1</p><

5、;p>  1.2 MATLAB的應(yīng)用2</p><p><b>  2 理論基礎(chǔ)3</b></p><p>  2.1 圓周卷積原理3</p><p>  2.2重疊相加法4</p><p><b>  3 程序設(shè)計(jì)6</b></p><p>  3.1 程序

6、設(shè)計(jì)思路6</p><p>  3.2程序設(shè)計(jì)流程圖7</p><p><b>  3.3方案比較8</b></p><p><b>  4 程序代碼9</b></p><p>  5 程序運(yùn)行結(jié)果與分析11</p><p><b>  心得體會(huì)12&l

7、t;/b></p><p><b>  參考文獻(xiàn)13</b></p><p><b>  摘要</b></p><p>  MATLAB是矩陣實(shí)驗(yàn)室(Matrix Laboratory)的簡(jiǎn)稱,是美國(guó)MathWorks公司出品的商業(yè)數(shù)學(xué)軟件,主要用于算法開發(fā)、數(shù)據(jù)可視化、數(shù)據(jù)分析以及數(shù)值計(jì)算等領(lǐng)域。本次課程設(shè)計(jì)將通

8、過MATLAB軟件進(jìn)行重疊相加法圓周卷積的設(shè)計(jì),并對(duì)其具體過程進(jìn)行分析。</p><p>  關(guān)鍵詞:MATLAB 重疊相加法 圓周卷積1 軟件基礎(chǔ)</p><p>  1.1 MATLAB介紹</p><p>  MATLAB是由美國(guó)mathworks公司發(fā)布的主要面對(duì)科學(xué)計(jì)算、可視化以及交互式程序設(shè)計(jì)的高科技計(jì)算環(huán)境。它將數(shù)值分析、矩陣計(jì)算、科學(xué)數(shù)據(jù)可視化以及非

9、線性動(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ì)語言(如C、Fortran)的編輯模式,代表了當(dāng)今國(guó)際科學(xué)計(jì)算軟件的先進(jìn)水平。</p><p>  Matlab和Mathematica、Maple并稱為三大數(shù)學(xué)軟件。它在數(shù)學(xué)類科技應(yīng)用軟件中在數(shù)值計(jì)算方面首屈一指。MAT

10、LAB可以進(jìn)行矩陣運(yùn)算、繪制函數(shù)和數(shù)據(jù)、實(shí)現(xiàn)算法、創(chuàng)建用戶界面、連接MATLAB開發(fā)工作界面、連接其他編程語言的程序等,主要應(yīng)用于工程計(jì)算、控制設(shè)計(jì)、信號(hào)處理與通訊、圖像處理、信號(hào)檢測(cè)、金融建模設(shè)計(jì)與分析等領(lǐng)域。</p><p>  MATLAB的基本數(shù)據(jù)單位是矩陣,它的指令表達(dá)式與數(shù)學(xué)、工程中常用的形式十分相似,故用MATLAB來解算問題要比用C,F(xiàn)ORTRAN等語言完成相同的事情簡(jiǎn)捷得多,并且MATLAB也吸

11、收了像Maple等軟件的優(yōu)點(diǎn),使MATLAB成為一個(gè)強(qiáng)大的數(shù)學(xué)軟件。在新的版本中也加入了對(duì)C,F(xiàn)ORTRAN,C++ ,JAVA的支持??梢灾苯诱{(diào)用,用戶也可以將自己編寫的實(shí)用程序?qū)氲組ATLAB函數(shù)庫中方便自己以后調(diào)用,此外許多的MATLAB愛好者都編寫了一些經(jīng)典的程序,用戶可以直接進(jìn)行下載就可以使用。</p><p>  MATLAB具有以下特點(diǎn):</p><p>  1.高效的數(shù)值

12、計(jì)算及符號(hào)計(jì)算功能,能使用戶從繁雜的數(shù)學(xué)運(yùn)算分析中解脫出來;</p><p>  2.具有完備的圖形處理功能,實(shí)現(xiàn)計(jì)算結(jié)果和編程的可視化;</p><p>  3.友好的用戶界面及接近數(shù)學(xué)表達(dá)式的自然化語言,使學(xué)者易于學(xué)習(xí)和掌握;</p><p>  4.功能豐富的應(yīng)用工具箱,為用戶提供了大量方便實(shí)用的處理工具。</p><p>  1.2

13、MATLAB的應(yīng)用</p><p>  MATLAB 產(chǎn)品族可以用來進(jìn)行以下各種工作:   </p><p><b>  ● 數(shù)值分析   </b></p><p>  ● 數(shù)值和符號(hào)計(jì)算   </p><p>  ● 工程與科學(xué)繪圖   </p><p>  ● 控制系統(tǒng)的設(shè)計(jì)與仿真   <

14、;/p><p>  ● 數(shù)字圖像處理 技術(shù)   </p><p>  ● 數(shù)字信號(hào)處理 技術(shù)   </p><p>  ● 通訊系統(tǒng)設(shè)計(jì)與仿真 </p><p>  ● 財(cái)務(wù)與金融工程   </p><p>  MATLAB 的應(yīng)用范圍非常廣,包括信號(hào)和圖像處理、通訊、控制系統(tǒng)設(shè)計(jì)、測(cè)試和測(cè)量、財(cái)務(wù)建模和分析以及計(jì)算生物學(xué)

15、等眾多應(yīng)用領(lǐng)域。附加的工具箱(單獨(dú)提供的專用 MATLAB 函數(shù)集)擴(kuò)展了 MATLAB 環(huán)境,以解決這些應(yīng)用領(lǐng)域內(nèi)特定類型的問題。2 理論基礎(chǔ)</p><p>  2.1 圓周卷積原理</p><p>  對(duì)兩個(gè)N點(diǎn)序列和,除了可以做線性卷積外,還有一種很重要的卷積運(yùn)算,就是圓周卷積。</p><p><b>  令</b></p>

16、;<p>  則圓周卷積結(jié)果長(zhǎng)度不變,為N。</p><p>  由上式可以得出圓周卷積與周期卷積的關(guān)系,就是有限長(zhǎng)序列圓周卷積結(jié)果的周期延拓,等于它們周期延拓后的周期卷積。也就是說,周期卷積的主值序列,是各周期序列主值序列的圓周卷積。</p><p>  圓周卷積的實(shí)現(xiàn)步驟如下:</p><p>  若、分別是長(zhǎng)度為N、M的序列則與線性卷積至多M+N

17、-1個(gè)非零值,如果L<M+N-1則周期延拓時(shí)必然會(huì)有一部分非零值發(fā)生混疊;只有當(dāng)L>M+N-1時(shí),周期延拓才不會(huì)發(fā)生混疊。</p><p>  之所以討論用圓周卷積來計(jì)算線性卷積的條件,是因?yàn)閳A周卷積可在頻域下利用DFT求得,從而可采用DFT的快速算法FFT來計(jì)算,這樣就可以利用FFT來計(jì)算線性卷積,大大提高運(yùn)算效率。</p><p><b>  2.2重疊相加法&l

18、t;/b></p><p>  在實(shí)際應(yīng)用中利用FFT來計(jì)算兩個(gè)序列的圓周卷積從而實(shí)現(xiàn)計(jì)算其線性卷積,但是常遇到的問題是參加卷積的兩個(gè)序列的長(zhǎng)度相差較大,這樣長(zhǎng)度小的序列就需要補(bǔ)很多的零點(diǎn),這樣就需要打的存儲(chǔ)量,運(yùn)算時(shí)間也會(huì)變長(zhǎng)。所以常用到的解決方法有兩種,其中一種就是重疊相加法。</p><p>  h(n)長(zhǎng)度為N,x(n)長(zhǎng)度為無限長(zhǎng),</p><p>

19、  x(n)取M點(diǎn),且與N盡量接近</p><p>  重疊相加法的卷積示意圖如下:</p><p>  重疊相加法的步驟如下</p><p> ?。?)將h(n)補(bǔ)零延長(zhǎng)到L =M+ N -1,并計(jì)算長(zhǎng)為L(zhǎng)的FFT,得到 H(k)。</p><p> ?。?)分別將xk(n)補(bǔ)零延長(zhǎng)到L =M+ N -1,并計(jì)算長(zhǎng)為L(zhǎng)的FFT,得到 Xk(

20、k)</p><p> ?。?)計(jì)算,并求長(zhǎng)為L(zhǎng)的反變換,即</p><p> ?。?)將yk(n)的重疊部分相加,最后得到結(jié)果為</p><p><b>  3 程序設(shè)計(jì)</b></p><p>  由以上原理可以設(shè)計(jì)程序利用FFT算法來實(shí)現(xiàn)基于重疊相加法的圓周卷積。</p><p>  3.1

21、 程序設(shè)計(jì)思路</p><p>  函數(shù)juanji(x1,x2,L)的設(shè)計(jì):</p><p>  x1(n)進(jìn)行N點(diǎn)快速傅里葉變換得X1k</p><p>  x2(n)進(jìn)行N點(diǎn)快速傅里葉變換得X2k</p><p>  進(jìn)行頻域相乘Yk=X1k*X2k</p><p>  對(duì)Yk進(jìn)行反變換得到時(shí)域卷積結(jié)果y(n)&

22、lt;/p><p>  函數(shù)chongdie(x,h,N)的設(shè)計(jì):</p><p><b>  方案1:</b></p><p>  (1)首先取長(zhǎng)序列x(n)進(jìn)行分段的長(zhǎng)度N,以使其分段后的長(zhǎng)度與較短的相近</p><p> ?。?)確定圓周卷積的周期L</p><p> ?。?)填充序列使得循環(huán)中

23、對(duì)序列的索引不會(huì)超出范圍</p><p><b> ?。?)確定分段數(shù)K</b></p><p> ?。?)對(duì)序列進(jìn)行分段調(diào)用juanji()函數(shù)計(jì)算圓周卷積</p><p><b> ?。?)各段重疊相加</b></p><p>  (7)取出實(shí)際的輸出序列</p><p>

24、;<b>  方案2:</b></p><p> ?。?)首先取圓周卷積的周期L(即進(jìn)行L點(diǎn)的快速傅里葉變換)</p><p>  (2)計(jì)算每一分段的大小N</p><p> ?。?)填充序列使得循環(huán)中對(duì)序列的索引不會(huì)超出范圍</p><p><b> ?。?)計(jì)算分段數(shù)K</b></p&g

25、t;<p>  (5)對(duì)序列進(jìn)行分段調(diào)用juanji()函數(shù)計(jì)算圓周卷積</p><p><b> ?。?)各段重疊相加</b></p><p> ?。?)取出實(shí)際的輸出序列</p><p>  3.2程序設(shè)計(jì)流程圖</p><p>  整體程序包含主程序與卷積函數(shù)、重疊相加函數(shù)兩大部分。函數(shù)juanji

26、()流程圖如下</p><p>  此函數(shù)用于對(duì)X1和X2兩序列進(jìn)行快速傅里葉變換后進(jìn)行乘積,之后再進(jìn)行反變換后恢復(fù)到時(shí)域結(jié)果。</p><p>  chongdie(x,h,N)函數(shù)流程圖如下:</p><p>  方案1: 方案2:</p><p><b>  3.3方案比較&

27、lt;/b></p><p>  方案1和方案2的區(qū)別在于:在方案1中由已知的長(zhǎng)序列x(n)分段大小N、短序列長(zhǎng)度M依據(jù)公式計(jì)算LN+M-1圓周卷積周期L。而在方案2中由已知的圓周卷積周期L、短序列長(zhǎng)度M依據(jù)公式計(jì)算長(zhǎng)序列x(n)的分段大小。</p><p>  比較這兩種方案可以知道,方案1中如果L直接取L=N+M-1,則L的值不一定是2的n次方,而接下來的要進(jìn)行的L點(diǎn)快速傅里葉變

28、換中,L的值需要為2的n次方才能正確計(jì)算。所以方案1的必須要求取恰當(dāng)?shù)腘值以使L點(diǎn)滿足要求。方案2中可以直接取L為恰當(dāng)?shù)闹祻亩鴿M足快速傅里葉變換的要求,所以方案2比方案1的適用范圍更大。</p><p><b>  4 程序代碼</b></p><p><b>  主程序:</b></p><p>  x1=[1,2,3,

29、4,5,5,4,3,2,1];</p><p>  x2=[1,0,1];</p><p><b>  L=8;</b></p><p>  y=chongdie(x1,x2,L);</p><p>  s=1:10;subplot(2,2,1);</p><p>  stem(s,x1)<

30、/p><p>  r=1:3;subplot(2,2,2);</p><p>  stem(r,x2)</p><p>  u=1:13;subplot(2,2,3);</p><p><b>  stem(u,y)</b></p><p>  函數(shù)juanji():</p><p

31、>  function y=juanji(x1,x2,L)</p><p>  if length(x1)>L %如果x1長(zhǎng)度大于L則產(chǎn)生錯(cuò)誤 </p><p>  error('L must not be less than length of x1');</p><p><b>  end &l

32、t;/b></p><p>  if length(x2)>L %如果x2長(zhǎng)度大于L則產(chǎn)生錯(cuò)誤</p><p>  error('L must not be less than length of x2');</p><p><b>  end </b></p><p

33、>  X1k=fft(x1,L); %對(duì)x1進(jìn)行L點(diǎn)FFT計(jì)算</p><p>  X2k=fft(x2,L); %對(duì)x2進(jìn)行L點(diǎn)FFT計(jì)算</p><p>  Yk=X1k.*X2k; %頻域相乘 </p><p>  y=ifft(Yk);

34、 %反變換得卷積結(jié)果</p><p>  if (all(imag(x1)==0))&(all(imag(x2)==0))</p><p>  y=real(y);</p><p><b>  end</b></p><p>  函數(shù)chongdie():</p><p>&

35、lt;b>  方案1:</b></p><p>  function[y]=chongdie(x,h,N)</p><p>  Lenx=length(x); %取x(n)的長(zhǎng)度</p><p>  M=length(h); %取h(n)的長(zhǎng)度</p><p>  

36、L=N+M-1; %計(jì)算圓周卷積的周期L使其不發(fā)生混疊</p><p>  x=[x,zeros(1,N-1)]; %填充序列使得循環(huán)中對(duì)序列的索引不會(huì)超出圍</p><p>  K=floor(Lenx/N);</p><p>  y=zeros(1,Lenx+L-1); %確定分段數(shù)K&l

37、t;/p><p>  for i=0:1:K</p><p>  ix=i*N; </p><p>  x_seg=x(ix+1:ix+N); %將x(n)分段</p><p>  y_seg=juanji(x_seg,h,L); %調(diào)用函數(shù)juanji()計(jì)算圓周卷積</p>&

38、lt;p>  y(ix+1:ix+L)=y(ix+1:ix+L)+y_seg(1:L); %各段重疊相加</p><p><b>  end</b></p><p>  y=y(1:Lenx+M-1); %取出實(shí)際的輸出序列</p><p><b>  方案2:</b></p>

39、;<p>  function[y]=chongdie(x,h,L)</p><p>  Lenx=length(x); %取x(n)的長(zhǎng)度</p><p>  M=length(h); %取h(n)的長(zhǎng)度</p><p>  N=L-M+1;

40、 %計(jì)算分段大小N</p><p>  x=[x,zeros(1,N-1)]; %填充序列使得循環(huán)中對(duì)序列的索引不會(huì)超出圍</p><p>  K=floor(Lenx/N); %確定分段數(shù)K</p><p>  y=zeros(1,Lenx

41、+L-1);</p><p>  for i=0:1:K</p><p><b>  ix=i*N;</b></p><p>  x_seg=x(ix+1:ix+N); %將x(n)分段</p><p>  y_seg=juanji(x_seg,h,L);

42、 %調(diào)用函數(shù)juanji()計(jì)算圓周卷積</p><p>  y(ix+1:ix+L)=y(ix+1:ix+L)+y_seg(1:L); %各段重疊相加</p><p><b>  end</b></p><p>  y=y(1:Lenx+M); %取出實(shí)際的輸出序列</p>

43、<p>  5 程序運(yùn)行結(jié)果與分析</p><p><b>  輸入序列和周期L</b></p><p>  x1=[1,2,3,4,5,5,4,3,2,1];</p><p>  x2=[1,0,1];</p><p><b>  L=8;</b></p><p&

44、gt;  運(yùn)算結(jié)果:124689986421</p><p>  由程序運(yùn)行結(jié)果與線性卷積結(jié)果比較可以知道程序計(jì)算結(jié)果正確的。</p><p><b>  心得體會(huì)</b></p><p>  作為電子信息工程系的學(xué)生,數(shù)字信號(hào)處理這門課程是其他很多課程的基礎(chǔ),所以學(xué)好數(shù)字信號(hào)處理這門課是非常重要的。而MATLAB這款軟件

45、對(duì)數(shù)字信號(hào)處理的建模、編程、分析、實(shí)現(xiàn)有極大的幫助作用,所以我們應(yīng)該掌握使用MATLAB編程來實(shí)現(xiàn)對(duì)數(shù)字信號(hào)的分析處理。</p><p>  此次我得到的課設(shè)題目是:基于重疊相加法圓周卷積的實(shí)現(xiàn)。拿到課設(shè)題目后,我仔細(xì)研究了與題目相關(guān)的原理,包括線性卷積、周期卷積、圓周卷積、重疊相加法、離散傅里葉變換DFT、快速傅里葉變換FFT等原理知識(shí),弄清楚了它們之間的關(guān)系。通過這次課程設(shè)計(jì),我不僅順利完成課程設(shè)計(jì)的要求,而

46、且在課程設(shè)計(jì)過程中通過對(duì)相關(guān)原理的回顧,對(duì)各相關(guān)原理之間的關(guān)系有了脫胎換骨般的認(rèn)識(shí),也意識(shí)到此前學(xué)到的理論知識(shí)是多么的淺薄。</p><p>  在和同組同學(xué)一起討論基于重疊相加法的圓周卷積原理后,我開始了利用MATLAB來實(shí)現(xiàn)這個(gè)功能。在編寫程序的過程中,我查閱了很多有關(guān)MATLAB的編程知識(shí),通過整合所查閱到的編程知識(shí),結(jié)合先前研究的基于重疊相加法的圓周卷積原理,我設(shè)計(jì)了具有此功能的MATLAB函數(shù)。在設(shè)計(jì)時(shí)

47、我遇到了不少的問題,剛開始時(shí)我先設(shè)定分段長(zhǎng)度N,然后由N來求卷積周期L。但是在程序運(yùn)行過程中我發(fā)現(xiàn)算法具有很大的局限性。通過仔細(xì)揣摩這其中的問題,原來是我忽略了FFT運(yùn)算的條件。所以我制定了第二個(gè)方案,先設(shè)定卷積的周期L,然后由L來求分段長(zhǎng)度N,這樣程序的適用范圍就擴(kuò)大了。為了提高程序的適用性,我不斷的對(duì)程序進(jìn)行修改和測(cè)試,以求能夠達(dá)到更好的效果,這個(gè)過程讓我體會(huì)到了編程解決問題的樂趣。</p><p>  通過

48、本次課程設(shè)計(jì),我對(duì)書本知識(shí)有了更深刻的理解,并應(yīng)用課本的理論知識(shí),結(jié)合相關(guān)軟件,設(shè)計(jì)解決問題的算法。從而提高了由知識(shí)轉(zhuǎn)換為技能的能力,提高了自己的實(shí)踐能力。通過與同學(xué)的互相溝通,不僅使各自的知識(shí)得到了擴(kuò)充,而且從中得到了很多的啟示,這次課程設(shè)計(jì)讓人受益匪淺。</p><p><b>  參考文獻(xiàn)</b></p><p>  【1】《數(shù)字信號(hào)處理》,劉泉、闕大順、郭志強(qiáng)

49、編著,電子工業(yè)出版社,2009</p><p>  【2】《信號(hào)與系統(tǒng)》,劉泉,江雪梅編著,高等教育出版社,2006</p><p>  【3】《MATLAB從入門到精通》,周建興、豈興明等編,人民郵電出版社,2008</p><p>  【4】《MATLAB實(shí)用教程》,徐金明、張孟喜、丁濤編,清華大學(xué)出版社,2007</p><p>  【

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論