<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > MPEG聲音編碼系統的單片DSP實(shí)現

MPEG聲音編碼系統的單片DSP實(shí)現

作者: 時(shí)間:2012-04-05 來(lái)源:網(wǎng)絡(luò ) 收藏

本文引用地址:http://dyxdggzs.com/article/257594.htm

(2)輸入數據的組織 輸入數據的組織不但要考慮方便地從數模轉換器取得聲音原始數據,還要考慮輸入數據在片內數據RAM的存儲適合作為多相濾波器組和聲學(xué)模型的FFT運算的輸入.多相濾波器組每次移入32個(gè)新的聲音數據,移出32個(gè)舊的樣值,操作如下:

Xi=Xi-32,i=511,510,…,32
Xi=next-input-audio-sample,i=31,30,…,0

然而A-2181并不適于實(shí)現數據的移動(dòng),每個(gè)賦值運算需要兩個(gè)指令才能完成,每次分析濾波操作需要1024個(gè)指令周期.如果利用A- 2181的多通道自動(dòng)緩沖串口及間接尋址能力,適當地組織輸入聲音數據,就可利用滑動(dòng)窗的方法實(shí)現數據的移入和移出,如圖2所示.


圖2 多相濾波的滑動(dòng)窗技術(shù)

為了保證幀邊界處理的連續性,輸入數據緩存應該設計成圓緩沖的形式,其長(cháng)度應能存儲兩幀聲音輸入數據.當在處理一幀數據時(shí),輸入數據可以緩沖到另一幀.這樣,數據移動(dòng)的開(kāi)銷(xiāo)就節約了.同時(shí),輸入數據的組織還要利于聲學(xué)模型的FFT運算,FFT需要利用ADSP-2181的地址反轉尋址模式.由于 FFT計算和輸入數據的緩存是同時(shí)進(jìn)行的,所以FFT計算的指針需要地址反轉,而輸入緩沖的指針卻不能地址反轉,否則會(huì )導致輸入聲音數據排列混亂. ADSP-2181提供這種能力,它的第一地址指針組I0,I1,I2,I3有地址反轉能力,而第二地址指針組I4,I5,I6,I7卻不受地址反轉模式的影響.所以從第二地址指針組中選擇指針進(jìn)行輸入緩沖,從第一地址指針組中選擇指針進(jìn)行FFT計算.

(3)聲學(xué)模型的改進(jìn) 用DSP實(shí)現心理聲學(xué)模型的一個(gè)難題是其中有大量的對數運算,雖然可以用多項式逼近求得其近似值,但是其巨大的運算量說(shuō)明這不是一個(gè)明智的選擇.在改進(jìn)的心理聲學(xué)模型中,FFT運算后并不立即換算到對數域,而是用分段折線(xiàn)逼近線(xiàn)性域的掩蔽效應曲線(xiàn).為簡(jiǎn)單起見(jiàn),使用與標準一致的分段方法.逼近采用取指數的多項式展開(kāi)的一次項的方法,這種方法雖然比較粗糙,但正如前面分析的那樣,聲學(xué)模型在16bit定點(diǎn)實(shí)現時(shí)不是主要矛盾,因而還是可以接受的.

得到掩蔽門(mén)限以后,為計算信掩比供比特分配使用,還是需要從線(xiàn)性域轉換到對數域.這時(shí),我們采用一種利用ADSP-2181移位器的近似計算方法.通過(guò)EXP指令,可以提取2進(jìn)制補碼小數的指數,對能量而言又有1bit約3dB.因而指數值乘3就近似得到該補碼小數的dB值,尾數部分的影響忽略不計.

(4)比例因子的編碼 標準中一共給出了63個(gè)比例因子,但是并不是所有這些比例因子都可以用16bit的2進(jìn)制數表示.如果用雙字進(jìn)行精度擴展,在量化時(shí)又將面臨雙字除法的巨大開(kāi)銷(xiāo),因此,只使用其中可以用16bit的2進(jìn)制補碼小數精確表示的子集,即序號為3的倍數且小于等于45 的比例因子.

采用比例因子子集后,比例因子編碼就可以不再通過(guò)比較的方法得到,而可以直接通過(guò)計算子帶最大幅度的指數獲得,簡(jiǎn)化了比例因子的編碼.

(5)軟件仿真結果 結合上述各項算法改進(jìn),根據ADSP-2181的特點(diǎn)和標準,用AD公司的開(kāi)發(fā)軟件進(jìn)行了軟件仿真.表1列出了仿真得到的各個(gè)模塊對運算量和存儲量要求進(jìn)行的估算結果.仿真在抽樣率為48kHz,編碼模式為立體聲,輸入信號為頻率為1kHz的正弦波,輸出碼率為 192kbit/s的情況下進(jìn)行.

由表1可知,ADSP-2181的性能得到了較充分的利用.仿真結果表明,在以上的條件下,解碼輸出的信噪比可達80dB左右.可見(jiàn),所作的算法改進(jìn)是比較有效的.

表1 各模塊的運算量和存儲量要求

4 硬件設計

硬件結構框圖如圖3所示.各模塊的基本功能如下:


DSP核:除完成所有編碼算法以外,還要完成對模數轉換電路的初始化配置;通過(guò)輔助控制電路選擇抽樣時(shí)鐘,通過(guò)接口電路接受主機的編碼參數.

輔助控制電路:由FPGA及附屬電路實(shí)現,完成時(shí)鐘的產(chǎn)生、FIFO狀態(tài)的監測、地址譯碼等功能.

輸出緩沖:編碼碼流的暫時(shí)存儲區,同時(shí)提供完全異步的輸出接口方式.在需要實(shí)現圖象聲音唇形同步的應用中特別有用.

外部存儲器:包括BDMA空間、I/O空間.

模數轉換電路:完成聲音的數字化,直接與DSP的串口0連接.抽樣頻率由外部提供的256倍抽樣時(shí)鐘的頻率決定,正常工作前需要進(jìn)行初始化.

接口電路:接口電路分為兩部分,一部分是編碼輸出接口,另一部分是與主機連接的接口.主機接口使用RS232接口芯片完成DSP串口1與主機串口的連接,DSP使用中斷和內部計時(shí)器實(shí)現異步串型通信.

上述方案已經(jīng)在“九五”科技攻關(guān)項目中實(shí)現,實(shí)時(shí)編解碼的聲音通過(guò)了主觀(guān)測試.



上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: MPEG DSP 聲音編碼

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>