基于單片機(jī)設(shè)計(jì)的通用漢字文本播音系統(tǒng)
嵌入式語音播放系統(tǒng)應(yīng)用日益廣泛。漢字語音播放的方法有錄音芯片法、語音合成芯片法及漢字語音庫法等。Flash存儲器容量不斷增大,利用Windows的Speech SDK可以方便地提取漢字語音文件,因此漢字語音庫法得以廣泛應(yīng)用。
漢字語音庫法可分為專用語音播放和通用語音播放兩類。專用語音播放系統(tǒng)只存儲少量固定的語音資源,只需較小的存儲容量,但應(yīng)用范圍有限。通用語音播放系統(tǒng)存儲所有不同讀音漢字的單字語音資源,可實(shí)現(xiàn)任意文本組合的語音播放,適用于播放內(nèi)容經(jīng)常更新的場合。本系統(tǒng)由1220個不同讀音漢字讀音文件構(gòu)成語音庫,存于一片F(xiàn)lash存儲器中,實(shí)現(xiàn)了基于SPCE061A的嵌入式通用漢字文本語音播放系統(tǒng)。系統(tǒng)硬件簡單,使用方便,成本低廉,適用于公交車報(bào)站器等應(yīng)用系統(tǒng)中。
1硬件原理
直接由漢字的wave讀音文件構(gòu)成的語音庫占存儲空間很大,語音文件壓縮后,可使語音庫數(shù)據(jù)占Flash存儲器空間大大減小。凌陽為語音播放提供了多種壓縮算法,本系統(tǒng)采用碼激勵線性預(yù)測(CELP)編碼的SACM_S480壓縮算法,其壓縮比例為80:3。壓縮后的語音資源數(shù)據(jù)可存放在一片512 kB的Flash存儲器中。
普通單片機(jī)為核心的語音播放系統(tǒng)硬件上需要較多的外圍器件和電路,如存儲器、D/A轉(zhuǎn)換器等,軟件上語音解壓縮速度不快會影響其他操作。而若采用嵌入式微處理器實(shí)現(xiàn)語音播放系統(tǒng)則成本太高。凌陽16位單片機(jī)SPCE061A是一個最佳的選擇,它帶有DSP指令,將嵌入式語音系統(tǒng)所需的A/D、D/A等功能模塊都集成在一個芯片中,具有很強(qiáng)的可編程音頻處理功能。凌陽還提供SACM_LIB語音庫(本系統(tǒng)使用SACMV26e.lib)可實(shí)現(xiàn)錄音、播放和語音識別等功能。
本系統(tǒng)硬件原理如圖1所示,主要由SPCE061A單片機(jī)和外部Flash存儲器SPR4096A兩個芯片組成。SPCE061A運(yùn)行所有語音解碼播放及其他操作的軟件功能,它的D/A輸出經(jīng)音頻功放SPY0030接揚(yáng)聲器。SPR4096A存儲包括漢字讀音序號索引表、語音資源地址索引表和語音資源數(shù)據(jù)的所有語音信息。
通用文本語音播放有預(yù)先存儲固定文本播放、接收文本后播放和實(shí)時文本播放等3種工作方式。實(shí)時文本播放方式對系統(tǒng)的軟件處理能力的要求最高,最能檢驗(yàn)系統(tǒng)的語音播放操作與其他操作的配合情況,故本系統(tǒng)采用實(shí)時文本播放的方式進(jìn)行程序調(diào)試,即串行口輸入漢字的同時進(jìn)行文本播放,硬件上SPCE061A的UART與PC機(jī)的RS-232連接。
SPCE061A有內(nèi)置ICE(在線仿真器)調(diào)試接口,可實(shí)現(xiàn)在線仿真、調(diào)試和下載,程序調(diào)試非常方便,這也是選擇SPCE061A的主要原因之一。硬件上ICE調(diào)試接口與PC機(jī)并行口連接。SPCE061A除可編程音頻處理功能外,還具有豐富的I/O口、時鐘源及中斷源,F(xiàn)lash存儲達(dá)32 k字,RAM有2 k字,在語音播放的同時還能進(jìn)行復(fù)雜的控制操作。
SPR4096A容量為512 k×8位,分256個扇區(qū),每個扇區(qū)為2 kB,可配置為BMI(總線存儲器接口)或SIF(串行接口總線)。為節(jié)省I/O口,本系統(tǒng)使用串行接口。此串行接口是凌陽自行定義的SIO接口,也用SCK和SDA兩根信號線,但數(shù)據(jù)格式與I2C或SPI略有不同,SPCE061A的IOB0為時鐘信號SCK,IOB1為數(shù)據(jù)信號SDA。