《電子技術應用》
您所在的位置:首頁 > 通信與網(wǎng)絡 > 業(yè)界動態(tài) > ILBC編碼算法及其在VOIP中的應用

ILBC編碼算法及其在VOIP中的應用

2008-05-08
作者:郭廷廷, 李 敬

  摘 要: VOIP正在成為熱門的應用領域,語音質(zhì)量" title="語音質(zhì)量">語音質(zhì)量的提高是其難點之一。ILBC算法是一種基于CELP(Code Excited Linear Predictive Coding)的新的低比特率語音編碼算法,其優(yōu)異的語音質(zhì)量、突出的長時預測方法[1]及丟包掩蔽[2](PLC)技術,很好地解決了互聯(lián)網(wǎng)上傳輸語音的問題。詳細探討了ILBC的實現(xiàn)原理,對其關鍵技術進行了較深入的分析,給出了實驗結論,并對其應用作了一些展望。
  關鍵詞: ILBC(Internet Low Bit Vate Codec) VOIP(Voice Over IP) PLC 丟包掩蔽 動態(tài)碼本


  隨著互聯(lián)網(wǎng)的迅速發(fā)展,人們對通過互聯(lián)網(wǎng)進行實時語音、視頻傳輸?shù)囊笤桨l(fā)強烈,VOIP正是在這一應用背景下誕生的一門新技術,它把數(shù)字語音編碼技術與分組交換網(wǎng)相結合,提供實時語音及其相關服務,該技術要求占用盡可能小的網(wǎng)絡帶寬并擁有良好的語音質(zhì)量。由于當前網(wǎng)絡環(huán)境" title="網(wǎng)絡環(huán)境">網(wǎng)絡環(huán)境的特點,丟包現(xiàn)象不可避免,以往的低比特率編碼標準雖然可以解決帶寬問題,但丟包時語音質(zhì)量不能保證。因而,需要新的語音編碼算法來滿足這一要求。
1 ILBC簡介
  ILBC是由Global IP Sound公司提出的一種專為包交換網(wǎng)絡通信設計的編解碼" title="編解碼">編解碼,優(yōu)于目前流行的G.729A、G.723.1,對丟包進行了特殊處理,既使在丟包率相當高的網(wǎng)絡環(huán)境下,仍可獲得非常清晰的語音效果。
  ILBC是一種適用于窄帶網(wǎng)絡的編碼算法。根據(jù)網(wǎng)絡帶寬的不同,ILBC提供兩種編碼的格式,如表1。該算法使用了長時的預測技術和幀獨立編碼方法,使其非常適合在存在丟包的網(wǎng)絡環(huán)境中傳播。


2 ILBC算法的原理
2.1 ILBC編碼

  ILBC本質(zhì)上是一種基于幀的線性預測編碼方法,是對CELP(碼激勵線性預測編碼)的一種發(fā)展,其獨有的動態(tài)碼本更新技術、語音加強算法和丟包掩蔽技術使其在VOIP中應用時有更好的性能。對于每一個含有160/240(20ms/30ms) 樣點的輸入幀,ILBC算法將進行以下主要操作:
  (1) 把該幀分為4/6 個子幀,每子幀40個樣點。對30ms的幀,進行兩組10階的LPC分析,得到相應的LPC系數(shù);對于20ms的幀,進行一次10階LPC分析。
  (2)每次分析得到的LPC系數(shù)將轉化為LSF(線譜對)參數(shù),并對LSF系數(shù)進行量化,內(nèi)插以得到各個子幀的LSF系數(shù);隨后,由各子幀的LSF系數(shù)得到各子幀對應的分析器,對各個子幀進行線性預測,計算各子幀的殘差。
  (3)從殘差中找到兩個能量最大的連續(xù)子幀,然后把能量值較小的首23/22個樣點(30ms/20ms)或尾23/22樣點從連續(xù)子幀中去除,剩余的57/58個被選定為本次處理的初始狀態(tài)。對于濁音語音,這樣的選取方式將至少包含一個基音脈沖。
  (4)對初始狀態(tài)進行基于DPCM的標量量化,量化結果將作為編碼輸出的一部分。與此同時,初始狀態(tài)被存入碼本存儲區(qū),以構成動態(tài)碼本的初始值,用于對本幀的剩余樣點進行矢量量化" title="矢量量化">矢量量化。
  (5)對于剩余的殘差,矢量量化將按下面順序進行:(a)包含有初始狀態(tài)的兩個連續(xù)子幀中剩余的23/22個樣點;(b) 時間軸上處于初始狀態(tài)之后的各個子幀; (c)時間軸上在初始狀態(tài)之前的各個子幀。對于此矢量量化,每次搜索碼本的范圍是動態(tài)碼本,其中存儲了已經(jīng)被解碼的對象,并隨著最新的解碼結果,該動態(tài)碼本被更新。
  (6)對編碼結果進行封包處理。
  ILBC的編碼的框圖如圖1所示。


2.2 ILBC解碼
  ILBC是一種運用了分析合成方法的編解碼算法,解碼部分的運算量相對要小一些,使其在功能不強的客戶端的實時解碼成為可能。
  解碼的主要過程如下:
  (1)解包,參數(shù)提取。
  (2)從得到的LSF參數(shù)進行內(nèi)插,并轉化各個子幀的LPC系數(shù),以便進行合成操作。
  (3) 對初始狀態(tài)進行解碼,解碼結果一方面作為激勵信號" title="激勵信號">激勵信號暫存,另一方面存入碼本存儲區(qū),以構成動態(tài)碼本的初始值。
  (4) 對剩余的子幀部分,按照與編碼相同的次序進行殘差解碼,并用解碼結果更新動態(tài)碼本,重復(4)直到所有子幀完成譯碼。
  (5) 對于解碼得到的殘差信號,進行語音增強的操作。該語音增強采用了條件限制的增強方法。
  (6) 進行語音合成,形成解碼后的語音。
  (7) 高通濾波,以消除合成后的低頻語音。
  ILBC解碼的流程圖如圖2所示。


2.3 ILBC的比特流定義
  對于20 ms的幀,共使用了304個比特來表示編碼后的語音信號,被封裝在38個字節(jié)中;對于30ms的幀,共使用了400個比特,封裝在50個字節(jié)中。在封裝的過程中,按照數(shù)據(jù)對傳輸誤差的敏感程度不同,這些比特被分成三類,第一類代表了最敏感的數(shù)據(jù)[3]。表2 列出了ILBC編碼的比特流分配情況。


3 ILBC的關鍵技術
  與以往的低比特率語音編解碼算法相比,ILBC除了采用經(jīng)典的線性預測分析法、LPC系數(shù)到LSF系數(shù)相互轉換、分裂矢量量化LSF參數(shù)和多級形狀-增益量化[4]殘差外,主要有下面特殊的方法。
  (1) 基于初始狀態(tài)的動態(tài)碼本的選取和更新。
  ILBC利用了基于初始狀態(tài)的動態(tài)碼本的更新方法,把最新的解碼結果加入碼本,以取代較老的碼矢。通過這種算法,可以較為方便地生成碼本,同時也提供了很好的碼本預測能力。
  (2) 幀間獨立的長時預測方法,在此基礎上的PLC(丟包掩蔽)技術。
  經(jīng)典的CELP方法是利用以往的激勵信號來對自適應碼本進行更新的,這樣的方法在分組交換網(wǎng)中有下面問題:
 ?、偃绻^去的信號丟失或在傳輸過程中被污染,解碼用的碼本就會與編碼時不同,將導致解碼語音質(zhì)量變差;
 ?、谠谡Z音建立階段,解碼端的自適應碼本并不能很好地描述基音周期,導致解碼語音建立時間加長。
  ILBC采用了基于初始狀態(tài)的解碼方法,初始碼本是從初始狀態(tài)中得到的,通常都會包含至少一個基音脈沖,因而建立時間較快;同時,從初始狀態(tài)出發(fā),既有時間上前向的預測,也有向后的預測,因而體現(xiàn)了長時預測的概念,配合PLC技術,即使出現(xiàn)丟幀,解碼語音質(zhì)量也不會有明顯下降。
  PLC技術的基本原則是:解碼端若收到正確的幀,則計算出的LPC系數(shù)和激勵碼本被存儲; 若丟幀,則使用上一個正確幀中的激勵信號,利用基音同步重復的方法得到本幀解碼信號。
  (3) 利用有條件限制的優(yōu)化算法[3]加強殘差語音。
  該算法的主要思想是對要加強的殘差語音塊,尋找其前3個塊和后3個塊,用這6個塊的線性組合逼近當前待加強的塊。計算待加強塊和逼近塊的均方誤差。若誤差足夠小,就把逼近塊作為加強塊;否則,加強塊為待加強塊和逼近塊的線性組合。


4 實驗結果與性能評測
  圖3是Dynstat公司在具有丟包情況的網(wǎng)絡環(huán)境下對ILBC、G729.A、G723.1幾種算法進行測試后的MOS(平均意見得分)對比圖,可以看出ILBC編碼的語音質(zhì)量整體高于其余兩種編碼,尤其是當丟包率較高時,MOS得分遠高于另外兩種編碼。
  為了對ILBC在丟幀時仍有良好語音質(zhì)量做出解釋,進行了以下實驗:
  (1)在短時間內(nèi)對有丟包時的解碼片斷做分析,如圖4所示。實驗得出,僅有一幀丟失時,語音的損壞基本上不會被聽者察覺,當出現(xiàn)連續(xù)兩幀以上丟失時,才會被察覺。在文獻[2]中有ILBC與G.729.A的丟幀對比。


  (2)初始狀態(tài)編碼是ILBC中的關鍵步驟,應用了標量編碼的方式。為使編碼更有效,實現(xiàn)時,先用一個全通濾波器將殘差的動態(tài)范圍壓縮,解碼時再通過逆濾波恢復。圖5是對某一幀語音的殘差分析的結果,經(jīng)過多幀測試發(fā)現(xiàn),該技術使殘差的動態(tài)范圍減小了約1/3。
  由于實時傳輸?shù)男枰?,算法的時間復雜度成為實際系統(tǒng)實現(xiàn)時重要的考慮因素,在PC機(Celeron 2.7G, 512M內(nèi)存)上對用ANSI-C實現(xiàn)的ILBC浮點算法[1]進行運算量統(tǒng)計,可以得到表3的結果,可以得到①解碼的復雜度較小,是一種非對稱的編碼方案;②編碼部分碼本搜索占用了最長的時間,成為算法優(yōu)化時要考慮的關鍵部分。

?


  ILBC算法優(yōu)異的語音質(zhì)量及良好的丟包掩蔽技術,使其在VOIP中的應用前景非常廣闊。2002年2月,ILBC是IETF 接受的關于語音/音頻編解碼的第一個標準。2004年4月在關于多媒體終端適配器和媒體網(wǎng)關分布的CableLabsPacketCable1.1 Audio/Video編解碼規(guī)范中,被指定為強制的編解碼算法。軟件與系統(tǒng)方面, Skype、Hostip、Pandora Networks和Pingtel Instant都對該算法進行支持,DSP及專用集成電路方面,TI 已經(jīng)推出相應的定點DSP實現(xiàn)方案,AudioCodes已有專用芯片支持。
  可以預計,不久的將來, ILBC將在VOIP中得到更加廣泛的應用。
參考文獻
1 Andersen S V. Internet low bit rate codec. IETF internet-draft, 2002
2 Andersen S V. ILBC- A linear predictive coder with robustness to packetlosses. Global IP Sound
3 Klein WB. Enhancement of coded speech by constrained optimization. In: proc IEEE Speech Coding Workshop, 2002,submitted for publication
4 楊行峻, 唐 昆. 語音信號數(shù)字處理. 北京:電子工業(yè)出版社,1995

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權者。如涉及作品內(nèi)容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 久久国产精品1区2区3区网页 | 嘿嘿嘿视频在线观看网站 | 欧美日韩亚洲色图 | 91免费视频软件 | 成熟女人50岁一级毛片不卡 | 无边泳池在线观看 | 久久精品免费全国观看国产 | 视频在线观看免费网站 | 天天操天天拍 | 欧美日本韩国一区 | 天天干夜夜爽天天操夜夜爽视频 | 天天操天天摸天天射 | 26uuu欧美日本 | 日日夜夜天天干干 | 成人一a毛片免费视频 | 奇米影视综合网 | 在线涩涩 | 成人欲涩漫h漫免费动漫 | 国产22页| 色综合日韩 | 本道在线 | 国产精品视频成人 | 性videos另类hdwww | 亚洲黄色中文字幕 | 欧美一区二区三区视频在线观看 | 日批视频免费观看 | 国产在线欧美精品中文一区 | 日韩大片免费看 | 日韩激情成人 | 亚洲天天操 | 两性色午夜视频免费网 | 久久国产精品高清一区二区三区 | 精品午夜国产在线观看不卡 | 天堂视频网 | 国产视频二区 | 草草视频手机在线观看视频 | 黄色影片在线免费观看 | 婷婷桃色网| 黄色片免费观看视频 | 成人动漫在线免费观看 | aa级一级天堂片免费观看 |