《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > 基于TMS320VC5509實現(xiàn)MP3解碼
基于TMS320VC5509實現(xiàn)MP3解碼
劉 毅, 姚若河, 鄭學(xué)仁
摘要: 介紹了利用數(shù)字信號處理芯片TMS320VC5509實現(xiàn)MP3解碼的方案。討論了MP3霍夫曼解碼方法,并利用DSP的C語言在TMS320VC5509上實現(xiàn)了該算法。利用CCS的Profile功能對運算復(fù)雜度進行了估算,結(jié)果顯示TMS320VC5509完全能夠達到該解碼算法的計算量要求,并能夠?qū)崿F(xiàn)實時解碼。
關(guān)鍵詞: DSP 邊信息 片上 16bit 64KB 地址總線
Abstract:
Key words :

  摘 要: 介紹了利用數(shù)字信號處理芯片TMS320VC5509實現(xiàn)MP3解碼的方案。討論了MP3霍夫曼解碼方法,并利用DSP的C語言在TMS320VC5509上實現(xiàn)了該算法。利用CCS的Profile功能對運算復(fù)雜度進行了估算,結(jié)果顯示TMS320VC5509完全能夠達到該解碼算法的計算量要求,并能夠?qū)崿F(xiàn)實時解碼。
  關(guān)鍵詞: DSP TMS320VC5509  McBSP  CCS  MP3  霍夫曼解碼


  TMS320VC5509(以下簡稱C5509)是TI公司C5000 DSP 系列中的新一代產(chǎn)品,該芯片最低工作電壓為0.9V,其核的最低功耗僅為0.05MW/MIPS,性能最高可達800 MIPS。C5509為嵌入式DSP應(yīng)用及高性能儀器儀表、智能機器人、手持設(shè)備、數(shù)字音頻播放器和數(shù)碼相機等應(yīng)用提供了有效的解決方案。MP3是指MPEG(活動圖像專家組)國際標準音頻第三層編/解碼,MP3編碼是通過將音頻信號由時域信號轉(zhuǎn)換為頻域信號,并根據(jù)人類心理聲學(xué)特征去除部分冗余信息實現(xiàn)的,ISO/IEC11172-3 Part 3給出了詳細的編/解碼標準。解碼涉及霍夫曼解碼、修正余弦反變換(IMDCT)、子帶合成等復(fù)雜運算模塊。本文利用C5509實現(xiàn)對MP3的解碼運算。
1 C5509 DSP 處理器的特點和工作原理
1.1 C5509 DSP的性能概述

  C5509有32×16bit" title="16bit">16bit指令緩沖隊列,可實現(xiàn)高效的塊循環(huán)操作;兩個17×17bit的MAC單元,可在單周期內(nèi)執(zhí)行兩次MAC操作;1個40bit的ALU、1個40bit的桶型移位器,4個40bit的累加器可執(zhí)行比C54系列DSP更高效的算術(shù)運算,在400MHz的晶振驅(qū)動下,可達到800MIPS的性能。以44.1kHz采樣率的MP3數(shù)據(jù)流為例,對128kbit/s數(shù)據(jù)率的MP3數(shù)據(jù)進行解碼。霍夫曼解碼、IMDCT、子帶合成等運算模塊共需消耗1.3MIPS的CPU資源,對于平均每秒必須解碼44.6幀數(shù)據(jù)來講,總運算量為44.6×1.3=57.98MIPS,C5509完全可以滿足此速度要求。
  C5509還具有128K×16bit的片上" title="片上">片上RAM,其中包括64KB" title="64KB">64KB的DARAM、192KB的SARAM和64KB的片上ROM。
  與眾多TMS320系列DSP處理器一樣,C5509采用了哈佛結(jié)構(gòu),共有12組獨立總線,其中包括3組數(shù)據(jù)讀總線、2組數(shù)據(jù)寫總線、5組數(shù)據(jù)地址總線" title="地址總線">地址總線、1組程序讀總線和1組程序地址總線,這些總線并行地為各個計算單元提供指令和操作碼,從而為高速的數(shù)據(jù)運算提供了有力的保障。
1.2 C5509 DSP的外設(shè)介紹
  C5509提供了專用的外部存儲器接口(EMIF),用于控制DSP與外部存儲器之間所有數(shù)據(jù)的傳輸。可與EMIF無縫鏈接的存儲器有:異步存儲器(ROM、FLASH、 SRAM)、同步突發(fā)SRAM、同步DRAM(SDRAM),并可支持可選的32、16、8位數(shù)據(jù)訪問。對EMIF編程時,必須根據(jù)實際的外部存儲器考慮如何分配片內(nèi)使能空間(CE)。通過EMIF接口,主處理器可將數(shù)據(jù)和程序置于片外,從而節(jié)省了片上硬件資源。
  其次,C5509有3個獨立的多通道緩存串口(McBSP),使得C5509能夠直接與其他C55xx系列DSP、多媒體數(shù)字信號編解碼器等設(shè)備高速互連,這些McBSP可以提供全速雙工通信,并支持128通道的收發(fā),接收或者發(fā)送可以選擇使用獨立的時鐘,字寬為8、12、16、20、24位任選。
  為保證與常見的異步通信模塊進行數(shù)據(jù)通信,C5509提供了與TL16C550C等專用異步通信接口IC互連的UART,外部數(shù)據(jù)經(jīng)由TL16C550C進出DSP的UART,最終交給片內(nèi)CPU處理。圖1為與C5509配合使用的典型專用異步通信接口IC(TL16C550C)的管腳圖。
  C5509的UART每接到數(shù)據(jù)就會產(chǎn)生相應(yīng)的中斷請求,通知CPU及時采集數(shù)據(jù),將Rx線上的串行數(shù)據(jù)放入接收寄存器中,在滿足緩沖區(qū)長度后,寄存器的并行數(shù)據(jù)再交給CPU做后續(xù)處理。


2 解碼算法說明
2.1 MP3文件的格式
  MP3文件以幀為基本單位,每幀的構(gòu)成如表1所示。由于MP3文件數(shù)據(jù)格式采用了比特池技術(shù),故主數(shù)據(jù)有可能在幀頭之前,具體位置可由幀邊信息" title="邊信息">邊信息所包含的main_data_begin變量獲得。


  解碼時首先將一定長度(本系統(tǒng)為2kbit)的數(shù)據(jù)讀入C5509的內(nèi)部RAM中,然后尋找?guī)耐阶謘ync_word(FFF)。如果找到同步字,則以其為首的32bit即為幀頭。由幀頭中的校驗位可知是否有校驗數(shù)據(jù),如無,則其后的256bit數(shù)據(jù)即為幀邊信息。主數(shù)據(jù)一般包含兩個粒度組(gr)的數(shù)據(jù),每個粒度組又包含左右聲道(ch)兩部分的數(shù)據(jù)信息,各個聲道數(shù)據(jù)可獨立解碼,故將每個粒度單個聲道解碼的程序編寫為單個的*.c文件,以適應(yīng)單聲道或者其他MP3格式的解碼。MP3編碼根據(jù)人類心理聲學(xué),將每個粒度組分為三部分數(shù)據(jù):第一部分對應(yīng)低頻采樣的Big_values(大值區(qū)),用較大絕對值的量化值存放低頻值;第二部分為Count1區(qū),用絕對值較小的量化值存放中頻值,所有量化值的可能取值為1,0,-1;第三部分為編碼為零的Zero高頻區(qū),零數(shù)據(jù)無須在MP3文件中出現(xiàn),只需在解碼時詢問每個粒度組的計數(shù)是否已經(jīng)達到576。若計數(shù)為576,則說明該粒度組已解完576個頻率線的量化值。
  上述幀邊信息存儲了供后續(xù)解碼的全部重要信息。為方便引用,將其定義為結(jié)構(gòu)體。部分元素的定義和注釋如下:
  struct Granule {
  unsigned part2_3_length;  //用以計算Count1
               //區(qū)位置;
  unsigned big_values;       //用以計算Big_values
               //區(qū)位置;
  unsigned table_select[3];  //用以確定查找哪一
                 //個霍夫曼表;
  ……
  };
  table_select[3]的值就是霍夫曼表的下標h,可在解主數(shù)據(jù)時鎖定某個具體的霍夫曼表。
2.2 MP3數(shù)據(jù)的霍夫曼解碼原理
  如上小節(jié)所述,每個粒度組的數(shù)據(jù)根據(jù)聲學(xué)特性將0到奈奎斯特頻率的頻率線分為Big_values、Count1和Zero三個區(qū)。在解碼時,Big_values區(qū)對應(yīng)的霍夫曼碼表格式如表2所示,而Count1區(qū)碼表格式如表3所示。

 


  存放霍夫曼碼表的文件huffman.h中包含32個供Big_values區(qū)查詢用的碼表和2個供Count1區(qū)查詢用的碼表。為了方便快速查得短長度的編碼值,還增加了輔助表h_cue[34][16]。當開始解主數(shù)據(jù)時,將定長(例如32位)數(shù)據(jù)dataword()入棧,首先移出該緩存區(qū)的前四位數(shù)據(jù),作為查輔助表的頭數(shù)據(jù)lead,然后根據(jù)lead值和幀邊信息中的霍夫曼查找表下標h,得出輔助表的具體數(shù)據(jù)h_cue[h][lead],這個數(shù)據(jù)只是指向Big_values區(qū)或者Count1區(qū)某個表的首地址h_tab,具體要用到該表的哪個數(shù)據(jù)仍需程序提供一個偏移量繼續(xù)判斷。此時可以先由緩存區(qū)中去掉lead四個位的數(shù)據(jù)與鎖定的霍夫曼表對比,如果這后面的數(shù)據(jù)與被鎖定的霍夫曼表頭的碼字一致,則可馬上得到解碼的數(shù)據(jù);若是兩個碼字不一致,則還需由h_cue[h][lead]和h_cue[h][lead+1]的差值得到偏移量,從而最終得到正確的解碼數(shù)據(jù)。(格式如表2和表3所示)。
  另外,由于MP3編碼中對絕對值小于等于15的量化值直接編碼,對絕對值大于15的量化值采用ESC(附加值)編碼,所以在得到加碼數(shù)據(jù)后還需判斷是否要為其添加附加值和符號位。詳細的解碼流程如圖2所示。


  MP3解碼的主要運算量集中在霍夫曼解碼、反量化、IMDCT、子帶合成四個運算模塊,而霍夫曼解碼占整個運算量總和的1/5。利用CCS的Profile工具對44.1kHz采樣率、128kbps比特率的MP3數(shù)據(jù)進行運算復(fù)雜度的估算,可得本系統(tǒng)的解碼模塊消耗的運算量為1.3MIPS。由此可知,對于每秒解50幀以上的實時解碼,DSP要承擔(dān)65MIPS的運算復(fù)雜度,利DSP實現(xiàn)的本解碼模塊是完全可以勝任的。
參考文獻
1 彭啟琮. TMS320VC55x系列DSP的CPU與外設(shè). 北京:清華大學(xué)出版社,2005:275~388
2 TMS320VC5509A Fixed-Point Digital Signal Processor Data Manual.Texas Instruments Incorporated,2005:13~50
3 TMS320C55x DSP Programmer’s Guide. Texas Instruments  Incorporated, 2001:4~84
4 范建軍. MP3文件格式剖析.咸寧師專學(xué)報,2002;22(6):77~79
5 王潮營. 基于DSP的MP3解碼器的研究與實現(xiàn)(碩士學(xué)位論文).哈爾濱:哈爾濱工程大學(xué)信息與通信工程學(xué)院,2004:9~25

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩四区| 久久国产精品久久久久久久久久| 国产精品久久| 亚洲欧美精品在线| 亚洲欧美制服中文字幕| 狠狠色丁香婷婷综合影院| 欧美精品久久久久a| 亚洲欧美日韩在线不卡| 欧美一区永久视频免费观看| 亚洲国产精品99久久久久久久久| 欧美日韩一区综合| 欧美日韩福利视频| 久久国产欧美| 欧美一区激情视频在线观看| 亚洲国产成人不卡| 一区二区三区av| 黄色精品网站| 国产一区二区三区观看| 欧美精品日韩综合在线| 欧美激情精品久久久久久久变态| 亚洲欧美www| 亚洲欧美精品| 欧美在线视频全部完| 亚洲欧洲久久| 亚洲欧美久久| 91久久精品国产| 国产欧美日韩综合精品二区| 欧美激情乱人伦| 欧美日韩高清在线播放| 欧美日本一道本| 久久久久久久一区二区| 亚洲一区二区成人| 亚洲国产婷婷| 亚洲免费伊人电影在线观看av| 在线观看中文字幕亚洲| 国产欧美日韩亚洲一区二区三区| 国产农村妇女毛片精品久久麻豆 | 亚洲无毛电影| 亚洲国产精品日韩| 亚洲毛片在线观看.| 韩国自拍一区| 亚洲国产精品成人久久综合一区 | 亚洲视频在线观看网站| 久久精品国产99精品国产亚洲性色 | 亚洲第一区中文99精品| 亚洲免费成人| 欧美一区二区福利在线| 9国产精品视频| 亚洲国产精品一区二区第一页 | 亚洲国产精品久久久久| 99re成人精品视频| 午夜精品网站| 免费观看成人www动漫视频| 亚洲欧美国产精品va在线观看| 欧美在线日韩| 欧美大片免费观看在线观看网站推荐 | 国产精品久久久久久久午夜片 | 亚洲午夜一区| 亚洲精品视频二区| 尤物精品在线| 一区二区三区国产精品| 欧美一区永久视频免费观看| 亚洲乱码久久| 日韩视频免费大全中文字幕| 亚洲一级二级在线| 久久美女艺术照精彩视频福利播放| 欧美大片在线观看一区| 国产精品高清网站| 亚洲国产高清一区二区三区| 亚洲夜间福利| 亚洲免费久久| 久久亚洲精选| 久久女同精品一区二区| 欧美日韩国产首页在线观看| 国产女主播一区二区三区| 亚洲国产天堂久久国产91| 亚洲欧美日韩天堂| 一区二区国产日产| 亚洲免费观看高清完整版在线观看| 亚洲综合激情| 欧美另类69精品久久久久9999| 国产亚洲欧美另类中文| 亚洲精选一区二区| 亚洲国产精品久久精品怡红院| 午夜一区二区三区在线观看| 亚洲一区高清| 午夜精品在线视频| 欧美福利视频网站| 国产亚洲欧美日韩一区二区| 99精品视频免费观看视频| 亚洲人成啪啪网站| 亚洲美女av在线播放| 性欧美1819性猛交| 亚洲一区网站| 欧美日韩国产小视频| 亚洲国产精品黑人久久久| 欧美在线亚洲一区| 亚洲国产精品久久精品怡红院| 欧美一区二区三区免费视频| 欧美日韩直播| 日韩视频在线观看国产| 亚洲人成在线播放| 一区二区av| 欧美成人综合一区| 一区在线视频观看| 日韩性生活视频| 99成人精品| 欧美精品一区在线| 亚洲国产一区二区a毛片| 亚洲成人中文| 一本色道**综合亚洲精品蜜桃冫| 亚洲欧美国产日韩天堂区| 欧美日本一区| 91久久精品国产91久久性色| 亚洲国产精品久久久久久女王| 久久久久久久综合狠狠综合| 国产日韩一区二区三区| 在线观看亚洲精品| 久久精品99国产精品日本| 久久久蜜桃一区二区人| 国产日产亚洲精品| 香蕉亚洲视频| 久久久久久久久久久成人| 国产亚洲毛片在线| 欧美在线欧美在线| 久久免费99精品久久久久久| 国产自产精品| 日韩午夜av电影| 9l国产精品久久久久麻豆| 欧美精品久久久久久久| 最新国产成人av网站网址麻豆| 日韩亚洲欧美成人| 欧美日韩国产色站一区二区三区| 一本色道**综合亚洲精品蜜桃冫| 亚洲视频一二区| 国产精品福利在线| 午夜日韩在线| 久久资源av| 国产精品porn| 亚洲电影免费在线观看| 亚洲免费视频成人| 欧美在线影院| 狠狠色伊人亚洲综合成人| 亚洲人成7777| 欧美视频一区二区在线观看| 在线日本成人| 日韩视频一区二区三区| 欧美日韩精品三区| 亚洲一区免费在线观看| 久久免费99精品久久久久久| 亚洲国产精品传媒在线观看| 亚洲四色影视在线观看| 国产精品视频免费观看| 亚洲精品免费观看| 亚洲欧美精品伊人久久| 国产一区二区三区久久久| 亚洲欧洲一二三| 国产精品大片| 亚洲欧美在线播放| 快射av在线播放一区| 亚洲美女性视频| 久久精品国产亚洲精品| 亚洲欧洲视频| 欧美一区二区三区久久精品| 在线免费高清一区二区三区| 99精品欧美一区二区蜜桃免费| 国产精品美女| 夜夜嗨av一区二区三区免费区| 小嫩嫩精品导航| 亚洲第一在线综合网站| 亚洲免费在线| 亚洲黄色成人久久久| 亚洲欧美国内爽妇网| 尤物网精品视频| 亚洲欧美另类在线观看| 伊人成年综合电影网| 亚洲字幕一区二区| **性色生活片久久毛片| 亚洲影院色无极综合| 在线观看不卡av| 欧美伊久线香蕉线新在线| 亚洲精品一区二区三区蜜桃久| 久久国产福利| 99www免费人成精品| 久久综合给合久久狠狠狠97色69| 一区二区三区福利| 老司机午夜精品视频| 亚洲天堂av图片| 母乳一区在线观看| 亚洲丰满在线| 性色av香蕉一区二区| 亚洲黄页视频免费观看| 欧美诱惑福利视频| 亚洲免费高清视频| 免费久久99精品国产| 亚洲午夜av在线| 欧美精品成人| 亚洲电影毛片| 国产片一区二区| 亚洲一区免费在线观看|