版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 本科畢業(yè)論文(設計)</p><p> 論文題目: 利用MATLAB平臺實現 </p><p> 少量字的語音識別功能 </p><p><b> 目 錄</b></p><p><b> 引言4</b></p>&
2、lt;p> 1.語音識別簡介5</p><p> 1.1語音識別系統的分類5</p><p> 1.2語音識別系統的基本構成5</p><p> 2.語音識別參數6</p><p> 2.1線性預測系數(LPC)6</p><p> 2.2線性預測倒譜系數(LPCC)8</p>
3、<p> 2.3 MFCC系數8</p><p> 2.4參數計算流程9</p><p> 3.DTW算法11</p><p> 3.1 DTW算法原理11</p><p> 3.2 DTW的高效算法14</p><p> 4.HMM算法16</p><p>
4、; 4.1 HMM的原理16</p><p> 4.2 HMM的前向概率和后向概率17</p><p> 4.3識別算法——Viterbi解碼19</p><p> 4.4 baum-welch算法20</p><p> 5.實驗及總結23</p><p> 5.1 實驗準備以及步驟23<
5、/p><p> 5.2 實驗結果及討論25</p><p> 5.3 實驗結論29</p><p><b> 參考文獻30</b></p><p><b> 引 言</b></p><p> 自上世紀80年代開始,語音識別技術的研究進入了一個蓬勃發(fā)展的時期,一些商
6、用系統也從實驗室進入市場。然而,在實際的應用中,由于各種干擾因素導致的測試條件與訓練環(huán)境的不匹配,系統的性能往往會收到極大的影響。因此提高語音識別系統的性能就成為了語音識別技術真正走向實用化的關鍵課題。</p><p> 語音識別是以聲音作為研究對象它是語音信號處理的一個重要研究方向,是模式識別的一個分支涉及到生理學、心理學、語言學、計算機科學以及信號處理等諸多領域,甚至還涉及到人的體態(tài)語言(如人在說話時的表情
7、、手勢等行為動作可幫助對方理解),其最終目標是實現人與機器進行自然語言通信。本文研究了漢語語音識別技術及其實現方法。論文首先分析了語音信號預處理問題。對MFCC倒譜系數在語音識別中的運用做了詳細介紹。其次研究了基于DTW的語音識別系統,針對DTW算法中系統識別性能過分依賴于端點檢測、動態(tài)規(guī)劃的計算量太大等缺陷,分別提出了快速DTW算法和端點松動的DTW算法,仿真結果比較理想。繼而研究了基于HMM的語音識別系統。針對HMM在實際應用中的優(yōu)
8、化計算問題,包括初始模型選取,定標等進行了深入的分析與探討。針對傳統定標仍能溢出的問題,給出了無溢出的參數重估公式。</p><p> 第一章 語音識別簡介</p><p> 1.1語音識別系統的分類</p><p> 語音識別是近年來十分活躍的一個研究領域。在不遠的將來,語音識別技術有可能作為一種重要的人機交互手段,輔助甚至取代傳統的鍵盤、鼠標等輸入設備,在
9、個人計算機上進行文字錄入和操作控制。本文介紹了語音識別的基本流程、所用到的語音參數算法、語音識別的訓練算法和識別算法做初步的探究,主要運用了特定人孤立詞識別的DTW算法和非特定人識別的連續(xù)HMM算法的MATLAB識別系統。</p><p> 語音識別按說話人的講話方式可分為孤立詞(Isolated Word)識別、連接詞(Connected Word)識別和連續(xù)語音(Continuous Speech)識別。孤
10、立詞識別是指說話人每次只說一個詞或短語,每個詞或短語在詞匯表中都算作一個詞條,一般用在語音電話撥號系統中。連接詞語音識別支持一個小的語法網絡,其內部形成一個狀態(tài)機,可以實現簡單的家用電器的控制,而復雜的連接詞語音識別系統可以用于電話語音查詢、航空定票等系統。連續(xù)語音識別是指對說話人以日常自然的方式發(fā)音,通常特指用于語音錄入的聽寫機。顯然,連續(xù)非特定人語音識別的難度要大得多,因為不僅有說話人口音的問題,還有協同發(fā)音、斷字斷句、搜索等問題,
11、除了考慮語音的聲學模型外還要涉及到語言模型,如構詞法、文法等。</p><p> 從識別對象的類型來看,語音識別可以分為特定人(Speaker Dependent)語音識別和非特定人(Speaker Independent)語音識別。特定人是指只針對一個用戶的語音識別,非特定人則可用于不同的用戶。實際上,非特定人語音識別的初始識別率往往都比較低,一般都要求用戶花一定的時間對系統進行訓練,將系統的參數進行一定的自
12、適應調整,才能使識別率達到滿意的程度。</p><p> 非特定人大詞表連續(xù)語音識別是近幾年研究的重點,也是研究的難點。目前的連續(xù)語音識別大多是基于HMM(隱馬爾可夫模型)框架,并將聲學、語言學的知識統一引入來改善這個框架,其硬件平臺通常是功能強大的工作站或PC機。</p><p> 1.2語音識別系統的基本構成</p><p> 語音識別系統的典型實現方案為
13、:輸入的模擬語音信號首先要進行預處理,包括預濾波、采樣和量化、加窗、端點檢測、預加重等。語音信號經預處理后,接下來很重要的一環(huán)就是特征參數提取。對特征參數的要求是:</p><p> 提取的特征參數能有效地代表語音特征,具有很好的區(qū)分性。</p><p> 各階參數之間有良好的獨立性。</p><p> 特征參數要計算方便,最好有高效的計算方法,以保證語音識別
14、的實時實現。</p><p> 在訓練階段,將特征參數進行一定的處理之后,為每個詞條得到一個模型,保存為模版庫。在識別階段,語音喜好經過相同的通道得到語音參數,生成測試模版,與參考模版進行匹配,將匹配分數最高的參考模版作為識別結果。同時還可以在很多先驗知識的幫助下,提高識別的準確率。</p><p> 第二章 語音識別的參數</p><p> 2.1 線性預測
15、系數</p><p> 語音信號是一種典型的時變信號,然而如果把觀察時間縮短到十毫秒至幾十毫秒,則可以得到一系列近似穩(wěn)定的信號。人的發(fā)音器官可以用若干段前后連接的聲管進行模擬,這就是所謂的聲管模型。下圖為語音產生的生理結構示意圖:</p><p> 圖2-1 語音產生的生理結構示意圖[1]</p><p> 由于發(fā)音器官不可能毫無規(guī)律地快速變化,因此語音信號
16、是準穩(wěn)定的(quasi steady)。全極點線性預測模型(LPC)可以對聲管模型進行很好的描述,這里信號的激勵源是由肺部氣流的沖擊引起的,聲帶可以有周期振動也可以不振動,分別對應濁音(Vowel)和清音(Consonant),而每段聲管則對應一個LPC模型的極點。一般情況下,極點的個數在12~16之間,就可以足夠清晰地描述語音信號的特征了。LPC是語音分析的重要手段,它能很好地進行譜估計,即可作為語音特征的參數。因此僅用12個LPC系
17、數就能很好地表示復雜語音信號的特征,這就大大降低了信號的冗余度并有效地減少了計算量和存儲量,使之成為語音識別和語音壓縮的基礎。下圖為以聲管模型為基礎的LPC模型:</p><p> 圖2-2 以聲管模型為基礎的LPC模型</p><p> 由: </p><p> 該式表示p個方程構
18、成的方程組,未知數為p個。求解該方程組,就可以得到系統的線性預測系數。由基于自相關的遞推求解公式求解,也就是所謂的Durbin算法得:</p><p> ………………………………………………2.1</p><p> ……………………………..2.2</p><p> …………………………………………………...2.3</p><p>
19、 …………………………..2.4</p><p> ………………………………………2.5</p><p> 公式中,上標表示第次迭代,每次迭代只計算和更新 直到時,結束迭代。</p><p> 在MATLAB中利用lpc函數[2]計算LPC系數,其語法為:</p><p> a = lpc(x,n);</p><p
20、> 這里x為一幀語音信號,n為計算LPC參數的階數。通常x為240點或256點的數據,n取10~12,對語音識別來說就已經足夠。</p><p> 2.2 線性預測倒譜系數</p><p> 在語音識別系統中,很少直接使用LPC系數,而是由LPC系數推導出另一種參數:線性預測倒譜系數(LPCC)。倒譜實際上是一種同態(tài)信號處理方法,標準的倒譜系數計算流程需要進行FFT變換[3],
21、對數操作和相位校正等步驟,運算比較復雜。在實際運作中大多數語音識別系統都會采用倒譜參數來作為有關距離的度量。LPC 倒譜系數是描述說話人聲道特性的,廣泛應用于聲紋識別。在實際計算中,當序列x(n)為最小相位的情況下,可以利用序列x(n)及其倒譜系數c(n)的遞推關系來簡化計算。</p><p> 序列x(n)及其復倒譜系數c(n)的遞推公式如下:</p><p> ……...………..
22、.….2.6</p><p> LPCC參數是一種非常重要的參數,它不是由原始信號x(n)得到,而是由LPC系數得到的。由2.6式可得LPC到LPCC的直接遞推關系。</p><p> ……………………………………………..2.7</p><p> ……………………2.8</p><p> ………………………...…..2.9<
23、/p><p> 2.3 MFCC系數</p><p> LPC模型是基于發(fā)音模型建立的,LPCC系數也是一種基于合成的參數。這種參數沒有充分利用人耳的聽覺特性。實際上,人的聽覺系統是一個特殊的非線性系統,它響應不同頻率信號的靈敏度是不同的,基本上是一個對數的關系。近年來,一種能夠比較充分利用人耳這種特殊的感知特性的參數得到了廣泛的應用,這就是Mel尺度倒譜參數(Mel-scaled Cep
24、strum Coefficient),或稱Mel頻率倒譜系數,簡稱為MFCC。大量的研究表明,MFCC參數能夠比LPCC參數更好地提高系統的識別性能。從目前使用的情況來看,在大詞匯量語音識別應用中已逐漸取代原本常用的線性預測編碼導出的倒頻譜參數,原因是它考慮了人類發(fā)聲與接收聲音的特性,具有更好的魯棒性。由于語音信號在時域上的變化快速而不穩(wěn)定,所以通常都將它轉換到頻域上來觀察,此時它的頻譜會隨著時間作緩慢的變化。所以通常將加窗后的幀經過快
25、速傅立葉變換(FFT),求出每幀的頻譜參數。再將每幀的頻譜參數通過一組N 個( N 一般為20 ~ 30 個)三角形帶通濾波器所組成的Mel頻率濾波器,將每個頻帶的輸出取對數,求出每一個輸出的對數能量(log energy)</p><p> MFCC參數的計算是以“bark”為其頻率基準的,它和線性頻率的轉換關系是:</p><p> ……………………………….2.10</p&
26、gt;<p> MFCC參數也是按幀計算的。首先要通過FFT得到該幀信號的功率譜,轉換為Mel頻率下的功率譜。這需要在計算之前先在語音的頻譜范圍內設置若干個帶通濾波器:</p><p><b> ………2.11</b></p><p> MFCC參數的計算通常采用如下的流程:</p><p> ?。?)首先確定每一幀語音采樣
27、序列的點數。對每幀序列進行預加重處理后再經過離散FFT變換,取模的平方得到離散功率譜。</p><p> ?。?)計算通過M個后所得的功率值,即計算和在各離散頻率點上乘積之和,得到M個參數,。</p><p> ?。?)計算的自然對數,得到,。</p><p> ?。?)對計算其離散余弦變換,得到,。</p><p> ?。?)舍去代表直流成
28、分的,取作為MFCC參數。</p><p> MATLAB中計算mfcc參數的函數為melcepst.m,其中調用了函數melbankm.m,用來計算M個濾波器的系數。</p><p> 2.4 完整的參數計算流程</p><p><b> 特征提取方法:</b></p><p> 特征的選取取決于具體的系統,下
29、面的特征是有代表性的:</p><p><b> ?、俜龋ɑ蚬β剩?lt;/b></p><p><b> ②過零率</b></p><p><b> ?、叟R界帶特征矢量</b></p><p> ④線形預測系數特征矢量(LPC)</p><p> ?、?/p>
30、LPC倒譜特征矢量(LPCC)</p><p> ?、?Mel倒譜系數(MFCC)</p><p> ⑦前三個共振峰F1,F2,F3</p><p><b> 具體步驟分4步:</b></p><p><b> 1.端點檢測</b></p><p> 所謂端點檢測,就
31、是在實時輸入的聲音信號中,區(qū)分背景噪聲和環(huán)境噪聲,準確地判斷出聲音信號的開始點和結束點。這一過程應由特定的算法自動完成,通常利用短時能量來檢測濁音,用過零率來檢測清音,兩者配合實現可靠的端點檢測。端點檢測算法常用的是由語音能量和過零率組合的有雙門限法,以及短時能量和過零率的乘積構成的能頻值法。</p><p><b> 預加重濾波器</b></p><p> 在語
32、音參數計算之前,一般要將其通過一個預加重濾波器。</p><p><b> 倒譜提升窗口</b></p><p> 在為每幀數據計算出階MFCC參數后,通常還要為這個系數分別乘以不同的權系數,實際上是一個短的窗口:</p><p> ……………………………………………..2.12</p><p> …………………
33、…2.13</p><p><b> 差分倒譜系數</b></p><p> 標準的MFCC參數只反映了語音參數的靜態(tài)特性,而人耳對語音的動態(tài)特征更為敏感,通常用差分倒譜參數來描述這種動態(tài)特性。</p><p> 差分參數的計算采用下面的公式:</p><p> …………………….2.14</p>
34、<p> 這里c和d都表示一幀語音參數,k為常數,通常取2,這時差分參數就稱為當前幀的前兩幀和后兩幀參數的線性組合。</p><p><b> 第三章 DTW算法</b></p><p> 3.1 DTW算法原理</p><p> 在孤立詞語音識別中,最為簡單有效的方法是采用DTW(Dynamic Time Warping,動
35、態(tài)時間彎折)算法,該算法基于動態(tài)規(guī)劃(DP)的思想,解決了發(fā)音長短不一的模板匹配問題,是語音識別中出現較早、較為經典的一種算法。用于孤立詞識別,DTW算法與HMM算法在相同的環(huán)境條件下,識別效果相差不大,但HMM算法要復雜得多,主要體現在HMM算法在訓練階段需要提供大量的語音數據,通過反復計算才能得到模型參數,而DTW算法的訓練中幾乎不需要額外的計算。所以在孤立詞語音識別中,DTW算法仍得到廣泛的應用。</p><p
36、> 在訓練和建立模板階段以及在識別階段,都采用端點檢測算法確定語音的起點和終點。已存入模板庫的各個詞條稱為參考模板,一個參考模板可表示為,m為訓練語音幀的時序標號,m=1為起點語音幀,m=M為終點語音幀,因此為該模板所包含的語音幀總數,為第幀的語音特征矢量。所要識別的一個輸入詞條語音稱為測試模板,可表示為,為測試語音幀的時序標號,n=1為起點語音幀,n=N為終點語音幀,因此N為該模板所包含的語音幀總數,T(n)為第n幀的語音特征
37、矢量。參考模板與測試模板一般采用相同類型的特征矢量(如MFCC系數)、相同的幀長、相同的窗函數和相同的幀移。測試和參考模板分別用T和R表示,為了比較它們之間的相似度,可以計算它們之間的距離D[T,R],距離越小則相似度越高。為了計算這一失真距離,應從T和R中各個對應幀之間的距離算起。設n和m分別是T和R中任意選擇的幀號,d[T(n),R(m)]表示這兩幀之間的距離。距離函數取決于實際采用的距離度量,在DTW算法中通常采用歐氏距離。<
38、;/p><p> 若N=M則可以直接計算,否則要考慮將T(n)和R(m)對齊。對齊可以采用線性擴張的方法,如果N<M可以將T線性映射為一個M幀的序列,再計算它與之間的距離。但是這樣的計算沒有考慮到語音中各個段在不同的情況下的持續(xù)時間會產生或長或短的變化,因此識別效果不可能最佳。因而更多地是采用動態(tài)規(guī)劃(DP)的方法。</p><p> 如果把測試模板的各個幀號n=1~N在一個二維直角
39、坐標系中的橫軸上標出,把參考模板的各幀號m=1~M在縱軸上標出,通過這些表示幀號的整數坐標畫出一些縱橫線即可形成一個網格,網格中的每一個交叉點(n,m)表示測試模式中某一幀與訓練模式中某一幀的交匯點。DP算法可以歸結為尋找一條通過此網格中若干格點的路徑,路徑通過的格點即為測試和參考模板中進行距離計算的幀號。路徑不是隨意選擇的,首先任何一種語音的發(fā)音快慢都有可能變化,但是其各部分的先后次序不可能改變,因此所選的路徑必定是從左下角出發(fā),在右
40、上角結束</p><p> 圖3-1 DTW算法路徑原理示意圖</p><p> 為了描述這條路徑,假設路徑通過的所有格點依次為其中=(1,1),=(N,M)。路徑可以用函數描述,其中,。那么下一個通過的格點只可能是下列三中情況之一:</p><p> …………………………..3.1</p><p> 用表示上述三個約束條件。求最佳
41、路徑的問題可以歸結為滿足約束條件時,求最佳路徑函數,使得沿路徑的積累距離達到最小值,即:</p><p><b> ………...3.2</b></p><p> 搜索該路徑的方法如下:搜索從點出發(fā),可以展開若干條滿足的路徑,假設可計算每條路徑達到點時的總的積累距離,具有最小累積距離者即為最佳路徑。易于證明,限定范圍內的任一格點只可能有一條搜索路徑通過。對于,其可達
42、到該格點的前一個格點只可能是、和,那么一定選擇這3個距離中的最小者所對應的格點作為其前續(xù)格點,若用代表此格點,并將通過該格點之路徑延伸而通過,這時此路徑的積累距離為:</p><p> …………….....3.3</p><p><b> ….3.4</b></p><p> 這樣可以從=(1,1)出發(fā)搜索,再搜索……,對每一個都存儲相應
43、的前一格點及相應的幀匹配距離。搜索到時,只保留一條最佳路徑。這便是DTW算法。[5]</p><p> 3.2 DTW的高效算法</p><p> 由于匹配過程中限定了彎折的斜率,因此許多格點實際上是到達不了的,如下圖所示。因此菱形之外的格點對應的幀匹配距離是不需要計算的。另外也沒有必要保存所有的幀匹配距離矩陣和累積距離矩陣,因為每一列各格點上的匹配計算只用到了前一列的三個網格。充分利
44、用這兩個特點可以減少計算量和存儲空間的需求。</p><p> 如圖所示,把實際的動態(tài)彎折分為三段,,其中:</p><p> ……………………………3.5</p><p> 圖3-2 DTW高效路徑示意圖</p><p> 和都取最相近的整數。由此也得出對M和N長度的限制條件:</p><p> …………
45、……………………..3.6</p><p> 當不滿足以上條件時,認為兩者差別實在太大,無法進行動態(tài)彎折匹配。</p><p> 在X軸上的每一幀不再需要與Y軸上的每一幀進行比較,而只是與Y軸上間的幀進行比較,和的計算如下式:</p><p> ................................3.7</p><p>
46、………………….3.8</p><p> 也可能會出現的情況,此時彎折匹配的三段為。</p><p> 對于X軸上每前進一幀,雖然所要比較的Y軸上的幀數不同,但彎折特性是一樣的,累積距離的更新都是用下式實現的:</p><p><b> ……..3.9</b></p><p> 由于X軸上每前進一幀,只需要用到前
47、一列的累積距離,所以只需要兩個列矢量D和d分別保存前一列的累積距離和計算當前列的累積距離,而不用保存整個距離矩陣。每前進一幀都進行更新,即按上式利用前一列的累積距離D和當前列的所有幀匹配距離d(x,y),求出當前幀的累積距離,保存于矢量d中,再把新的距離d賦值給D,作為新的累積距離,供下一列使用。這樣一直前進到X軸上最后一列,矢量D的第M個元素即為兩個模板動態(tài)彎折的匹配距離。</p><p> 圖3-3 DT
48、W改進算法模型[6]</p><p> 第四章 非特定人語音識別算法——HMM</p><p> 4.1 HMM的原理</p><p><b> HMM基本概念</b></p><p> HMM,即隱馬爾科夫模型(Hidden Markov Model),是在Markov鏈的基礎之上發(fā)展起來的。由于實際問題比Ma
49、rkov鏈模型所描述的更為復雜,觀察到的事件并不是與狀態(tài)一一對應,而是通過一組概率分布相聯系,這樣的模型就稱為HMM。它是一個雙重隨機過程,其中之一是Markov鏈,這是基本隨機過程,它描述狀態(tài)的轉移。另一個隨機過程描述狀態(tài)和觀察值之間的統計對應關系,即站在觀察者的角度,只能看到觀察值,不能直接看到狀態(tài),而是通過一個隨機過程去感知狀態(tài)的存在及其特性。</p><p> 一個HMM模型由若干個狀態(tài)組成,隨著時間的
50、變化,各個狀態(tài)之間可以發(fā)生轉移,也可以在一個狀態(tài)內駐留。每個觀察向量對不同的狀態(tài)都有相應的輸出頻率。[7]以一個包含四個狀態(tài)為例,狀態(tài)之間或狀態(tài)自身的轉移概率用表示,輸入觀察序列為。每個觀察序列是一幀MFCC參數。在這個模型中,序列是可觀測的輸入序列,稱為觀察序列,而每一時刻所處的狀態(tài)卻是隱含的。下表為HMM模型的各參數及其說明[8]:</p><p> 其中輸出概率密度函數中參數描述如下表所示。</p&
51、gt;<p> 權系數滿足下面的條件</p><p> ……………………………4.1</p><p> 這種連續(xù)混合高斯HMM通常簡稱為CHMM。對于每一個狀態(tài),都用若干個正態(tài)高斯概率密度函數(簡稱為pdf)的線性組合來表示,每個pdf有各自的均值矢量和協方差矩陣,這些都是通過對大量的MFCC參數進行統計得到的。</p><p> 對于HMM模
52、型,有三個基本問題需要解決:</p><p> ?。?)給定觀察序列和HMM模型計算觀察斜率對HMM模型的輸出概率。</p><p> (2)給定觀察序列和HMM模型確定一個最優(yōu)的狀態(tài)轉移序列。</p><p><b> (3)調整使最大。</b></p><p> 4.2 前向概率和后向概率——HMM的輸出概率計
53、算</p><p> 1.HMM輸出概率的計算</p><p> 給定觀察序列和HMM模型,如果已知狀態(tài)轉移序列,則有:</p><p><b> …...4.2</b></p><p> HMM模型輸出序列q的概率為:</p><p> ……………….4.3</p>&l
54、t;p> 對所有可能的狀態(tài)轉移序列q,模型輸出觀察序列O的概率[9]。由全概率公式可得:</p><p><b> ….4.4</b></p><p> 該式大約需要次計算,這在實際中是無法承受的。為了降低計算復雜度,可以采用前向和后向算法。</p><p> 2.HMM的前向概率和后向概率</p><p>
55、; 首先定義HMM的前向概率為:</p><p> ………………………...4.5</p><p> 表示給定HMM模型參數,部分觀察序列在t時刻處于狀態(tài)的概率。那么有:</p><p><b> 初始化:</b></p><p> …………………………4.6</p><p><b
56、> 遞歸:</b></p><p> …………...4.7</p><p><b> 終結:</b></p><p> ………………………………4.8</p><p> 與前向概率相對應,還有后向概率。定義后向概率為:</p><p> ……………………....4.9
57、</p><p> 表示HMM模型參數,觀察序列在t時刻處于狀態(tài)i,系統輸出部分觀察序列的概率。</p><p> 后向概率也有類似的遞推公式計算:</p><p><b> a) 初始化:</b></p><p> ……………………………4.10</p><p><b> 遞
58、歸:</b></p><p><b> ………….4.11</b></p><p><b> 終結:</b></p><p> 前向概率和后向概率的遞推關系由下圖說明</p><p> 圖4-1 前向概率和后向概率示意圖</p><p> 3.利用前向概
59、率和后向概率計算輸出概率</p><p> 前向概率公式和后向概率公式巧妙地將整個觀察序列對HMM模型的輸出概率分成兩個部分觀察序列的輸出概率的乘積,而且它們各自都有相應的遞推公式,可以大大簡化計算[10]。經過分析,可以得到下面的輸出概率計算公式:</p><p> ………………4.12</p><p> 實際上,這就是HMM三個基本問題中第一個問題的解答。
60、它的另一種常用的形式是:</p><p> …………..4.13</p><p> 實際計算中首先計算出對于每個t和每個狀態(tài)i的前向概率和后向概率,然后套用上面的公式,計算出該觀察序列對模型的輸出概率。這兩個公式也稱為全概率公式。</p><p> 4.3 識別算法——Viterbi解碼</p><p> Viterbi算法,不僅可以
61、找到一條足夠好的狀態(tài)轉移路徑,還可以得到該路徑所對應的輸出概率。同時,用Viterbi算法計算輸出概率所需要的計算量要比全概率公式的計算量小很多。</p><p> 定義為時刻t時沿一條路徑,且,產生出的最大概率,即有</p><p> ……………..4.14</p><p> Viterbi算法的遞推形式如下</p><p><
62、b> 初始化</b></p><p> ………………………….4.15</p><p> …………………………………...4.16</p><p><b> 遞歸</b></p><p> …………..4.17</p><p> ..................4
63、.18</p><p><b> 終結</b></p><p> ………………………………4.19</p><p> …………………………..4.20</p><p><b> 狀態(tài)序列求?。?lt;/b></p><p> ……………….4.21</p>
64、<p> 這里,為t時刻第i狀態(tài)的累積輸出概率,為t時刻第i狀態(tài)的前續(xù)狀態(tài)號,為最優(yōu)狀態(tài)序列中t時刻所處的狀態(tài),為最終的輸出概率。</p><p> 對語音處理應用而言,動態(tài)范圍很大,或者說不同的Q使的值差別很大,而事實上是中舉足輕重的唯一成分,因此,常常等價地使用和,那么,Viterbi算法也能用來計算。</p><p> 4.4 Baum-Welch 算法</p&
65、gt;<p> 這個算法實際上是解決HMM訓練,即HMM參數估計問題,或者說,給定一個觀察值序列,該算法能確定一個,使最大。</p><p> 由前向變量和后向變量的定義,有:</p><p> …………..4.22</p><p> 這里,求取,使最大是一個泛函極值問題。但是由于給定的訓練序列有限,因而不存在一個最佳的方法來估計。在這種情況下
66、,Baum-Welch算法利用遞歸的思想,使局部極大,最后得到模型參數。</p><p> 定義為給頂訓練序列O和模型時,時刻t時Markov鏈處于狀態(tài)和時刻t+1為狀態(tài)的概率,即</p><p> …………………………4.23</p><p><b> 可以推導出:</b></p><p> …………………4.
67、24</p><p> 那么,時刻t時Markov鏈處于狀態(tài)的概率為:</p><p> …………….…………4.25</p><p> 因此,表示從狀態(tài)轉移到狀態(tài)的次數的期望值。由此,導出了Baum-Welch算法的重估公式[11](reestimation):</p><p> ..…………………………………..4.26</
68、p><p> ……………… 4.27</p><p> …………….4.28</p><p><b> 試推導該重估公式:</b></p><p> 引理:設為正實數,為非負實數,即,那么由對數函數的凹特性有如下結論:</p><p> ……..……….………..4.29</p>
69、<p> ………………….………..4.30</p><p> ..……………4.31</p><p> 此處所有求和均是從1到S。</p><p><b> 定義輔助函數</b></p><p> ...……………4.32</p><p> 其中,為原來的模型,為新求取
70、的模型,O為訓練用觀察值序列,,S為某個狀態(tài)序列,那么,由引理易推出下面的定理[12]:</p><p> 如果,那么?!?.……..4.33</p><p> 該定理構成了重估公式的理論基礎:對輔助函數,重要能找到,使達到最大值,那么就能保證,從而使,這樣,新得到的模型在表示訓練序列O方面就比原來的模型要好。一直重復這個過程,直到某個收斂點,就可以得到根據訓練序列O估計出
71、的結果模型,而使最大而求取參數的公式就稱之為重估公式。不同的,其參數,A和B就不同,重估公式的具體形式也不同[13]。</p><p><b> 第五章 實驗及總結</b></p><p> 5.1 實驗準備及步驟</p><p> 實驗平臺為Windows平臺上,采用Matlab數學工具通過完成程序而實現的。本實驗主要采用DTW算法實現
72、語音識別。</p><p> 首先,我們使用windows自帶的錄音器,分別由我和合作者黃博錄入了4組數據(1人兩組),每組8個音頻文件,本別為從“一”到“八”的漢語發(fā)音。其中一組為參考模板,另外一組為測試模板。</p><p> 首先用wavread函數讀入wav文件,用mfcc函數獲得其MFCC參數,用vad函數對其進行端點檢測,并保存語音部分的MFCC參數到參考模板的機構數組re
73、f(i).mfcc中。</p><p> 我們比較一下兩個人的語音端點檢測的短時信號圖:</p><p> 圖5-1 說話者A發(fā)音的vad輸出(1)——橫軸:時間(單位:秒)縱軸:能量——(單位:eV)(上圖)語音原始信號;Energy 短時能量(單位:eV);ZCR 過零率(單位:%)</p><p> 圖5-2 說話者A發(fā)音的vad輸出(2)——橫軸:時間
74、(單位:秒)——縱軸:能量(單位:eV)(上圖)語音原始信號;Energy 短時能量(單位:eV);ZCR 過零率(單位:%)</p><p> 圖5-3說話者B發(fā)音的vad輸出(2)——橫軸:時間(單位:秒)——縱軸:能量(單位:eV)(上圖)語音原始信號;Energy 短時能量(單位:eV);ZCR 過零率(單位:%)</p><p> Vad函數的功能就是通過端點檢測功能甄別出語
75、音信號的起始點與結束點,圖中的紅線就是程序標記的語音信號始末點,可以看出,雜音基本被排除,效果是非常明顯的。</p><p> 同時,從以上三個圖的對比可以看出,不同發(fā)音者的發(fā)音波形及特性有較明顯區(qū)別。</p><p> 原始波形中,發(fā)音者A的波形在橫軸兩端不對稱,而發(fā)音者B的波形在橫軸兩端比較對稱;</p><p> 能量波形中,兩者的區(qū)別更加明顯:發(fā)音者A
76、的能量高峰在語音后部,發(fā)音者B的能量高峰在語音前部;</p><p> 過零率波形中也可以明顯看出兩個人的區(qū)別。端點檢測下的短時能量分析只是語音識別的第一步,但是通過該步驟已經可以粗略的區(qū)別出不同發(fā)音者,并且可以進一步分析發(fā)音者語音信號的特點。由此證明了端點檢測在語音識別中是非常重要的。</p><p> 5.2 實驗結果及討論</p><p> 本實驗的MA
77、TLAB運行環(huán)境中輸出結果如下列圖所示:</p><p> 圖5-4 說話者A的兩組語音匹配結果及距離匹配矩陣</p><p> 圖6 說話者B的兩組語音匹配結果及距離矩陣</p><p> 從輸出記過看,識別具有了一定程度的正確度。為了進一步驗證結果,看一下匹配距離矩陣dist的數據如下圖所示:</p><p> 距離矩陣的對角線上
78、是正確匹配模板的對應分數,可見對角線上的8個數值中有50%都是在本行中最小的,由此驗證了識別結果的正確性。</p><p> 圖5-5說話者B的兩組語音匹配結果及距離匹配矩陣</p><p> 圖5-6說話者A和B 的語音匹配結果及距離匹配矩陣</p><p> 圖5-7 說話者A和B的匹配矩陣的三維曲面圖</p><p> 圖5-8
79、 說話者A和B的匹配矩陣的的三維柱狀圖</p><p> 圖5-9 說話者A和B的匹配矩陣的灰度視圖</p><p> 結果顯示:說話者A的自匹配識別率為89%,說話者B的自匹配識別率也為89% ,而A和B之間的識別率為62% 。</p><p> 圖5-4,圖5-5,圖5-6中的匹配矩陣元為每個語音信號和參考模板中所有共8個語音信號的匹配距離,可以看出,在正
80、確識別情況下,矩陣對角線上的矩陣元是本行中最小的(同一個語音信號和自己匹配距離最?。谄ヅ涫〉那闆r下,對角線上的矩陣元也是次最小的。這一結果說明了DTW的可靠性和穩(wěn)定性。</p><p> 圖5-7,圖5-8,圖5-9以不同方式直觀的顯示了矩陣元的大小關系。X軸表示說話者A的語音信號編號,Y軸表示說話者B的語音信號編號,Z軸表示矩陣元的大小。</p><p> 三維曲面圖中的藍色部
81、分,灰度圖中的全黑色部分為數值較小區(qū)域,可以看書,這個區(qū)域基本是在對角線上的?;叶葓D中的紅色連線便顯示了黑色方塊分布在對角線上及附近。</p><p> 自匹配的識別準確率達到90%,而不同發(fā)音者之間的識別率有明顯下降,為60%。這也是顯示出DTW算法在非特定人語音識別中不如特定人語音識別準確。</p><p> 文獻[1]指出,使用DTW算法的特定人孤立字語音識別率能高達近100%
82、,而我們始終無法達到這一效果。有幾方面的原因:</p><p> 1.錄音設備和程序偏簡單。一個非常良好和精確的模板庫是高效率語音識別系統的基礎。我們使用簡易麥克風和windows自帶錄音程序可能無法建立一個完備的模板庫。</p><p> 2.DTW算法自身的缺陷。DTW自身算法只適用于孤立字語音識別,而且是簡單字。因此識別機理上更加先進的HMM和ANN方法能夠滿足更高的要求。 對D
83、TW算法進行改進(比如端點檢測)已經提高了該算法的識別率。</p><p> 3.DTW算法僅限于孤立字的語音識別,而連續(xù)語音的識別目前來說還比較難以達到高的識別率,這也是今后語音識別課題研究發(fā)展的方向。</p><p><b> 5.3 實驗結論</b></p><p> 課題最終在MATLAB平臺的基礎上基本實現了個別個體的特定語音識
84、別,基本上達到了預定的目的?;贒TW模型的語音識別簡單的說就是通過MATLAB的程序段,將待識別的語音信號與數據庫中的模板進行相似度對比,將相似度最高者最為識別結果輸出,同時DTW的識別效率取決于參考模板的清晰度以及廣泛度,如果能夠建立一個范圍龐大而且清晰的特定人語音庫,將能夠大大提高語音識別的效率。我們的試驗由于時間以及外部設備的關系,難以組建一個非常精確的參考樣本,因此識別的效率略微偏低,不過已經足夠說明DTW識別算法在特定人孤立
85、字語音識別中的巨大作用。本文對于DTW算法提出了幾條在實際操作中切實可行的改進建議,并對MFCC參數編程和ANN的應用進行了探討。在程序中,由于受數據庫的局限,并沒有實現對于語音的模糊識別,但個別個體的特定語音識別也具有廣泛的用途。</p><p><b> 參考文獻:</b></p><p> [1] Rabiner L, Juang B H. Fundamen
86、tals of Speech Recognition, Prentice-Hall International. Inc, 1999, p.17</p><p> [2] D.G.Childers, Matlab之語音處理與合成工具箱(影印版), 清華大學出版社, 2004, p.45-51</p><p> [3] 黃文梅, 熊桂林, 楊勇, 信號分析與處理—MATLAB語言及應用,
87、 國防科技大學出版社, 2000, p.37-40</p><p> [4] 楊行峻, 遲惠生,“語音數字信號處理”, 電子工業(yè)出版社. 1995</p><p> [5] 張焱, 張杰, 黃志同, 語音識別中動態(tài)時間規(guī)整和隱馬爾可夫統一模型 數據采集與處理 1997年03期 p.218-222</p><p> [6] 何強, 何英, MATLAB擴展編程[
88、M], 清華大學出版社, 2002 p.345-347</p><p> [7] Rabiner L and Juang B H. Introduction to hidden Markov models, IEEE ASSP Mag, vol.3,no.1,4-16,1986</p><p> [8] Huang X D. Hidden Markov Models for Speec
89、h Recognition, Edinburgh Information Technology Series.1999(7):136-202</p><p> [9] Rabiner L, A tutorial on hidden Markov models and selected applications in speech recognition, Proc, of IEEE, 77(2)257-286,
90、1989</p><p> [10] Jen+Tzung Chien, Predictive Hidden Markov Model Selection for Speech Recognition, IEEE Transaction on Speech and Audio Processing, vol.13, No.3, May 2005</p><p> [11] 謝錦輝, 隱M
91、arkov模型(HMM)及其在語音處理中的應用, 華中理工大學出版社.</p><p> [12] Christoph Gerber, A General Approach to Speech Recognition, Electronic Workshops in Computing, 1995</p><p> [13] Xu Bo, FENG Yuguang, YU Jinson
92、g, Intelligent classifier for dynamic fault patterns based on Hidden Markov Model</p><p> [14] MATLAB Primer, seventh edition, Chapman & Hall/CRC 2005</p><p> [15] Ara V.Nefian. Luhong Lia
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 畢業(yè)論文---利用matlab平臺實現少量字的語音識別
- 基于matlab車牌識別畢業(yè)論文
- 畢業(yè)論文-基于matlab的指紋識別
- 畢業(yè)論文-基于matlab的指紋識別
- 畢業(yè)論文-語音識別機器人的設計與實現
- 畢業(yè)論文(設計)基于模板匹配的車牌識別及matlab實現
- 人臉識別畢業(yè)論文--人臉檢測技術研究及matlab實現
- 基于matlab平臺的圖像增強技術畢業(yè)論文
- 畢業(yè)論文---語音識別機器人的設計
- 基于matlab語音信號采集與分析的畢業(yè)論文
- 畢業(yè)論文——基于matlab的語音信號頻譜分析
- matlab實現turbo編譯碼畢業(yè)論文
- 基于matlab的手寫體數字識別算法的實現與分析-畢業(yè)論文
- 結業(yè)畢業(yè)論文基于matlab地指紋識別
- 數值積分算法與matlab實現畢業(yè)論文
- 基于matlab的語音信號fir數字濾波處理畢業(yè)論文
- 畢業(yè)論文--基于matlab的人臉識別系統設計
- 基于matlab的語音識別算法研究
- 畢業(yè)論文(設計)數值積分算法與matlab實現
- 語音識別電風扇控制系統設計-畢業(yè)論文
評論
0/150
提交評論