新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于TMS320VC5509實現MP3解碼

        基于TMS320VC5509實現MP3解碼

        作者: 時間:2010-03-04 來源:網絡 收藏

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

          另外,由于編碼中對絕對值小于等于15的量化值直接編碼,對絕對值大于15的量化值采用ESC(附加值)編碼,所以在得到加碼數據后還需判斷是否要為其添加附加值和符號位。詳細的流程如圖2所示。

        基于TMS320VC5509實現MP3解碼


          解碼的主要運算量集中在霍夫曼解碼、反量化、IMDCT、子帶合成四個運算模塊,而霍夫曼解碼占整個運算量總和的1/5。利用CCS的Profile工具對44.1kHz采樣率、128kbps比特率的數據進行運算復雜度的估算,可得本系統的解碼模塊消耗的運算量為1.3MIPS。由此可知,對于每秒解50幀以上的實時解碼,DSP要承擔65MIPS的運算復雜度,利DSP的本解碼模塊是完全可以勝任的。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 怀安县| 军事| 临泉县| 汨罗市| 建阳市| 乌鲁木齐县| 德化县| 锦屏县| 兰溪市| 岗巴县| 泰宁县| 临澧县| 庆云县| 通州区| 涿鹿县| 镇宁| 巴青县| 出国| 连山| 安多县| 遂宁市| 乐陵市| 射阳县| 东城区| 隆德县| 宁陵县| 土默特右旗| 门头沟区| 茶陵县| 沙湾县| 溆浦县| 乳源| 闽侯县| 凤山县| 古交市| 竹北市| 襄垣县| 修水县| 安庆市| 沈丘县| 铜鼓县|