《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 嵌入式技術(shù) > 業(yè)界動(dòng)態(tài) > 采用DSP內(nèi)核技術(shù)進(jìn)行語(yǔ)音壓縮開(kāi)發(fā)

采用DSP內(nèi)核技術(shù)進(jìn)行語(yǔ)音壓縮開(kāi)發(fā)

2009-06-30
作者:翟東力 王曉蕾

  摘 要: 介紹了一種采用DSP內(nèi)核芯片設(shè)計(jì)開(kāi)發(fā)的手持式語(yǔ)音設(shè)備。該語(yǔ)音設(shè)備無(wú)需開(kāi)發(fā)系統(tǒng)支持,語(yǔ)音播放時(shí)間長(zhǎng)達(dá)200分鐘,而壓縮比達(dá)到46:1,僅使用一片32兆位的閃速存儲(chǔ)器就可保存全部數(shù)據(jù)。
  關(guān)鍵詞: DSP內(nèi)核 語(yǔ)音壓縮


  隨著儀器儀表人機(jī)界面越來(lái)越趨于人性化,語(yǔ)音識(shí)別的需求不斷增長(zhǎng),語(yǔ)音處理技術(shù)發(fā)展迅速,各種處理算法層出不窮,為大容量的語(yǔ)音應(yīng)用提供了愈加靈活的技術(shù)手段。然而,語(yǔ)音數(shù)據(jù)的壓縮比越高,數(shù)據(jù)回放算法所要求的計(jì)算能力也越強(qiáng)。目前,大多數(shù)高壓縮比的語(yǔ)音壓縮數(shù)據(jù)生成必須采用專(zhuān)用的語(yǔ)音開(kāi)發(fā)工具和開(kāi)發(fā)版權(quán),這給國(guó)內(nèi)的小規(guī)模用戶造成了一定的困難。在8K的采樣速率下,同樣是使用4兆位的flash芯片來(lái)存儲(chǔ)數(shù)據(jù),不同的語(yǔ)音算法所能提供的回放時(shí)間有很大差異。例如,采用ADPCM(自適應(yīng)增量脈沖編碼)算法只可提供128秒的回放時(shí)間,而采用TI的LPC(線性預(yù)測(cè)編碼)算法卻可得到50分鐘的回放時(shí)間。在某一工程項(xiàng)目中,我們需要開(kāi)發(fā)一種回放時(shí)間長(zhǎng)達(dá)200分鐘的低成本手持語(yǔ)音設(shè)備,由于使用了DSP內(nèi)核芯片,在較短的時(shí)間內(nèi)完成了開(kāi)發(fā)工作,達(dá)到了預(yù)先提出的性能指標(biāo)。
1 語(yǔ)音算法與芯片特點(diǎn)
  在本項(xiàng)目中,我們選擇了DSP集團(tuán)的語(yǔ)音壓縮最新算法Triple Rate Coder,其壓縮比達(dá)到了46:1,且音質(zhì)良好,MOS指標(biāo)達(dá)到了3.98。
  該算法的基本思想是:首先將語(yǔ)音分為若干小段,由于語(yǔ)音信號(hào)的譜變化是一個(gè)緩變量,因此在每一小段內(nèi)信號(hào)是平穩(wěn)變化的。然后用一個(gè)數(shù)字濾波器和一個(gè)激勵(lì)函數(shù)來(lái)表示這一段時(shí)域波形的離散采樣序列。在實(shí)際算法中是采用了一個(gè)十階的線性預(yù)測(cè)濾波器,計(jì)算時(shí)還將每一幀分為4個(gè)子幀,每一子幀的濾波器系數(shù)矢量由上一幀和本幀數(shù)據(jù)計(jì)算得到,而最后一子幀的濾波器系數(shù)矢量則由矢量分解預(yù)測(cè)法得到;激勵(lì)函數(shù)采用的是偽隨機(jī)多脈沖激勵(lì)函數(shù),由最大似然算法得到。對(duì)每一幀計(jì)算得到濾波器系數(shù)矢量和函數(shù)生成元后,將這些系數(shù)再壓縮打包就得到了最后的語(yǔ)音壓縮數(shù)據(jù)。當(dāng)對(duì)語(yǔ)音壓縮數(shù)據(jù)進(jìn)行解壓時(shí),首先將打包的數(shù)據(jù)展開(kāi),然后建立起線性預(yù)測(cè)濾波器,將重新生成的偽隨機(jī)多脈沖激勵(lì)函數(shù)輸入濾波器,這樣在濾波器的輸出端就可得到被恢復(fù)的語(yǔ)音信號(hào)序列了。
  該算法的實(shí)時(shí)運(yùn)算需要22MIPS以上的運(yùn)算速度,為此DSP集團(tuán)將DSP內(nèi)核和算法代碼集成在D6571系列芯片內(nèi),以滿足除PC用戶以外的更廣泛應(yīng)用。D6571原理框圖如圖1所示,其本身可直接外掛并管理4兆位的flash,8K采樣速率時(shí)在2.8KB的數(shù)據(jù)率下可提供25分鐘的回放時(shí)間。該芯片具備工業(yè)標(biāo)準(zhǔn)的編解碼器接口,可直接與串行PCM接口的音頻編解碼芯片相連,如美國(guó)國(guó)家半導(dǎo)體的TP3054或韓國(guó)三星半導(dǎo)體的KS8620。D6571可外接兩片音頻編解碼芯片,上電后可用設(shè)置命令對(duì)外接音頻編解碼芯片的工作模式進(jìn)行設(shè)置。例如:設(shè)置外接芯片的時(shí)鐘是外同步還是自同步;設(shè)置外接芯片處于輸出方式還是輸入方式等。


  根據(jù)實(shí)際開(kāi)發(fā)經(jīng)驗(yàn),我們認(rèn)為D6571芯片與其它公司所提供的某些DSP內(nèi)核芯片相比,其最大的優(yōu)點(diǎn)是幾乎不需要任何開(kāi)發(fā)工具或軟件就可使用。因?yàn)樵撔酒臄?shù)據(jù)是雙向的,既可由上位機(jī)將壓縮后的語(yǔ)音數(shù)據(jù)通過(guò)它解壓轉(zhuǎn)變成語(yǔ)音,也可輸入語(yǔ)音通過(guò)它進(jìn)行實(shí)時(shí)壓縮后傳送給上位機(jī)。這就大大方便了長(zhǎng)回放時(shí)間語(yǔ)音開(kāi)發(fā)用戶的使用。更何況目前許多語(yǔ)音壓縮芯片對(duì)語(yǔ)音數(shù)據(jù)的管理是不公開(kāi)的,例如:某些數(shù)字錄音電話的語(yǔ)音壓縮芯片。
2 系統(tǒng)構(gòu)成
  與語(yǔ)音處理有關(guān)的系統(tǒng)構(gòu)成如圖2所示。


  語(yǔ)音數(shù)據(jù)存放在一片32兆位的flash中,采用三星的K29W3200,這是一種8位并行接口的閃存,并行接口有利于提高代碼效率和滿足實(shí)時(shí)性要求。
  在語(yǔ)音數(shù)據(jù)的壓縮和回放過(guò)程中,D6571和flash之間的數(shù)據(jù)吞吐均通過(guò)上位機(jī)進(jìn)行。上位機(jī)采用89C52。系統(tǒng)還有64×64的點(diǎn)陣液晶模塊ACM6464等外圍設(shè)備。所有的設(shè)備均使用一條公共的8位數(shù)據(jù)總線,即CPU的P0口;P2口的六根口線用于鍵盤(pán)管理;P3口的兩根口線作為兩條串口線;這樣用于外設(shè)管理的口線還剩余16根可用。系統(tǒng)實(shí)際使用了其中的14根線:與flash管理有關(guān)的使用6根,與D6571有關(guān)的使用4根,還有4根用于液晶顯示管理。
  音頻編解碼接口芯片采用一片TP3054,TP3054工作所需的同步脈沖、采樣時(shí)鐘、數(shù)據(jù)信號(hào)等只需要與D6571的四根控制線相連即可得到。
3 系統(tǒng)開(kāi)發(fā)
  本系統(tǒng)的語(yǔ)音開(kāi)發(fā)分為上載、數(shù)據(jù)合成及下載三個(gè)過(guò)程。上載是指獲得語(yǔ)音壓縮數(shù)據(jù);數(shù)據(jù)合成是指將全系統(tǒng)的數(shù)據(jù)按一定的結(jié)構(gòu)組織成一個(gè)文件;下載是指儀器裝配出廠時(shí)將文件燒錄到flash中。這三個(gè)過(guò)程均通過(guò)PC機(jī)進(jìn)行。由于系統(tǒng)板上MCU的串行信號(hào)直接輸出的是TTL電平,因此,本系統(tǒng)的語(yǔ)音開(kāi)發(fā)唯一需要另外制作的硬件就是使用一片MAX232來(lái)完成與PC機(jī)之間的電平轉(zhuǎn)換。
  D6571具有16位寬度的總線,但也允許以分時(shí)方式使用8位總線,這時(shí)上位機(jī)須用HL信號(hào)表示送上總線的是高8位還是低8位;而當(dāng)D6571主動(dòng)將數(shù)據(jù)送上總線時(shí),會(huì)發(fā)出ACK信號(hào)通知上位機(jī)讀取數(shù)據(jù)。HRD和HWR則是讀和寫(xiě)的控制線。由于Triple Rate Coder算法是按30毫秒分幀采樣,然后再進(jìn)行分析壓縮的,因此無(wú)論是讀取壓縮數(shù)據(jù)還是回送壓縮數(shù)據(jù),均必須在一幀之內(nèi)完成,否則D6571會(huì)自行進(jìn)入休眠狀態(tài)。向D6571輸送語(yǔ)音數(shù)據(jù)的過(guò)程如下:首先送出解壓控制命令,然后接收一個(gè)回送狀態(tài)字,狀態(tài)字中包含了當(dāng)前幀所需要的字節(jié)數(shù),上位機(jī)就連續(xù)送出規(guī)定數(shù)目的數(shù)據(jù),待一幀處理完畢后,D6571會(huì)繼續(xù)送出狀態(tài)字。如此循環(huán)就可連續(xù)回放出語(yǔ)音了。而利用D6571進(jìn)行語(yǔ)音壓縮的數(shù)據(jù)處理過(guò)程正好相反,狀態(tài)字中包含的是當(dāng)前幀壓縮所得到的字節(jié)數(shù),上位機(jī)就應(yīng)連續(xù)接收規(guī)定數(shù)目的數(shù)據(jù)。
  上載時(shí),首先要得到的是各個(gè)語(yǔ)音段的壓縮數(shù)據(jù)。作為準(zhǔn)備工作,先用PC機(jī)的錄音機(jī)工具將我們所需的語(yǔ)音錄制成WAV文件。然后對(duì)MCU和PC機(jī)分別編寫(xiě)共同配合工作的兩段程序來(lái)完成以下功能:PC機(jī)通過(guò)聲卡播放聲音給D6571;89C52控制D6571進(jìn)行語(yǔ)音壓縮并讀回壓縮數(shù)據(jù),然后通過(guò)串口線回送給PC機(jī),PC機(jī)則將每段的壓縮數(shù)據(jù)存盤(pán)。
  由于每段語(yǔ)音播放時(shí)均要有一定的中文點(diǎn)陣字符顯示,數(shù)據(jù)合成的任務(wù)就是要將每段數(shù)據(jù)加上索引和字符點(diǎn)陣數(shù)據(jù)后再合成為一個(gè)完整的近32兆位的二進(jìn)制文件。文件形成時(shí)為了使數(shù)據(jù)定位和讀出編程方便,數(shù)據(jù)塊以flash的頁(yè)為單位,一頁(yè)為528字節(jié)。
  下載工作則較簡(jiǎn)單,在設(shè)備出廠前直接使用系統(tǒng)89C52的串口將數(shù)據(jù)合成形成的文件下載到閃存中即可。
  D6571的壓縮率極高,使用和開(kāi)發(fā)也比較方便。因此盡管本系統(tǒng)的語(yǔ)音容量長(zhǎng)達(dá)200分鐘,但系統(tǒng)整體設(shè)計(jì)十分簡(jiǎn)潔、經(jīng)濟(jì),幾乎不需調(diào)試。主要開(kāi)發(fā)工作是MCU和PC機(jī)的一些程序開(kāi)發(fā)使用C51和VB編程,開(kāi)發(fā)速度也比較快。
  由于D6571的控制命令很豐富,系統(tǒng)用戶界面的軟件是很容易編寫(xiě)的。例如,由于該芯片具有30階的音量控制命令,我們未添任何硬件就為設(shè)備增加了數(shù)字音量控制功能。D6571的控制命令還包含自動(dòng)增益控制、變速回放、數(shù)字濾波器等更加高級(jí)的命令,因此,它幾乎可應(yīng)用于任何語(yǔ)音場(chǎng)合。
參考文獻(xiàn)
1 楊行峻,遲惠生.語(yǔ)音信號(hào)數(shù)字處理.北京:電子工業(yè)出版社,1995
2 吳樂(lè)南.數(shù)據(jù)壓縮的原理與應(yīng)用.北京:電子工業(yè)出版社,1995
3 何振亞.數(shù)字信號(hào)處理的理論與應(yīng)用.北京:人民郵電出版社,1983
4 D6571 data sheet.DSP Group,INC.
5 TP3054 TP3057 data sheet.National Semiconductor Cor-poration

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無(wú)法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,請(qǐng)及時(shí)通過(guò)電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。