當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]介紹了MP3解碼器的工作原理,分析了各個解碼環(huán)節(jié)的計算量和消耗時間。將MP3解碼過程中耗時最多的子帶綜合濾波環(huán)節(jié)使用矩陣乘法器單元做了優(yōu)化和改進,提出一種可大幅度提高MP3實時解碼效率的軟硬件協(xié)同設(shè)計方法,并在SoC仿真平臺上得到實時驗證,達到了較好的優(yōu)化效果。由于SoC的設(shè)計方法比較靈活,可以根據(jù)實際需要設(shè)計硬件模塊,所以該設(shè)計具有方便、靈活和可靠性高等特點,是工程實用價值較高的解碼器。

0 引言
    MP3(MPEG Audio Layer 3)是一種以高保真為前提實現(xiàn)的高效壓縮技術(shù)。MP3音頻編碼器復(fù)雜,壓縮率很高,但其音色和音質(zhì)還可以保持基本完整,因此該音頻格式文件在計算機、網(wǎng)絡(luò)和各種電子設(shè)備上都得到了廣泛運用。
    由于MP3音頻解碼相對比較復(fù)雜,為了達到在控制成本的范圍內(nèi)實現(xiàn)快速解碼的要求,提出了在SoC上通過增加矩陣乘法器運行快速的兩個16點DCT算法,進一步提高MP3解碼速度的可行性方案。

1 MP3解碼流程分析
   
MP3解碼的流程如圖1所示,解碼的主要過程包括同步處理、解幀頭、解邊帶信息、解比例因子、Huffman解碼、逆量化、頻率線重排序、立體聲處理、混疊重建、改進離散余弦逆變換(IMDCT)、頻率倒置處理、子代綜合濾波,最后輸出原始的PCM數(shù)據(jù)。


    在這些過程中由于IMDCT和子帶綜合濾波的算法比較復(fù)雜,占用硬件資源較多,處理時間長,因此功耗所占比例相應(yīng)較高。表1是在DSP平臺上成功移植后,對代碼進行耗時分析的結(jié)果。
    根據(jù)表1可知,子帶綜合濾波占了整個解碼時間的60 %以上,是決定解碼速度的最關(guān)鍵模塊;其次是長塊IMDCT運算,占了整個解碼時間的10%以上。若采用MPEG-1建議的算法流程,數(shù)值計算主要集中在子帶綜合濾波上。以兩聲道48 kHz采樣率為例,乘法運算量為(48 000/32)×(64×32+512)×2=7 680 000次/s。因此,子帶綜合濾波是MP3解碼器的優(yōu)化重點,減少子帶綜合濾波的計算量和計算時間是MP3解碼器實現(xiàn)的核心。



2 子帶綜合濾波分析
   
子帶綜合濾波是MP3解碼的最后一部分,也是解碼過程中最為耗時的關(guān)鍵步驟。它負責(zé)從IMDCT的輸出值中把PCM值還原出來,可以分成5個步驟。首先是Matrixing(矩陣)運算,即,2,…,63。由公式可知,它從32個子帶Sk的每個子帶中取出一個值組成32個值送入一個矩陣中進行運算,然后把輸出Vi的64個結(jié)果放入一個1 024的先入先出(FIFO)緩存中,再從1 024值中取出一半,組成一個512矢量Ui,并對這512矢量進行加窗運算,即Wi=UiDi,i=1,2,…,511,加窗系數(shù)Di由MP3官方協(xié)議AnnexB Table3-B.3提供。最后將加窗結(jié)果Wi進行疊加生成32個時域PCM輸出。
    1次矩陣運算乘法和加法運算過程分別為1 024次和992次,完成1個聲道的解碼需要18次矩陣運算。矩陣運算是子帶綜合濾波的關(guān)鍵步驟。實際上,Konstantinos Konstantinides提出的方法,只需要做一些變化就可以通過32點DCT變換成矩陣運算。
2.1 32點快速DCT算法分析
   
快速DCT變換算法主要基于系數(shù)矩陣分裂方法,增加輸入的預(yù)處理,使得乘法和加法計算量減半。32點的DCT變換到矩陣運算如圖2所示。其中V(1×64)表示矩陣的輸出,A,B都是長度為1×16的矢量,(A,B)表示32點DCT的輸出。


    由于32點的DCT可以分解成2個16點的DCT變換,依次類推可以分解成8點的DCT變換,考慮到定點數(shù)字信號處理中的有限字長效應(yīng),實際只需分解1次,將32點DCT化成2個16點的DCT。簡化子帶濾波流程以及使用快速DCT變換后,子帶綜合濾波部分的運算量可以減少約60 %。
    由32點DCT分解為2個16點DCT過程推導(dǎo)如下:[!--empirenews.page--]

2.2 基于矩陣乘法器的快速DCT算法優(yōu)化
   
3×3矩陣乘法器由觸發(fā)器和乘累加器組成,是高性能DSP處理器的重要部件,也是實時處理的核心,其速度直接影響DSP處理器的速度。矩陣乘法器的實現(xiàn)有很多種,基本上都基于并行計算原則。由于每列結(jié)果與其他列不相關(guān),因此可以通過增加乘法器多列同時計算,經(jīng)過n次乘累加就可以得到最后結(jié)果。圖3給出矩陣乘法器的結(jié)構(gòu)。


    顯然,這種結(jié)構(gòu)的計算速度很快,但是使用乘法器會因矩陣維數(shù)n的增加而快速增加,使用的觸發(fā)器也很多。在很多場合下,只要滿足處理速度的要求,完全沒有必要浪費這么多硬件資源,而是只要1個乘累加單元流水作業(yè),分步計算每1列結(jié)果既可。在做乘累加計算1個元素時候,準備下一組參與運算的數(shù)據(jù),如此循環(huán),同樣可以獲得較高的處理速度。
    在該設(shè)計中,由于B矩陣是1×n的一維向量輸入數(shù)據(jù),A矩陣為DCT系數(shù)矩陣,A矩陣中的元素為n個系數(shù)的線性組合,因此整個矩陣乘法器需要2組n個觸發(fā)器分別存放輸入數(shù)據(jù)和n個系數(shù),1個乘累加單元。輸入數(shù)據(jù)X[0:n],從X[O]到X[n]循環(huán)n次進入乘法器,使用選擇信號Assi-gn[0:n]選擇系數(shù)C[0:n],另外系數(shù)符號由Sign信號軟件控制,基本結(jié)構(gòu)如圖4所示。


    由于DCT計算本質(zhì)上就是n×n矩陣乘法運算,而n×n矩陣乘法器是在通用乘法器的基礎(chǔ)上增加2組分別存放系數(shù)矩陣的系數(shù)C(n)和輸入X(n)的n個寄存器,使之實現(xiàn)長度為n的乘累加功能,同時還需保存上次乘法結(jié)果。其中,DCT中的系數(shù)是一組n維基的n種線性組合。只需1次輸入n個系數(shù),使用軟件進行選擇和符號控制就可實現(xiàn)這些不同系數(shù)組合,無需反復(fù)往寄存器中置數(shù),大大提高了取數(shù)/置數(shù)的效率,節(jié)省了整個DCT的運算時間。
    因此在計算32點的DCT,可將32點DCT分解為2個16點的DCT計算,計算量也減少1倍。可以使用2組16×16的矩陣乘法器并行計算,使得計算時間大幅減少。表2是通過增加矩陣乘法器優(yōu)化處理后,子帶綜合濾波使用不同實現(xiàn)方式所需要的時間。


    結(jié)果表明,第2.1節(jié)中使用快速32點DCT算法改進子帶綜合濾波計算是有效的,直接減少59%的計算時間。在采用并行2個16×16矩陣乘法器加速快速32點DCT的計算,可以取得明顯的效果:使得計算時間比原算法減少了約91.4%,而且硬件上只增加1個乘法器和30個數(shù)據(jù)鎖存器,以及部分控制電路。使用軟硬件協(xié)同操作就可以獲得子帶綜合濾波計算速度上的大幅度上升。

3 結(jié)語
   
該設(shè)計面向SoC實現(xiàn)了利用增加矩陣乘法器就可加快基于32點快速DCT算法的MP3解碼中子帶綜合濾波的處理速度,大大緩解了系統(tǒng)的頸瓶,使得采用系統(tǒng)主頻比較低(fs≤100 MHz)的SoC平臺進行MP3的解碼成為可能。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉