国产日韩欧美一区二区三区三州_亚洲少妇熟女av_久久久久亚洲av国产精品_波多野结衣网站一区二区_亚洲欧美色片在线91_国产亚洲精品精品国产优播av_日本一区二区三区波多野结衣 _久久国产av不卡

?

基于VS1003B的語音通信方法研究

2015-01-25 10:51馬志強(qiáng)王建剛張德興
電子設(shè)計工程 2015年3期
關(guān)鍵詞:字節(jié)解碼音頻

馬志強(qiáng),王建剛,張德興

(總參謀部通信訓(xùn)練基地 河北 張家口 075100)

在通指裝備模擬訓(xùn)練器材研發(fā)中,經(jīng)常會遇到需要模擬實現(xiàn)語音通話功能的情況。常規(guī)的解決方案是在計算機(jī)上通過高級語言編程實現(xiàn)對聲音的采集和播放,并通過局域網(wǎng)進(jìn)行傳輸[1-2]。考慮到語音通信的模塊化和可控性,文中以STM32F107VCT6作為核心處理器,采用VS1003B作為語音采集和播放器件,通過CAN總線實現(xiàn)語音和信令傳輸,設(shè)計實現(xiàn)了一種低成本、高質(zhì)量的語音通信方法。

1 VS1003B解碼芯片介紹

VS1003B是由芬蘭VLSI公司出品的一款單芯片的MP3/WMA/MIDI音頻解碼和ADPCM編碼芯片,其內(nèi)部電路如圖1所示。由圖可見,VS1003B包含一個高性能、具有自主產(chǎn)權(quán)的低功耗DSP處理器內(nèi)核VSDSP4,工作數(shù)據(jù)存儲器為用戶應(yīng)用提供5 kB的指令RAM和0.5 kB的數(shù)據(jù)RAM,串行的控制和數(shù)據(jù)接口,4個常規(guī)用途的I/O口,一個UART,一個高品質(zhì)可變采樣率的ADC和立體聲DAC,還有一個耳機(jī)放大器和地線緩沖器。

VS1003B通過一個串行輸入總線來接收輸入的比特流,它可以作為一個系統(tǒng)的從機(jī)。輸入的比特流被解碼,然后通過一個數(shù)字音量控制器到達(dá)一個18位過采樣多位ε-ΔDAC。解碼過程通過一個串行控制總線來控制實現(xiàn)。除了基本的解碼,在用戶RAM中它還可以做其他特殊應(yīng)用,例如DSP音效處理[3]。

圖1 VS1003B內(nèi)部電路Fig.1 VS1003B internal circuit

2 設(shè)計原理

以半雙工語音通信為例,其工作原理如圖2所示。當(dāng)一方需要講話時,會按下PTT鍵,該信號被STM32微處理器檢測到后,一方面向?qū)Ψ桨l(fā)送“PTT已按下”的消息,另一方面控制己方VS1003B進(jìn)入錄音模式,VS1003B將采集到的音頻數(shù)據(jù)編碼后緩存給STM32,再通過CAN總線發(fā)送到對方。對方在收到“PTT已按下”消息后,會控制己方VS1003B開啟語音播放模式,將對方傳來的音頻數(shù)據(jù)傳輸給VS1003B進(jìn)行解碼,并根據(jù)需要調(diào)節(jié)音量,供耳機(jī)播放。

圖2 半雙工語音通信原理圖Fig.2 The principle diagram of the half duplex voice communication

VS1003B電路原理圖如圖3所示。J1為麥克風(fēng)輸入插座,用于連接麥克風(fēng)。J2為外部聲音輸入插座,連接音源。J3為耳機(jī)輸出插座,連接耳機(jī),由于內(nèi)部具有耳機(jī)驅(qū)動器,VS1003B輸出信號不需經(jīng)過任何功放電路,從而簡化了硬件電路。VS1003B各部分的供電電壓不同,IOVDD(I/O電壓)為3.3 V,CVDD(數(shù)字電路電壓)為 2.5 V,AVDD(模擬電路電壓)為2.8 V。最大的采樣率XTAL1/256,決定了能以正確的速度播放的音頻采樣率。例如,如果要播放48 kHz采樣率的音頻,XTAL1至少為12.288 MHz才能獲得正確的播放速度。

圖3 VS1003B電路原理圖Fig.3 VS1003B circuit principle diagram

對于STM32微處理器來說,總共需要7個IO口與VS1003B 連接。 SO(串行輸出)、SI(串行輸入)與 SCLK(串行總線時鐘)分別接 STM32的PB14、PB15和 PB13,即接到STM32的SPI2上,VS1003B通過SPI接口輸出IMA ADPCM編碼的音頻數(shù)據(jù)。其余的四根線中,DREQ(數(shù)據(jù)請求)連接到PC3,XCS(命令片選)連接到 PC10,XDCS(數(shù)據(jù)片選)連接到PC11,XRESET(復(fù)位)連接到 STM32 的 14 管腳(NRST),當(dāng)STM32復(fù)位時,VS1003B同時復(fù)位。操作時,只有當(dāng)DREQ為高(準(zhǔn)備好)時才能讀寫VS1003B。

3 VS1003B程序設(shè)計

3.1 初始化VS1003B

在設(shè)計中,STM32F103VET6通過 SPI總線對 VS1003B進(jìn)行控制,也就是通過VS1003B的串行數(shù)據(jù)接口 SDI和串行控制接口 SCI實現(xiàn)STM32F107VCT6與VS1003B的通信。VS1003B初始化流程如圖4所示。其中,DREQ為高時可判斷為硬件復(fù)位或軟件復(fù)位結(jié)束。

3.2 語音信號的采集

語音信號的采集就是把模擬的語音信號轉(zhuǎn)化為可控制的數(shù)字信號。在這一處理過程中,主要是對模擬音頻信號進(jìn)行采樣、量化和編碼。

目前常見的音頻信號的頻率范圍大致如下:電話為200Hz~3.4 kHz,調(diào)幅廣播為 50 Hz~7 kHz,調(diào)頻廣播為20Hz~15 kHz,高保真音頻信號為20 Hz~20 kHz。因此音頻取樣頻率一般定在 8~48 kHz范圍內(nèi)[4]。

圖4 VS1003B初始化流程圖Fig.4 The flow chart of VS1003B initialization

量化是利用預(yù)先規(guī)定的有限個電平來表示每一模擬采樣值的過程。量化的精度與其用來表示采樣值的二進(jìn)制位數(shù)有關(guān),例如4位可表示24=16個量化等級,8位可表示28=256個量化等級。明顯地,位數(shù)越多,量化值越接近采樣值,其精度也就越高,但相應(yīng)的所需的存儲量也越大(見表1)。

表1 常用音頻采樣、量化取值對照表Tab.1 Commonly used audio sampling,quantization value table

鑒于STM32F107VCT6主頻最高為72 MHz,在保證聲音質(zhì)量的前提下,應(yīng)盡量減少數(shù)據(jù)量,因此本文對聲音的采樣頻率為8 kHz,量化精度為8 bit,此時數(shù)據(jù)碼率為64 kbit/s。

語音壓縮編碼需要在保持可懂度、音質(zhì)、限制碼率及降低編碼過程的計算代價這幾個方面進(jìn)行折衷。VS1003B提供了IMA ADPCM編碼,這是由互動多媒體協(xié)會(IMA)制定的標(biāo)準(zhǔn),屬于波形編碼的一種,采用麥克風(fēng)和線入兩種輸入方式,可支持的音頻文件格式包括MP3、MP3+V、WMA、WAV、MIDI和SP-MIDI。IMA ADPCM適用于8~44.1 kHz采樣頻率,并且能在CPU占用率低和內(nèi)存空間需求少的條件下保證較好的音質(zhì),在Windows和MAC操作系統(tǒng)中有廣泛的應(yīng)用。IMA ADPCM錄音模式需要在SCI_MODE中對SM_RESET和SM_ADPCM進(jìn)行置位來啟動。在啟動ADPCM錄音前,必須分別向SCI_AICTRL0和SCI_AICTRL1寫入時鐘分割值 (據(jù)此可得到采樣率)和增益值[5]。錄音流程如圖5所示。記錄的語音數(shù)據(jù)以512字節(jié)為單位進(jìn)行存儲,并由STM32處理器通過CAN總線向?qū)Ψ睫D(zhuǎn)發(fā)。

3.3 CAN通信

圖5 VS1003B錄音流程圖Fig.5 The flow chart of VS1003B recording

CAN總線作為一種總線式串行通信網(wǎng)絡(luò),與一般的通信總線相比,具有突出的可靠性、實時性和靈活性等特點[6]??紤]到模擬訓(xùn)練器材對語音傳輸距離的要求不高,且STM32自帶bxCAN,即基本擴(kuò)展 CAN,它支持CAN協(xié)議 2.0A和2.0B,支持報文發(fā)送的優(yōu)先級要求,支持時間觸發(fā)通信,距離40 m內(nèi)波特率可達(dá)1 Mbit/s。因此,設(shè)計上采用CAN總線來實現(xiàn)語音數(shù)據(jù)傳輸,由STM32F107VCT6內(nèi)嵌的2路CAN控制器與外圍器件SN65HVD230(也標(biāo)識為VP230)收發(fā)器組成2路CAN收發(fā)電路,其中一路CAN組成信令網(wǎng),實現(xiàn)控制信令的傳輸;另一路CAN組成語音網(wǎng),將ADPCM壓縮編碼后的數(shù)據(jù),由STM32處理為CAN報文格式,發(fā)送到總線上,并對CAN過濾器進(jìn)行設(shè)置,使之僅在收到給自己的報文時引起中斷。

3.4 語音信號的播放

播放前將對方傳來的語音數(shù)據(jù)存放到STM32的緩沖區(qū),緩沖區(qū)的大小設(shè)置為512字節(jié),一般一次讀一個扇區(qū),然后將數(shù)據(jù)發(fā)往VS1003B。由于VS1003B有32字節(jié)的數(shù)據(jù)緩沖區(qū),一次可以發(fā)32個字節(jié)的數(shù)據(jù),然后檢測DREQ,當(dāng)DREQ為高時送下一個32字節(jié)的數(shù)據(jù),直到發(fā)完為止。DREQ為高表明VS1003B可以接受新的數(shù)據(jù),如果不考慮DREQ而直接連續(xù)的給VS1003B發(fā)音頻數(shù)據(jù),將會出現(xiàn)聲音斷斷續(xù)續(xù)的情況。語音播放流程如圖6所示,考慮到實際語音通信時,本地PTT鍵抬起時,對方會無法聽到語音,因此流程圖中采用判斷對方PTT鍵的狀態(tài)來處理是否播放。

圖6 語音播放流程圖Fig.6 The flow chart of VS1003B voice broadcasting

4 結(jié)束語

本文對基于STM32微處理器和VS1003B音頻解碼芯片的語音通信功能的實現(xiàn)進(jìn)行了研究,重點介紹了VS1003B的原理以及在語音通信應(yīng)用中的硬件電路設(shè)計和軟件程序設(shè)計。經(jīng)測試,該方法可較好地滿足語音通信要求,工作穩(wěn)定可靠,并在多個模擬訓(xùn)練器材研發(fā)項目中得到應(yīng)用,具有一定的參考價值。

[1]丁峰,魏偉.基于Flash Media Server實現(xiàn)VHF模擬器的語音通信[J].青島遠(yuǎn)洋船員學(xué)院學(xué)報,2009,30(4):9-11.DINGFeng,WEIWei.The realization of voice communication of the VHF simulator based on flash media server[J].Journal of Qingdao Ocean Shipping Mariners College,2009,30(4):9-11.

[2]禹華鋼,周安棟,劉宏波.多線程語音通信在模擬電臺通信中的應(yīng)用[J].火力與指揮控制,2010,35(3):42-45.YU Hua-gang,ZHOU An-dong,LIU Hong-bo.Application of multithread voice communication to simulated transmitterreceiver[J].Fire Control&Command Control,2010,35 (3):42-45.

[3]VLSI公司.VS1003 Datasheet[EB/OL].[2014-03-11]http://www.vlsi.fi/fileadmin/datasheets/vs1003.pdf.

[4]廖泉.基于CAN總線的語音通信系統(tǒng)[D].北京:北方工業(yè)大學(xué),2006.

[5]意法半導(dǎo)體有限公司.Implementing the ADPCM algorithm in high-density STM32F103xx microcontrollers[EB/OL].[2009-04]http://www.st.com/web/en/catalog/tools/PF257858.

[6]于寧寧,丁恩杰,趙宗平,等.基于CAN總線的煤礦語音通信系統(tǒng)的設(shè)計[J].電聲技術(shù),2010(10):59-61.YU Ning-ning,DING En-jie,ZHAO Zong-ping,et al.Design of coalminevoicecommunication systembased on CANbus[J].Audio Engineering,2010(10):59-61.

猜你喜歡
字節(jié)解碼音頻
《解碼萬噸站》
No.8 字節(jié)跳動將推出獨立出口電商APP
解碼eUCP2.0
No.10 “字節(jié)跳動手機(jī)”要來了?
必須了解的音頻基礎(chǔ)知識 家庭影院入門攻略:音頻認(rèn)證與推薦標(biāo)準(zhǔn)篇
NAD C368解碼/放大器一體機(jī)
Quad(國都)Vena解碼/放大器一體機(jī)
基于Daubechies(dbN)的飛行器音頻特征提取
簡談MC7字節(jié)碼
音頻分析儀中低失真音頻信號的發(fā)生方法