版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 語音信號濾波去噪</b></p><p> ——使用BOHMAN窗設計的頻率采樣型FIR濾波器</p><p> 學生姓名: 指導老師:</p><p> 摘 要 本課程設計主要內容是,利用窗口設計法設計頻率采樣型FIR濾波器并對加噪語音信號進行濾波去噪處理。仿真平臺為MATLAB7.0,開發(fā)工具是M語
2、言編程。在課程設計中,首先利用Windows下的錄音機工具錄制一段格式為.wav的語音信號,然后在MATLAB中對語音信號進行加噪,并繪制原始語音信號和加噪語音信號的時域和頻域波形,進行頻譜分析以確定所加噪聲頻率,再利用Bohman窗設計FIR濾波器,并檢測是否達到指標,最后使用濾波器對信號進行濾波去噪處理,并通過對比原始信號,加噪信號,濾波去噪信號的時域和頻域波形,或回放語音信號,檢測是否設計成功。通過程序調試及完善,本課程設計濾波后
3、的語音信號與原始語音信號基本一致,即設計的濾波器能夠從含噪信號中濾除單頻噪聲,還原原始信號,達到了設計目的。</p><p> 關鍵詞 課程設計;濾波去噪;FIR濾波器;BOHMAN窗;MATLAB</p><p><b> 1 引 言</b></p><p> 本課程設計主要解決在含噪情況下如何對語音信號進行濾波去噪處理。設計采用B
4、OHMAN窗設計的頻率采樣型FIR濾波器對一段含噪語音信號進行濾波去噪處理。數字濾波器是一種用來過濾時間離散信號的數字系統(tǒng),它是通過對抽樣數據進行數字處理來達到頻域濾波的目的。數字信號處理與模擬信號處理是信號處理的子集。數字信號處理的目的是對真實世界的連續(xù)模擬信號進行測量或濾波。隨著現(xiàn)代通信的數字化,數字濾波器變得更加重要。數字濾波器的種類很多,但總的來說可以分成兩大類,一類是經典濾波器,另一類可稱為現(xiàn)代濾波器。從濾波特性方面考慮,數字
5、濾波器可分為數字高通、數字低通、數字帶通和數字帯阻等濾波器。從實現(xiàn)方法上考慮,將濾波器分成兩種,一種稱為無限脈沖響應濾波器,簡稱IIR濾波器,另一種為FIR濾波器。設計FIR數字濾波器的方法有窗口設計法、頻率采樣法和等波紋最佳逼近法等。[1]</p><p> 1.1 課程設計目的</p><p> 數字信號處理課程設計是數字信號處理課程的重要實踐性環(huán)節(jié),是通信工程一次較全面的工程師能
6、力訓練。</p><p> (1)通過課程設計,加深對數字信號處理理論方面的認識;</p><p> (2)熟悉MALTAB工具軟件的運用,學會用計算機采集語音信號,以及對語音信號進行時域和頻域的分析;</p><p> (3)掌握數字信號處理中FIR濾波器的設計方法和步驟;</p><p> (4)掌握使用MATLAB對信號分析和處
7、理的方法;</p><p> (5)提高實際運用、綜合運用能力以及分析問題、解決問題能力;培養(yǎng)嚴肅認真、實事求是的科學態(tài)度,理論聯(lián)系實際的工作作風和辯證思維能力。</p><p> 1.2 課程設計的要求</p><p> (1)濾波器指標必須符合工程實際。</p><p> (2)設計完后應檢查其頻率響應曲線是否滿足指標。</
8、p><p> (3)處理結果和分析結論應該一致,而且應符合理論。</p><p> (4)獨立完成課程設計并按要求編寫課程設計報告書。</p><p><b> 1.3 設計平臺</b></p><p> 本課程設計使用的設計平臺為MATLAB7.0。</p><p> MATLAB是美國M
9、athWorks公司出品的商業(yè)數學軟件,主要包括MATLAB和Simulink兩大部分。它將數值分析、矩陣計算、科學數據可視化以及非線性動態(tài)系統(tǒng)的建模和仿真等諸多強大功能集成在一個易于使用的視窗環(huán)境中,為科學研究、工程設計以及必須進行有效數值計算的眾多科學領域提供了一種全面的解決方案,并在很大程度上擺脫了傳統(tǒng)非交互式程序設計語言的編輯模式,代表了當今國際科學計算軟件的先進水平。MATLAB在數學類科技應用軟件中在數值計算方面首屈一指。M
10、ATLAB可以進行矩陣運算、繪制函數和數據、實現(xiàn)算法、創(chuàng)建用戶界面、連接其他編程語言的程序等,主要應用于工程計算、控制設計、信號處理與通訊、圖像處理、信號檢測、金融建模設計與分析等領域。MATLAB的基本數據單位是矩陣,它的指令表達式與數學、工程中常用的形式十分相似,故用MATLAB來解算問題要比用其他語言完成相同的事情簡捷得多,并且MATLAB也吸收了像Maple等軟件的優(yōu)點,使MATLAB成為一個強大的數學軟件。在新的版本中也加入了
11、對C,F(xiàn)ORTRAN,C++,JAVA的支持??梢灾苯诱{用,用戶也可以將自己編寫的實用程序導入到MA</p><p><b> 2 設計原理</b></p><p> 2.1 FIR濾波器</p><p> FIR(Finite Impulse Response)濾波器:有限長單位沖激響應濾波器,是數字信號處理系統(tǒng)中最基本的元件,它可以在
12、保證任意幅頻特性的同時具有嚴格的線性相頻特性,同時其單位抽樣響應是有限長的,因而濾波器是穩(wěn)定的系統(tǒng)。因此,F(xiàn)IR濾波器在通信、圖像處理、模式識別等領域都有著廣泛的應用。</p><p> FIR濾波器相對于IIR濾波器具有易實現(xiàn)線性相位,系統(tǒng)總是穩(wěn)定的,允許設計多通帶(或多阻帶)濾波器的優(yōu)點,F(xiàn)IR濾波器主要有4種結構,直接型,級聯(lián)型,線性相位型,頻率采樣型,與IIR結構相比,結構是相對簡單的。FIR系統(tǒng)濾波器
13、的缺點在于它的性能不如同樣階數的IIR濾波器,不過由于數字計算硬件的飛速發(fā)展,這一點已經不成為問題。再加上引入計算機輔助設計,F(xiàn)IR濾波器的設計也得到極大的簡化。[3] FIR濾波器的設計方法有多種,如窗口設計法,頻率采樣法,最優(yōu)等波紋設計法等。隨著MATLAB軟件尤其是MATLAB的信號處理箱工具的不斷完善,不僅數字濾波器的計算機輔助設計有了可能,而且還可以使設計達到最優(yōu)化。</p><p> 有限長單位沖激
14、響應(FIR)濾波器有以下特點:</p><p> (1) 系統(tǒng)的單位沖激響應h (n)在有限個n值處不為零</p><p> (2) 系統(tǒng)函數H(z)在|z|>0處收斂,極點全部在z = 0處(因果系統(tǒng))</p><p> (3) 結構上主要是非遞歸結構,沒有輸出到輸入的反饋,但有些結構中(例如頻率抽樣結構)也包含有反饋的遞歸部分。</p>
15、<p> 設FIR濾波器的單位沖激響應h (n)為一個N點序列,0 ≤ n ≤N —1,則濾波器的系統(tǒng)函數為</p><p> H(z)=∑h(n)*z-n (2-1)
16、 </p><p> 就是說,它有(N—1)階極點在z = 0處,有(N—1)個零點位于有限z平面的任何位置。</p><p> FIR濾波器的設計分三步完成:</p><p> (1)技術要求:在設計濾波器之前,必須要有某些技術要求。這些技術要求是由用途決定的。</p><p> (2)近似:一旦技術要求確定之后,就要用
17、已學過的各種概念和數學提供一種濾波器的表述,它接近于所給出的一組技術要求。這一步是屬于濾波器設計的范疇。</p><p> (3)實現(xiàn):上面一步的結果是一個濾波器的表述,它可能是一個差分方程的形式,或者是某一系統(tǒng)函數H(z),或者是某一脈沖響應h(n)。依據這個表述要用硬件實現(xiàn)這個濾波器,或者在一臺計算機上通過軟件實現(xiàn)。[4]</p><p><b> 2.2 窗口設計法&l
18、t;/b></p><p> 窗口設計的基本思想是要選取某一種合適的理想頻率選擇性濾波器(這種濾波器總是有一個非因果,無限長的脈沖響應),然后將它的脈沖響應截斷(或加窗)以得到一個線性相位和因果的FIR濾波器。因此,這種方法的重點在于選擇某種恰當的窗函數和一種適合的理想濾波器?,F(xiàn)在用Hd(ejw)代表一理想頻率選擇性濾波器,它在整個通帶內有單位幅度增益和線性相位特性,而阻帶內具有零響應。</p>
19、;<p> 一理想帶寬為wc<π的LPF由下式給出為</p><p> 1e-jw , |w|≤wc</p><p> Hd(ejw)= (2-2)</p><p> 0 , wc<|w|≤ π </p><p>
20、 其中wc 也稱為截止頻率,α稱為樣本延遲(注意,根據DTFT性質,e-jαw意味者在正n方向的位移或延遲)。這個濾波器的脈沖響應具有無限長,對Hd(ejw)做傅里葉變換獲得理想濾波器的單位脈沖響應hd(n)。注意hd(n)是關于α對稱的,這一點對線性相位FIR濾波器來說是有用的。</p><p> 為了從hd(n)得到一個FIR濾波器必須在hd(n)兩邊將它截斷。為了得到一個長度為M的因果且線性相位FIR濾波
21、器h(n),就必須有</p><p> hd(n) , 0≤n≤M-1</p><p> h(n)= 和α= (2-3)</p><p> 0 , 其余n </p><p> 這種運算稱為“加窗”。一般來說,h(n)可當作是由hd(n)和某一窗函
22、數w(n)相乘而得到的。</p><p><b> 其中</b></p><p> 在0≤n≤M-1內關于α的某個對稱函數</p><p> w(n)= (2-4)</p><p><b> 0 </b
23、></p><p> 根據如何定義上面的w(n),可以得到不同的窗函數設計。[5]</p><p> 用窗口設計法設計FIR濾波器的主要設計步驟為:</p><p> (1)對Hd(ejw)做傅里葉變換獲得理想濾波器的單位脈沖響應hd(n)。</p><p> hd(n)=
24、(2-5)</p><p> (2)由性能指標確定窗函數w(n)和窗口長度N。</p><p> (3)求得實際濾波器的單位脈沖響應h(n)。 </p><p> h(n)=hd(n)w(n) (2-6)</p><p> 窗口設計法的基本思想:對于給定的濾波器技術要求,選
25、擇濾波器長度M和具有最窄主瓣寬度和盡可能最小的旁瓣衰減的某個窗函數w(n)。窗函數頻譜中的主瓣寬度較窄,獲得的過渡帶較陡;旁瓣衰減越大,阻帶的衰減越快。</p><p> 表2-1 常見窗函數性能小結</p><p> 過渡帶寬Δw </p><p> 窗函數名
26、 最小阻帶衰減</p><p> 近似值 準確值 </p><p> 矩形 21dB</p><p> Bartlett 25dB</p><
27、p> Hanning 44dB</p><p> Hamming 53dB</p><p> Blackman 74dB</p><p&g
28、t; 2.3 BOHMAN窗</p><p> 本課程設采用BOHMAN窗,通過查閱資料和實際調試,BOHMAN窗的過渡帶寬定為,最小阻帶衰減為51.5dB。</p><p> 當運用計算機實現(xiàn)工程測試信號處理時,不可能對無限長的信號進行測量和運算,而是取其有限的時間片段進行分析。做法是從信號中截取一個時間片段,然后用觀察的信號時間片段進行周期延拓處理,得到虛擬的無限長的信號,然后就
29、可以對信號進行傅里葉變換、相關分析等數學處理。無線長的信號被截斷以后,其頻譜發(fā)生了畸變,原來集中在f(0)處的能量被分散到兩個較寬的頻帶中去了(這種現(xiàn)象稱之為頻譜能量泄漏)。[6]</p><p> Bohman窗對應的Bohmanwin函數定義源程序如下:</p><p> function w = bohmanwin(n)</p><p> error(n
30、argchk(1,1,nargin));</p><p> [n,w,trivialwin] = check_order(n);</p><p> if trivialwin, return, end;</p><p> q = abs(linspace(-1,1,n));</p><p> w = [ 0; ((1-q(2:end-
31、1)).*cos(pi*q(2:end-1))+(1/pi)*sin(pi*q(2:end-1)))'; 0];</p><p> 當n=64時,Bohman窗如圖2-1所示。
32、 </p><p> 圖2-1 Bohwin窗</p><p><b> 3 設計步驟</b></p><p&g
33、t;<b> 3.1 設計流程圖</b></p><p> 語音信號濾波去噪——使用BOHMAN窗設計的頻率采樣型FIR濾波器的設計流程圖如圖3-1所示。</p><p><b> 開始</b></p><p> 錄制一段格式為.wav的語音信號</p><p> 利用函數wavread對
34、語音信號進行采樣</p><p><b> 對語音信號進行加噪</b></p><p> 繪制加噪前后語音信號的時域和頻域波形</p><p> 使用BOHMAN窗設計FIR濾波器</p><p> 繪制濾波器的頻率響應</p><p> 用濾波器對信號進行濾波</p>&
35、lt;p> 比較原始語音信號和濾波前后語音信號的波形及頻譜</p><p><b> 回放語音信號</b></p><p> 計算頻率采樣型FIR濾波器系數</p><p> 繪制頻率采樣型FIR濾波器的結構圖并填好系數</p><p><b> 結束</b></p>
36、<p> 圖3-1 設計流程圖</p><p> 3.2 錄制語音信號</p><p> 通過點擊開始/程序/附件/娛樂/錄音機,打開Windows下的錄音機工具,如圖3.2所示,然后錄制語音信號“大家好,我是***”,時間在2-3 s左右。點擊文件/另存為,將文件名命名為yuyin.wav,并保存。然后在Matlab軟件平臺下,利用函數wavread對語音信號進行采樣,記
37、住采樣頻率和采樣點數。采集完成后在信號中加入一個頻率為9000Hz的單頻噪聲。</p><p><b> 圖3-2 錄音機</b></p><p> 為了使后面濾波器的設計更精確,可對語音信號進行一些調整。</p><p> 首先通過錄音機打開語音信號,點擊文件/屬性,如圖3-3所示。再點擊按鈕進入聲音選定窗口,并將屬性改為22.050k
38、Hz,如圖3-4所示,點擊確定并保存調整后的語音信號。</p><p><b> 圖3-3 聲音屬性</b></p><p><b> 圖3-4 聲音選定</b></p><p><b> 對應程序如下:</b></p><p> >> [x,fs,bits
39、]=wavread('F:\yuyin.wav'); % 輸入參數為文件的全路徑和文件名,輸出的第一個參數是每個樣本的值,fs是生成該波形文件時的采樣率,bits是波形文件每樣本的編碼位數。</p><p> >> sound(x,fs,bits); % 按指定的采樣率和每樣本編碼位數回放</p><p> >> N=length(x);
40、 % 計算信號x的長度</p><p> >> fn=9000; % 單頻噪聲頻率,此參數可改</p><p> >> t=0:1/fs:(N-1)/fs; % 計算時間范圍,樣本數除以采樣頻率</p><p> >> x=x(:,1)'; % 將雙聲道轉為單聲道</p><p>
41、; >> y=x+0.1*sin(fn*2*pi*t); % 加噪聲</p><p> >> sound(y,fs,bits); % 應該可以明顯聽出有尖銳的單頻嘯叫聲</p><p> >> fs % 輸出采樣頻率</p><p> 輸出fs=22050Hz大于被采樣信號頻率的兩倍,采樣之后的數字信號完整
42、地保留了原始信號中的信息。</p><p> 然后對語音號進行快速傅里葉變換,得到信號的頻譜特性。</p><p><b> 對應程序如下:</b></p><p> >>X=abs(fft(x)); Y=abs(fft(y)); % 對原始信號和加噪信號進行fft變換,取幅度譜</p><p>
43、 >>X=X(1:N/2); Y=Y(1:N/2); % 截取前半部分</p><p> >>deltaf=fs/N; % 計算頻譜的譜線間隔</p><p> >>f=0:deltaf:fs/2-deltaf; % 計算頻譜頻率范圍</p><p> 最后畫出加噪前后語音信號的時域
44、和頻域波形,便于分析設計濾波器。如圖3-3所示。</p><p> 通過圖3-5,可以明顯觀察到,在時域波形圖中,加噪后的語音信號明顯被噪聲遮蓋了許多,在頻域圖中,在頻率為9000Hz處,有一個尖脈沖,也就是噪聲。</p><p> 圖3-5 加噪前后語音信號的時域和頻域波形</p><p><b> 3.3 濾波器設計</b></
45、p><p> 本課程設計利用BOHMAN窗實現(xiàn)FIR濾波器的設計。由于加入的單頻噪聲頻率fn為9000Hz,根據加噪前后語言信號的幅度譜圖分析可知,語言信號的有效帶寬0Hz—5000Hz左右,所以可設計一低通濾波器來濾除噪聲。由于BOHMAN窗的過渡帶寬定為,能提供的最小阻帶衰減為51.5dB。所以阻帶衰減As設置為一個適當小于51.5dB的參數。通帶波紋Rp設置為1dB。</p><p>
46、 設置的低通濾波器的性能指標如下:</p><p> fp=4000Hz, fo=8800Hz, Rp=1dB, As=45dB</p><p> 其中fp為通帶截止頻率,fo為阻帶截止頻率, Rp為通帶波紋,As為阻帶衰減。確定好濾波器的參數后,先計算出濾波器的階數M,然后調用自編ideal_lp函數計算理想低通濾波器的脈沖響應hd,再調用bohmanwin(M)函數產生M階的BO
47、HMAN窗,并計算出實際濾波器脈沖響應,最后調用自編freqz_m函數計算出濾波器的頻率特性。最后計算出真正的阻帶衰減As,和真正的通帶波紋Rp,檢測設計的濾波器是否符合要求。</p><p> 得出的M =24,Rp =0.0276,As = 49。所以濾波器的長度M=24,真正的通帶波紋Rp是0.0276dB,小于設置的指標1dB,真正的阻帶衰減As是49dB,大于設置的指標45dB,小于最小阻帶衰減51.
48、5dB。所以設計的低通濾波器滿足要求。</p><p> 最后畫出該低通濾波器的頻譜特性圖。如圖3-6所示。</p><p> 圖3-6濾波器的頻譜圖</p><p> 濾波器設計過程對應的程序如下:</p><p> >> Rp=1;As=45;fs=22050; fp=4000;fo=8800; % 低通濾波器設計指
49、標</p><p> >> wp=fp/fs*2*pi;ws=fo/fs*2*pi;tr_width=ws-wp; % 將Hz為單位的模擬頻率換算為rad為單位的數字頻率</p><p> >> M=ceil(10*pi/tr_width)+1 % 計算BOHMAN窗設計該濾波器時需要的階數</p><p> >> n=
50、[0:1:M-1]; % 定義時間范圍</p><p> >> wc=(ws+wp)/2;</p><p> >> hd=ideal_lp(wc,M); % 調用自編函數計算理想低通濾波器的脈沖響應</p><p> >> w_bohmanwin=(bohmanwin(M))'; % 產生M階的BOHMAN窗&
51、lt;/p><p> >> h=hd.*w_bohmanwin; % 計算實際濾波器脈沖響應</p><p> >> [db,mag,pha,grd,w]=freqz_m(h,[1]); % 調用自編函數計算濾波器的頻率特性</p><p> >> delta_w=2*pi/1000;</p><p&g
52、t; >> Rp=-(min(db(1:1:wp/delta_w+1))) % 真正的通帶波紋</p><p> >> As=-round(max(db(ws/delta_w+1:1:501))) % 真正的阻帶衰減</p><p> 3.4 信號濾波處理</p><p> 將設計好的FIR低通濾波器濾波器對信號進行濾波去噪處理。
53、</p><p><b> 對應程序如下:</b></p><p> >> y_fil=filter(h,1,y);% 用設計好的濾波器對y進行濾波</p><p> >> Y_fil=fft(y_fil);Y_fil=Y_fil(1:N/2); % 計算頻譜取前一半</p><p><
54、;b> 3.5 結果分析</b></p><p> 為了分析濾波器是否設計成功,首先用MATLAB繪制出原始信號,加噪信號,濾波去噪信號的時域波形和頻譜,如圖3-7所示。通過觀察和分析圖像,濾波后的語音信號時域波形與原始語音信號時域波形基本一致,位于幅度譜9000Hz處的單頻噪聲被濾除,與原始語音信號幅度譜基本一致。</p><p> 圖3-7 原始信號,加噪信號,
55、濾波去噪信號的時域波形和頻譜</p><p> 然后通過回放原始語音信號,加噪語音信號,去噪語音信號,對比發(fā)現(xiàn)去噪語音信號與原始語音信號基本一致,即濾波器濾除了噪聲的干擾。</p><p><b> 對應程序如下:</b></p><p> >> sound(x,fs,bits); % 播放原始語音信號</p>
56、<p> >> sound(y,fs,bits); % 播放加噪語音信號</p><p> >> sound (y_fil,fs,bits); % 播放去噪語音信號</p><p> 通過對比分析可得出結論,本課程設計濾波后的語音信號與原始語音信號基本一致,即設計的濾波器能夠從含噪信號中濾除單頻噪聲,還原了原始信號,達到了設計目的。<
57、/p><p> 3.6 繪制濾波器結構圖</p><p> 本課程設計為頻率采樣型FIR濾波器,先求出濾波器的系數,</p><p><b> 對應語句如下:</b></p><p> >> [C,B,A]=dir2fs(h) % 計算濾波器系數</p><p> 得出濾波器的
58、系數為:</p><p><b> C =</b></p><p><b> 1.9987</b></p><p><b> 1.9987</b></p><p><b> 1.9965</b></p><p><b&
59、gt; 1.9947</b></p><p><b> 1.9577</b></p><p><b> 1.6597</b></p><p><b> 0.9734</b></p><p><b> 0.3059</b></p&
60、gt;<p><b> 0.0344</b></p><p><b> 0.0046</b></p><p><b> 0.0021</b></p><p><b> 0.9996</b></p><p><b> 0.0
61、000</b></p><p><b> B =</b></p><p> -0.9914 0.9914</p><p> 0.9659 -0.9659</p><p> -0.9239 0.9239</p><p> 0.8660 -0.8660<
62、/p><p> -0.7934 0.7934</p><p> 0.7071 -0.7071</p><p> -0.6088 0.6088</p><p> 0.5000 -0.5000</p><p> -0.3827 0.3827</p><p> 0.2
63、588 -0.2588</p><p> -0.1305 0.1305</p><p><b> A =</b></p><p> 1.0000 -1.9319 1.0000</p><p> 1.0000 -1.7321 1.0000</p><p> 1
64、.0000 -1.4142 1.0000</p><p> 1.0000 -1.0000 1.0000</p><p> 1.0000 -0.5176 1.0000</p><p> 1.0000 -0.0000 1.0000</p><p> 1.0000 0.5176 1.000
65、0</p><p> 1.0000 1.0000 1.0000</p><p> 1.0000 1.4142 1.0000</p><p> 1.0000 1.7321 1.0000</p><p> 1.0000 1.9319 1.0000</p><p>
66、1.0000 -1.0000 0</p><p> 1.0000 1.0000 0</p><p> 繪制的頻率采樣型FIR濾波器如圖3-8所示。</p><p> 圖3-8 頻率采樣型FIR濾波器結構圖</p><p> 4 出現(xiàn)的問題及解決方法</p><p>
67、最開始遇到的問題主要是對理論知識不夠熟悉。</p><p> 由于數字信號處理是上個學期學習的課程,所以理論知識對我來說已經有點陌生了,最開始拿到課程設計題目時不知道從哪下手,在復習并掌握了FIR濾波器,窗口設計法相關的知識點后,我對本課程設計有了一定了理解。</p><p> 對語音信號加噪時遇到的問題:</p><p> 開始我將單頻噪聲fn設置為2000
68、Hz,繪制出加噪前后語音信號的時域和頻域波形后,發(fā)現(xiàn)語言信號的有效帶寬從0Hz—5000Hz左右噪聲處于語音信號的有效頻帶范圍內,要濾除噪聲就要設置一個帶阻濾波器,帶阻濾波器相對于低通濾波器來說較為復雜,經過多次調試后,將fn設置為9000Hz,所以本課程設計中濾波器設置為低通濾波器。</p><p> 由于坐標設置不適當,最初顯示的加噪前后語音信號的時域和頻域波形對比不是很明顯,對坐標進行調整后,通過對比加噪
69、前后的頻域圖,可以明顯觀察到在頻率為9000Hz處,有一個尖脈沖,也就是噪聲。</p><p> 設計濾波器時遇到的問題:</p><p> 由于本課程設計采用的是BOHMAN窗,教材中并沒有介紹,所以在設計時對我BOHMAN窗的性能并不了解,課程設計提供的資料中,BOHMAN窗的過渡帶寬為,最小阻帶衰減為51.5dB。但是運行程序后得出的真正的通帶波紋Rp和真正的阻帶衰減As是總是不
70、達標,濾波器不符合設計要求,老師建議將過渡帶寬增大,經過多次調試后,最終將過渡帶寬定為,設計的低通濾波器也達到了指標。</p><p> 最初得到的BOHMAN窗的階數M為456,由于要畫出濾波器的結構圖,所以階數過高。老師建議增大濾波器的過渡帶寬,或者對錄制的語音信號的屬性進行適當的調整。最后將語音信號的屬性調整為22.050kHz。運行程序后最終BOHMAN窗的階數M減小為24。</p>&l
71、t;p> 為了盡量減少BOHMAM窗的階數,減小M的值,低通濾波器的過渡帶寬參數設置的過大,加噪語音信號通過低通濾波器后不能將噪聲完全濾除,經過多次調試后將參數設置為了合適的值,能完全濾除噪聲。</p><p> 繪制頻率采樣型FIR濾波器時遇到的問題:</p><p> 雖然M值調至為了較小的值,但是對于繪制濾波器的結構圖來說還是較大,而且我對word繪圖比較陌生,所以繪制濾
72、波器時花費了較長的時間。</p><p><b> 程序中存在的問題:</b></p><p> 程序中有一些警告存在,多次修改調試程序還是沒有解決,最后尋求了老師的幫助,老師解釋到如果不影響整個程序的運行和濾波器的設計效果可以不多做考慮。</p><p> 編寫報告時出現(xiàn)的問題:</p><p> 寫報告時,主
73、要是沒有認真檢查,存在較多的格式問題,報告內容也不夠完善,經過老師的檢查后,查出了較多的漏洞,對報告進行修正后,報告的內容變的更為充實和準確。</p><p><b> 5 結束語</b></p><p> 兩周的課程設計說長不長說短不短,如果好好利用,我們不僅可以鞏固學過的知識,也能拓寬自己的視野,提升自己的能力。從一開始的無從下手,到最后的自我提升,無可否認,
74、這是對我們自身能力的重新認識和提升挑戰(zhàn)。</p><p> 數字信號處理是通信、電子、信息領域中最重要的專業(yè)課之一,數字信號處理對于我們通信工程的學生來說是一門很重要的科目,不僅僅因為它涵蓋了通信工程的許多理論知識,是考研的科目,而且其實踐性很強。</p><p> 數字信號處理的目的是對真實世界的連續(xù)模擬信號進行測量或濾波。因此在進行數字信號處理之前需要將信號從模擬域轉換到數字域,這
75、通常通過模數轉換器實現(xiàn)。而數字信號處理的輸出經常也要變換到模擬域,這是通過數模轉換器實現(xiàn)的。數字信號處理的算法需要利用計算機或專用處理設備如數字信號處理器(DSP)和專用集成電路(ASIC)等。數字信號處理技術及設備具有靈活、精確、抗干擾強、設備尺寸小、造價低、速度快等突出優(yōu)點,這些都是模擬信號處理技術與設備所無法比擬的。數字信號處理的核心算法是離散傅里葉變換(DFT),是DFT使信號在數字域和頻域都實現(xiàn)了離散化,從而可以用通用計算機處
76、理離散信號。而使數字信號處理從理論走向實用的是快速傅里葉變換(FFT),F(xiàn)FT的出現(xiàn)大大減少了DFT的運算量,使實時的數字信號處理成為可能、極大促進了該學科的發(fā)展。</p><p> 數字信號處理課程設計也讓我受益匪淺,通過此次課程設計,讓我更深入的了解了語音信號濾波去噪,窗口設計法設置FIR濾波器的相關知識,注意到很多以前沒有注意到的細節(jié),學到了很多在書本上所沒有學到過的知識。從一個小模塊設計到具有一定功能的
77、完整模塊設計,從單個小問題的判斷調試到整體化模塊的分析思維,本次課程設計不但使我對數字信號處理了解得更透徹,也使我認識到理論當與實際相聯(lián)系時才能使它的指導性充分地體現(xiàn)出來。</p><p> 當然,在設計過程中或多或少的遇到了一些問題,但在老師和同學的幫助下找出了原因所在。更培養(yǎng)了我利用自己的知識解決問題的能力。讓我意識到將理論與實際結合起來的重要性,只有理論知識是遠遠不夠的,只有把所學的理論知識與實踐相結合起
78、來,從理論中得出結論,才能將知識為我所用,從而運用到實際生活中,提高自己的實際動手能力和獨立思考的能力。這次課程設計也我意識到遇到問題不要一味的依賴于老師,還可以通過上網,去圖書館查找資料解決問題,這樣不僅提高了自己解決問題的能力,也更容易掌握知識。</p><p> 俗話說柴多火焰高,如果只憑自己的知識,我會浪費許多的時間和精力,可是滴水成海,在同學和老師的幫助下,我不僅把學到的知識運用的課程設計中,還體會到
79、設計成功后帶來的成就感。在本次課程設計中,特別感謝各位老師在本次課程設計中對我的細心指導,讓我順利完成了課程設計。</p><p><b> 參考文獻</b></p><p> [1] 高西全,丁玉美,闊永紅.數字信號處理——原理、實現(xiàn)及應用.北京:電子工業(yè)出版社,2009</p><p> [2] 張圣勤.MATLAB7.0實用教材.北
80、京:機械工程出版社,2008</p><p> [3] 綠波杰能.FIR濾波器.百度文庫:http://baike.baidu.com/view/2908166.htm,2013-2-27</p><p> [4] 張立材, 王民.數字信號處理.北京:人民郵電出版社,2008</p><p> [5] 維納·K·英格爾,約翰·G&
81、#183;普羅克斯.劉樹棠.數字信號處理(MATLAB版).西安:西安交通大學出版社,2008</p><p> [6] 趙紅怡.數字信號處理及其MATLAB實現(xiàn). 北京:化學工業(yè)出版社,2002</p><p> 附錄:語音信號濾波去噪設計源程序清單 </p><p> % 程序名稱:voicenoisefilter.m</p>&l
82、t;p> % 程序功能:采用基于BOHMAN窗的窗口設計法,設計FIR濾波器對含噪語音進行濾波去噪處理。</p><p><b> % 程序作者:王羚</b></p><p> % 最后修改日期:2013-3-5</p><p> %(1)對原始語音信號加噪</p><p> [x,fs,bits]=wa
83、vread('F:\yuyin.wav'); % 輸入參數為文件的全路徑和文件名,輸出的第一個參數是每個樣本的值,fs是生成該波形文件時的采樣率,bits是波形文件每樣本的編碼位數。</p><p> sound(x,fs,bits); % 按指定的采樣率和每樣本編碼位數回放</p><p> N=length(x); % 計算信號x的長度</p>
84、<p> fn=9000; % 單頻噪聲頻率,此參數可改</p><p> t=0:1/fs:(N-1)/fs; % 計算時間范圍,樣本數除以采樣頻率</p><p> x=x(:,1)'; % 將雙聲道轉為單聲道</p><p> y=x+0.1*sin(fn*2*pi*t); % 加噪聲</p>&l
85、t;p> sound(y,fs,bits); % 應該可以明顯聽出有尖銳的單頻嘯叫聲</p><p> fs % 輸出采樣頻率</p><p> %(2)畫出加噪前后語音信號的時域和頻域波形</p><p> X=abs(fft(x)); Y=abs(fft(y)); % 對原始信號和加噪信號進行fft變換,取幅度譜</p>
86、<p> X=X(1:N/2); Y=Y(1:N/2); % 截取前半部分</p><p> deltaf=fs/N; % 計算頻譜的譜線間隔</p><p> f=0:deltaf:fs/2-deltaf; % 計算頻譜頻率范圍</p><p> magX=abs(X);magY=abs(Y);<
87、/p><p> subplot(2,2,1);plot(t,x);grid</p><p> xlabel('時間(單位: s)');ylabel('幅度');title('原始語音信號')</p><p> subplot(2,2,2);plot(f,magX);grid</p><p>
88、 xlabel('頻率(單位: Hz)');ylabel('幅度譜');title('語音信號幅度譜圖')</p><p> subplot(2,2,3);plot(t,y);grid</p><p> xlabel('時間(單位: s)');ylabel('幅度');title('加入單頻干擾后的
89、語音信號')</p><p> subplot(2,2,4);plot(f,magY);grid</p><p> xlabel('頻率(單位: Hz)');ylabel('幅度譜');title('加入干擾后的語音信號幅度譜圖')</p><p> % (3)設置低通濾波器</p><
90、;p> Rp=1;As=45;fs=22050; fp=4000;fo=8800; % 低通濾波器設計指標</p><p> wp=fp/fs*2*pi;ws=fo/fs*2*pi;tr_width=ws-wp; % 將Hz為單位的模擬頻率換算為rad為單位的數字頻率</p><p> M=ceil(10*pi/tr_width)+1 % 計算BOHMAN窗設計該濾波器時
91、需要的階數</p><p> n=[0:1:M-1]; % 定義時間范圍</p><p> wc=(ws+wp)/2;</p><p> hd=ideal_lp(wc,M); % 調用自編函數計算理想低通濾波器的脈沖響應</p><p> w_bohmanwin=(bohmanwin(M))'; % 產生M階的BOHMA
92、N窗</p><p> h=hd.*w_bohmanwin; % 計算實際濾波器脈沖響應</p><p> [db,mag,pha,grd,w]=freqz_m(h,[1]); % 調用自編函數計算濾波器的頻率特性</p><p> delta_w=2*pi/1000;</p><p> Rp=-(min(db(1:1:wp/de
93、lta_w+1))) % 真正的通帶波紋</p><p> As=-round(max(db(ws/delta_w+1:1:501))) % 真正的阻帶衰減</p><p> %(4)畫出濾波器的頻譜特性圖</p><p> subplot(2,2,1);plot(w/pi,db);grid on;</p><p> xlabel
94、('w/pi');ylabel('dB');title('濾波器幅度響應圖')</p><p> subplot(2,2,2);plot(w/pi,mag);grid on;</p><p> xlabel('w/pi');ylabel('幅度mag');title('濾波器幅度響應圖')&
95、lt;/p><p> subplot(2,2,3);plot(w/pi,pha);grid on;</p><p> xlabel('w/pi');ylabel('相位mag');title('濾波器相位響應圖')</p><p> subplot(2,2,4);plot(n,hd);grid on;</p&g
96、t;<p> xlabel('n');ylabel('h(n)');title('濾波器脈沖響應圖')</p><p> %(5)用濾波器濾波器對信號進行濾波去噪處理。</p><p> y_fil=filter(h,1,y);% 用設計好的濾波器對y進行濾波</p><p> Y_fil=fft
97、(y_fil);Y_fil=Y_fil(1:N/2); % 計算頻譜取前一半</p><p> %(6)畫出原始信號,加噪信號,濾波去噪信號的時域波形和頻譜</p><p> subplot(3,2,1);plot(t,x); grid on</p><p> xlabel('時間t(單位: s)');ylabel('幅度');
98、title('原始語音信號時域波形');</p><p> subplot(3,2,2);plot( f,X); grid on</p><p> xlabel('頻率f(單位: Hz)');ylabel('幅度');title('原始語音信號幅度譜'); </p><p> subplot(3,
99、2,3);plot(t,y); grid on</p><p> xlabel('時間t(單位: s)');ylabel('幅度');title('加干擾語音信號時域波形');</p><p> subplot(3,2,4);plot(f,Y); grid on</p><p> xlabel('頻率f(
100、單位: Hz)');ylabel('幅度');title('加干擾語音信號幅度譜'); </p><p> subplot(3,2,5);plot(t,y_fil);grid on</p><p> xlabel('時間t(單位: s)');ylabel('幅度');title('濾波后語音信號時域波形
101、39;); </p><p> subplot(3,2,6);plot(abs(f),abs(Y_fil));grid on</p><p> xlabel('頻率f(單位: Hz)');ylabel('幅度');title('濾波后語音信號幅度譜'); </p><p> %(7)回放原始語音信號,加噪前后語音
102、信號</p><p> sound(x,fs,bits); % 播放原始語音信號</p><p> sound(y,fs,bits); % 播放加噪語音信號</p><p> sound (y_fil,fs,bits); % 播放去噪語音信號</p><p> %(8)計算濾波器系數</p><p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 課程設計--語音信號濾波去噪
- 語音信號的fir濾波器處理課程設計
- 課程設計報告---拉弦音樂濾波去噪-使用矩形窗設計的fir濾波器
- 基于tms320c6713語音信號濾波去噪——使用barthannwin設計的fir濾波器
- dsp課程設計--語音信號濾波去噪—使用脈沖響應不變法設計的巴特沃斯濾波器
- 數字信號處理課程設計--語音信號濾波去噪
- 語音信號去噪 ——數字濾波器的設計
- 基于matlab數字濾波器設計——語音信號去噪
- 《數字信號處理》課程設計--fir窗函數濾波器的設計
- 數字信號處理課程設計---使用布萊克曼窗設計的fir濾波器
- 語音信號的濾波課程設計
- 語音濾波器課程設計--語音濾波器
- fir低通濾波器加窗分析課程設計
- fir帶通濾波器課程設計
- fir帶阻濾波器課程設計
- 基于matlab的語音信號濾波去噪
- dsp課程設計-fir濾波器設計
- dsp課程設計-fir濾波器設計
- fir帶通濾波器課程設計
- dsp課程設計---fir濾波器設計
評論
0/150
提交評論