《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于ARM946E處理器的MP3解碼優(yōu)化設(shè)計(jì)
基于ARM946E處理器的MP3解碼優(yōu)化設(shè)計(jì)
胡瑞明 耿相銘 上海交通大學(xué)
摘要: 目前市場流行的MP3播放器是基于DSP和專用芯片的解決方案,通過硬件或?qū)S盟惴▽?shí)現(xiàn)解碼,具有良好的實(shí)時(shí)性。而消費(fèi)類電子產(chǎn)品正朝著多功能、低成本的方向發(fā)展。隨著ARM9功能的不斷增強(qiáng),利用系統(tǒng)本身處理器實(shí)現(xiàn)MP3軟解碼成為可能。另外,軟件實(shí)現(xiàn)更便于產(chǎn)品功能的升級和維護(hù),可以預(yù)見,嵌入式MP3軟解碼器的應(yīng)用將越來越廣泛。這里在分析MPEG I Audio Lay-er3解碼算法的基礎(chǔ)上,提出基于ARM946E處理器實(shí)現(xiàn)解碼算法的軟件優(yōu)化方法。
Abstract:
Key words :

        MP3(MPEG I Audio Layer 3)格式是基于電影專家組系統(tǒng)(Motion Picture Expert Group,MPEG)壓縮標(biāo)準(zhǔn)的一種聲音文件格式,其壓縮比根據(jù)采樣頻率、壓縮位率和聲音模式的不同而有所變化。MP3具有很高的壓縮率,可以達(dá)到1:12。一分鐘左右的CD音樂經(jīng)過MP3格式壓縮編碼后,可以壓縮到1兆左右的容量,其音色和音質(zhì)還可以保持基本完整而不失真。隨著數(shù)字音樂的不斷普及,現(xiàn)在MP3音樂已經(jīng)不僅局限于MPEG視頻應(yīng)用中,而是以一種獨(dú)立的數(shù)字音樂壓縮技術(shù)出現(xiàn)在計(jì)算機(jī)、網(wǎng)絡(luò)和各種電子設(shè)備上。目前市場流行的MP3播放器是基于DSP和專用芯片的解決方案,通過硬件或?qū)S盟惴▽?shí)現(xiàn)解碼,具有良好的實(shí)時(shí)性。而消費(fèi)類電子產(chǎn)品正朝著多功能、低成本的方向發(fā)展。隨著ARM9功能的不斷增強(qiáng),利用系統(tǒng)本身處理器實(shí)現(xiàn)MP3軟解碼成為可能。另外,軟件實(shí)現(xiàn)更便于產(chǎn)品功能的升級和維護(hù),可以預(yù)見,嵌入式MP3軟解碼器的應(yīng)用將越來越廣泛。這里在分析MPEG I Audio Lay-er3解碼算法的基礎(chǔ)上,提出基于ARM946E處理器實(shí)現(xiàn)解碼算法的軟件優(yōu)化方法。

 
  1 MPEG Audio Layer3的解碼流程
 
  MP3解碼算法流程如圖1所示。
 
 
  主要過程包括:數(shù)據(jù)流解碼、Huffman解壓縮、反量化與重排序、立體聲解碼、IMDCT和子帶合成運(yùn)算等。其中Huffman解碼與反量化、IMDCT和子帶合成等3個過程在MP3解碼過程中占用了最多的CPU和內(nèi)存資源,是嵌入式系統(tǒng)實(shí)現(xiàn)軟件解碼的關(guān)鍵。
 
  2 ARM946E處理器
 
  ARM946E處理器屬于ARM9內(nèi)核帶有E擴(kuò)展的一個可綜合版本,執(zhí)行v5TE架構(gòu)指令。采用5級流水線,存儲器系統(tǒng)根據(jù)哈佛體系結(jié)構(gòu)重新設(shè)計(jì),獨(dú)立的數(shù)據(jù)和指令總線。帶有一套存儲器子系統(tǒng),以提高系統(tǒng)性能和支持大型操作系統(tǒng)。
 
  如圖2所示,存儲器子系統(tǒng)包含1個存儲器保護(hù)單元(MPU)、高速緩存(Cache)和寫緩沖(Write Buffer);CPU通過該子系統(tǒng)與系統(tǒng)存儲器相連。
 
 
  相對于ARM7,ARM9E性能上的提高主要表現(xiàn)在工作頻率、改進(jìn)的硬件特性及優(yōu)化的指令執(zhí)行效率。另外,ARM9E集成了輕量級的DSP處理能力,以很小的成本(CPU增加功能需要增加硬件)換來非常實(shí)用的DSP性能。充分利用好芯片資源是實(shí)現(xiàn)MP3解碼優(yōu)化的關(guān)鍵。
 
  3 算法優(yōu)化
 
  針對MP3中涉及較大運(yùn)算的Huffman解碼與反量化、IMDCT和子帶合成,分別提出算法優(yōu)化處理。3.1 定長查找冗余表Huffman解碼算法Huffman解碼器可以通過從頭至尾逐一檢測各符號,以查表比較的方式進(jìn)行解碼。即從一維的bit流中分辨出各個長度不同的Huffman碼字,然后進(jìn)行復(fù)雜的匹配。
 
  由于LayeIⅢ中的Huffman碼表組長度不一,會增加碼字的搜索時(shí)間。定長查找冗余表法擴(kuò)充Huff_man查找表,每次選取定長N bit碼流作為查找索引。查找表中包括跳轉(zhuǎn)指針和編碼值。若節(jié)點(diǎn)索引值為跳轉(zhuǎn)指針時(shí),將通過擴(kuò)充Huff-man查找表得知此Huffman編碼的后續(xù)bit數(shù),并跳轉(zhuǎn)到另外一個節(jié)點(diǎn);然后再根據(jù)后續(xù)bit數(shù)從碼流中取值;接著從上次跳轉(zhuǎn)節(jié)點(diǎn)開始查找,如此重復(fù)直到找出對應(yīng)huffman編碼的內(nèi)容。查找表利用Union數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn),可減小Huffman表占用的空間。假設(shè)一Huff-man編碼長度為l,采用傳統(tǒng)算法需要1次移位操作和1次比較,使用定長查找法只需[z/N]次查找和[l/N]次比較操作。
 
  表1,表2是Huffman解碼的舉例說明:
 
 
 
 
 
  計(jì)算量可降低一半。
 
  子帶合成濾波在解碼過程中包括了32點(diǎn)到64點(diǎn)的IMDCT處理,如式(3)所示:
 
 
  由于N(i)(k)具有對稱特性,可以得出:
 
 
  只要計(jì)算0≤i<n/4和n/2+1≤i<3n/4范圍的V(i)值即可。其減少了將近一半的計(jì)算量。
 
  4 代碼優(yōu)化
 
  根據(jù)ARM946E處理器硬件特點(diǎn),對實(shí)時(shí)性要求較高的關(guān)鍵程序進(jìn)行C語言和ARM匯編級代碼優(yōu)化。
 
  4.1 減計(jì)數(shù)循環(huán)體
 
  IMDCT和子帶合成濾波器組2個運(yùn)算量最大部分中有多個循環(huán)體運(yùn)算,為了提高執(zhí)行效率,推薦使用減計(jì)數(shù)循環(huán)體。
 
  如表3所示,對于固定次數(shù)的循環(huán),減計(jì)數(shù)循環(huán)比增計(jì)數(shù)循環(huán)速度快。這是因?yàn)槊看卧鲇?jì)數(shù)循環(huán)體外加3條指令,而減計(jì)數(shù)循環(huán)體外只有2條指令,減循環(huán)終止條件為減計(jì)數(shù)到零,而不是計(jì)數(shù)增加到某個特定的限制值。由于減計(jì)數(shù)結(jié)果已存儲在指令條件標(biāo)志里,省去與零比較指令。
 
 
 4.2 內(nèi)聯(lián)函數(shù)和內(nèi)嵌匯編
 
  MP3解碼算法中定點(diǎn)化乘法都是通過函數(shù)調(diào)用來實(shí)現(xiàn),每次調(diào)用需要開銷23~28個時(shí)鐘周期,其中超過15個周期用于函數(shù)調(diào)用時(shí)PC指針以及寄存器壓棧保護(hù)上。采用內(nèi)聯(lián)函數(shù)方式(使用關(guān)鍵字_inline聲明)或宏指令,在編譯階段代碼段將被直接展開。另外armcc編譯器允許在C源程序中使用內(nèi)嵌匯編(但代碼可移植性差),使用包括匯編的內(nèi)嵌函數(shù),可以使編譯器支持通常不能有效使用的ARM指令和優(yōu)化方法,例如C編譯器不支持的ARM v5E擴(kuò)展指令。使用內(nèi)聯(lián)函數(shù)結(jié)合內(nèi)嵌匯編實(shí)現(xiàn)移位乘法,可使平均時(shí)鐘周期縮短為6~8個。
 
 
  4.3 ARM DSP擴(kuò)展指令的運(yùn)用
 
  ARM946E處理器支持ARMDSP擴(kuò)展指令,主要包括3個類型:
 
  (1)單周期的16×16和32×16 MAC操作;
 
  (2)對原有的算術(shù)運(yùn)算指令增加了飽和處理擴(kuò)展;
 
  (3)前導(dǎo)零(CLZ)運(yùn)算指令,提高歸一化、浮點(diǎn)運(yùn)算以及除法操作的性能。
 
  ARM處理器不支持浮點(diǎn)運(yùn)算,經(jīng)過測試及分析,定點(diǎn)運(yùn)算中數(shù)值的截?cái)嗾`差選擇為28 b,其可以達(dá)到較好的解碼音質(zhì),不會因?yàn)楸暨^多而影響播放效果。
 
  完成類似的乘法功能,ARM的SMULL(32×32)指令需要3個周期,而ARMDSP擴(kuò)展指令SMULWT(32×16)只需要1個周期。從數(shù)據(jù)的準(zhǔn)確性上分析,由于乘數(shù)的精度為16 b,最終結(jié)果有些差異,但由于MP3解碼運(yùn)算都是基于28 b的定點(diǎn)數(shù)值的,所以通常的運(yùn)算都是一個運(yùn)算結(jié)果跟某一個固定定點(diǎn)表中的數(shù)據(jù)相乘的。若選擇固定定點(diǎn)表中數(shù)據(jù)的高16 b數(shù)據(jù)進(jìn)行運(yùn)算,運(yùn)算的結(jié)果誤差在1 b以內(nèi)。
 
  為了驗(yàn)證使用ARMDSP擴(kuò)展指令的優(yōu)化效果,在系統(tǒng)120 MHz主頻下,以128 Kb/s的壓縮速率進(jìn)行編碼測試,采用的測試文件如表4所示。
 
 
  上述3個MP3測試文件的比特率均為128 Kb/s,使用這三首MP3歌曲進(jìn)行解碼分析結(jié)果如圖3所示。
 
 
  實(shí)驗(yàn)表明,使用ARMDSP擴(kuò)展指令比使用ARM一般指令解碼性能平均提高17.5%,主觀聽覺上音質(zhì)效果無差異。
 
  5 結(jié) 語

  這里充分利用ARM946E處理器的DSP擴(kuò)展指令特點(diǎn)提高程序代碼的執(zhí)行效率,對3個關(guān)鍵模塊:Huff-man解碼,IMDCT運(yùn)算,合成子帶濾波進(jìn)行算法優(yōu)化及簡化處理,減少了各模塊的運(yùn)算量,同時(shí)從C語言和ARM匯編層次來優(yōu)化代碼,取得了較好的實(shí)時(shí)MP3解碼效果。
 
來源:現(xiàn)代電子技術(shù)
此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲一二三四久久| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲欧美影院| 一本一本久久a久久精品综合麻豆| 亚洲国语精品自产拍在线观看| 激情久久久久| 国产一区二区三区无遮挡| 国产精品亚洲成人| 国产精品日韩欧美| 国产精品午夜春色av| 欧美性大战久久久久久久| 欧美日韩国产一区精品一区| 欧美国产乱视频| 欧美激情区在线播放| 欧美大尺度在线观看| 欧美电影在线观看完整版| 欧美国产第一页| 欧美激情综合五月色丁香小说| 欧美粗暴jizz性欧美20| 欧美激情一二三区| 欧美日产国产成人免费图片| 欧美精品少妇一区二区三区| 欧美久久久久久久久| 欧美日韩色一区| 欧美性久久久| 国产精品资源在线观看| 国产日韩欧美在线看| 国产亚洲精品资源在线26u| 国产亚洲欧美aaaa| 国产视频一区在线观看一区免费 | 影院欧美亚洲| 亚洲黄色免费电影| 中文精品在线| 欧美一区二区在线观看| 亚洲国产日韩综合一区| 亚洲卡通欧美制服中文| 亚洲午夜精品久久久久久app| 亚洲欧美日韩成人| 久久久www成人免费精品| 老妇喷水一区二区三区| 欧美精品一区二区视频| 国产精品久久久一区二区| 国产欧美韩日| 亚洲第一页中文字幕| 亚洲精品一区中文| 午夜精彩视频在线观看不卡| 亚洲国产女人aaa毛片在线| 日韩一区二区福利| 香蕉成人伊视频在线观看| 久久久亚洲高清| 欧美精品偷拍| 国产精品一区二区在线| 尹人成人综合网| 一区二区日韩| 欧美在线你懂的| 一区二区三区四区蜜桃| 久久er精品视频| 欧美高清hd18日本| 国产精品vvv| 激情视频一区| 亚洲天堂av电影| 91久久国产综合久久蜜月精品 | 国产亚洲精品自拍| 91久久精品一区二区别| 亚洲欧美999| 亚洲人成毛片在线播放女女| 亚洲女同同性videoxma| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日韩亚洲另类| 一区二区三区在线视频播放| 一区二区国产日产| 亚洲国产精品第一区二区| 亚洲亚洲精品三区日韩精品在线视频| 久久女同互慰一区二区三区| 欧美午夜精品久久久久久久| 在线观看久久av| 亚洲欧美www| 一区二区三区视频在线播放| 六月天综合网| 国产精品视频1区| 亚洲日本免费| 久久精品视频免费播放| 亚洲欧美国产精品桃花| 欧美精品国产一区二区| 韩国av一区二区三区四区| 亚洲一区二区三区高清| 日韩亚洲综合在线| 久热综合在线亚洲精品| 国产精品三级久久久久久电影| 亚洲精品日韩在线观看| 亚洲国产成人精品久久久国产成人一区| 亚洲天堂av图片| 欧美—级a级欧美特级ar全黄| 国产伊人精品| 亚洲欧美大片| 亚洲男女毛片无遮挡| 欧美日本一区| 亚洲国产网站| 亚洲国产成人久久综合| 久久国产精品久久国产精品| 国产精品久久久久久久久免费| 亚洲精品中文字| 亚洲精品小视频在线观看| 久久免费偷拍视频| 国产亚洲欧美另类中文| 亚洲欧美日韩中文视频| 亚洲一区久久久| 欧美色欧美亚洲高清在线视频| 91久久精品日日躁夜夜躁国产| 亚洲大片在线| 久久久91精品| 国产婷婷一区二区| 午夜精品久久久久久久白皮肤| 亚洲欧美www| 国产精品久久久久久久久久久久久 | **欧美日韩vr在线| 亚洲第一区在线| 久久人91精品久久久久久不卡| 国产热re99久久6国产精品| 亚洲一区在线免费观看| 亚洲欧美国产va在线影院| 国产精品国内视频| 中文日韩电影网站| 亚洲欧美不卡| 国产精品日韩精品| 亚洲综合色婷婷| 欧美伊人久久| 国产性猛交xxxx免费看久久| 午夜综合激情| 久久久久久网址| 国内久久精品| 亚洲第一中文字幕| 免费看亚洲片| 亚洲欧洲日产国码二区| 这里只有精品电影| 欧美视频成人| 亚洲中字在线| 久久久综合精品| 在线不卡视频| 亚洲精品国产欧美| 欧美精品激情| 亚洲网站视频福利| 久久成人在线| 伊人成人在线视频| 亚洲精品欧美专区| 欧美日韩亚洲激情| 亚洲影视综合| 久久久综合网站| 亚洲欧洲精品一区二区三区不卡 | 国产精品video| 亚洲欧美一区二区精品久久久| 久久精品国产在热久久| 在线观看日韩一区| 一区二区三区.www| 国产精品裸体一区二区三区| 午夜一区在线| 欧美成年人网| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲特级毛片| 久久久久久久久久久久久9999| 精久久久久久| 在线综合亚洲| 国产欧美日韩一区二区三区在线 | 午夜精品理论片| 麻豆精品一区二区av白丝在线| 亚洲三级免费电影| 欧美一区2区视频在线观看| 在线播放日韩欧美| 亚洲综合丁香| 在线不卡免费欧美| 亚洲一区二区三区在线播放| 国产在线精品一区二区中文| 亚洲每日在线| 国产区精品视频| 99在线精品视频在线观看| 国产精品香蕉在线观看| 91久久久亚洲精品| 国产精品女主播| 亚洲三级视频| 国产欧美日韩免费| 99在线精品观看| 好吊妞**欧美| 亚洲一级高清| 亚洲第一页在线| 午夜一区二区三区不卡视频| 一区二区三区在线不卡| 亚洲欧美日韩综合一区| 亚洲国产天堂久久国产91| 欧美一区二区三区在线视频 | 亚洲永久免费精品| 尤物yw午夜国产精品视频| 亚洲欧美成人一区二区三区| 在线免费日韩片| 久久成人免费| 一本色道久久综合狠狠躁篇的优点| 久久综合色婷婷| 亚洲欧美在线网| 欧美三级视频| 亚洲免费av电影| 原创国产精品91|