基于ADPCM算法的汽車智能語音報警系統(tǒng)
為了防止汽車發(fā)生交通事故,當(dāng)汽車智能檢測裝置探測到前方有危險時,必須向駕駛員發(fā)出警告信息。語音報警向駕駛員明確提示危險,以便駕駛員能及時準(zhǔn)確地采取措施。因此,本文提出數(shù)字語音處理技術(shù),先將各種狀況的報警信息進(jìn)行數(shù)字化采集、存儲,遇到危險時,將判斷危險類型并自動選擇播放存儲的報警信息。由于語音信息量大,直接存儲需占用龐大的存儲空間,為此,本文采用FPGA實現(xiàn)ADPCM(Adaptive Differential Pulse CodeModulation,自適應(yīng)差分脈沖編碼調(diào)制)編解碼器設(shè)計,對語音信息進(jìn)行壓縮存儲.從而使存儲信息量增大了一倍。
2 系統(tǒng)結(jié)構(gòu)及原理
本系統(tǒng)設(shè)計是以單片機(jī)和FPGA為核心。單片機(jī)控制系統(tǒng)的工作狀態(tài)、啟動錄放音并對錄放音時間進(jìn)行計時、顯示。FPGA對采集到的數(shù)據(jù)進(jìn)行壓縮、存儲、解壓。單片機(jī)與FPGA協(xié)調(diào)工作,提高了系統(tǒng)的工作效率和穩(wěn)定性。系統(tǒng)結(jié)構(gòu)如圖1所示。
首先,將所希望采集的各種報警聲音經(jīng)前向通道(話筒、差分放大器、濾波器、加法器)再由A/D轉(zhuǎn)換器轉(zhuǎn)換為數(shù)字信號并送人FPGA進(jìn)行ADPCM壓縮編碼處理,然后存儲到靜態(tài)存儲器SRAM中。遇到危險時,單片機(jī)對危險進(jìn)行判斷,控制FPGA將相應(yīng)的語音數(shù)據(jù)從SRAM中取出并進(jìn)行解碼,然后送至8 位的D/A轉(zhuǎn)換器,轉(zhuǎn)換為模擬信號,再經(jīng)后向通道(濾波器、校正電路、功率放大器、揚(yáng)聲器)復(fù)現(xiàn)報警聲音。
3 系統(tǒng)主要硬件設(shè)計
3.1 前置放大器
采用駐極體話筒采集語音信號,轉(zhuǎn)換其信號幅值為毫伏級的電信號,系統(tǒng)前級對其處理時,要盡可能提高放大器輸入端的信噪比,保證放大電路具有精確、穩(wěn)定的增益。為此,本文設(shè)計了如圖2所示的檢測放大電路。該電路前級采用電壓跟隨器,利用輸入電阻為無窮大而輸出趨于零的特性,提供高輸入電阻,實現(xiàn)阻抗變換與隔離;后級采用差動放大器,獲得較高的共模抑制比,增強(qiáng)電路抗干擾性。
電壓跟隨器由性能優(yōu)良的低噪聲音頻放大器NE5532構(gòu)成,工作電壓為12 V,工作帶寬為10 MHz,特別適用于語音信息處理。差動放大器采用AD620實現(xiàn)。AD620內(nèi)部實際上是一個差分放大器,其失調(diào)電壓電流小,共模抑制比高,因此處理微弱信號時,也就是放大和消除噪聲方面具有優(yōu)異性能,其增益G=1+(49.4 kΩ/Rg)(Rg為接在1、8引腳之間的電阻)。調(diào)節(jié)電位器R1,使放大的信號幅值介于-2.5 V和2.5 V之間,便于A/D轉(zhuǎn)換器采樣量化。
3.2 帶通濾波器
語音信號經(jīng)放大傳輸后容易拾取噪聲,因此在數(shù)據(jù)采集之前,需要通過帶通濾波器濾除掉帶外雜波。人的語音頻率范圍為300 Hz~3.4 kHz,故濾波器的通帶范圍應(yīng)為300 Hz~3.4kHz。如此寬的頻帶,必須采用低通部分與高通部分相級聯(lián)的方式實現(xiàn)。
高通濾波器設(shè)計指標(biāo):通帶截止頻率fp=300Hz,通帶允許最大衰減αp≤3 dB;為消除工頻干擾,確定阻帶截止頻率fs=50 Hz,阻帶允許最小衰減as>40 dB。選用兩級二階Butterworth高通濾波器相級聯(lián)構(gòu)成.仿真結(jié)果如圖3所示。
低通濾波器的設(shè)計指標(biāo)為:通帶截止頻率fp=3 400 Hz,通帶允許最大衰減αp≤3 dB;為抑制采樣混疊失真,確定阻帶截止頻率fs=4 000 Hz,阻帶允許最小衰減as≥40 dB。由于橢圓濾波器可以獲得較其他濾波器窄的過渡帶寬,故適用該系統(tǒng)設(shè)計。利用濾波器輔助設(shè)計軟件Filter Wiz Pro獲得五階橢圓低通濾波器電路如圖4、仿真結(jié)果如圖5所示。
級聯(lián)高通和低通濾波器,即可得到300 Hz~3.4 kHz帶通濾波器,實驗表明,該濾波器效果良好,達(dá)到設(shè)計指標(biāo)。后向通道的帶通濾波器的設(shè)計與此相同。
4 系統(tǒng)軟件的設(shè)計
4.1 FPGA部分
選用Altera公司的Cyclone系列的EPlC6Q-240C8實現(xiàn)ADPCM編碼器和解碼器。該器件含有120 000典型門資源、5 980個邏輯單元、6個RAM模塊、92 160 Bit RAM或ROM、2個數(shù)字PLL、185個可編程I/O口,最高工作時鐘可達(dá)300 MHz以上,并通過JTAG接口實現(xiàn)在系統(tǒng)配置。
ADPCM是一種利用樣本間的高度相關(guān)性和量化階自適應(yīng)壓縮數(shù)據(jù)的波形編碼技術(shù)。ADPCM綜合了APCM的自適應(yīng)特性和DPCM的差分特性。它的核心思想是利用自適應(yīng)改變量化階的大小,即就是使用小的量化階編碼小的差值,使用大的量化階來編碼大的差值;使用過去的樣本值估算下一個輸入樣本的預(yù)測值,實際樣本值和預(yù)測值之間的差值總是最小。ADPCM編解碼器的輸入信號是G.711 PCM代碼,若采樣頻率為8 kHz,每個代碼為8位,則它的數(shù)據(jù)率為64 Kb/s,而ADPC M的輸出代碼是“自適應(yīng)量化器”的輸出,該輸出是4位的差分信號,它的采樣頻率仍是8 kHz,數(shù)據(jù)率為32 Kb/s,這樣就獲得了2:1的數(shù)據(jù)壓縮。
編碼過程:計算8位的二進(jìn)制補(bǔ)碼的當(dāng)前采樣值Sc和上一預(yù)測采樣值Sp之間的差值d,該差值經(jīng)量化編碼輸出4位ADPCM代碼I。在算法中,定義一個結(jié)構(gòu)變量存儲預(yù)測采樣值Sp和量化步長q,并制定了兩個表:一個表為索引調(diào)整表,其輸入為差值量化編碼I,用于更新步長索引;另一個表為步長調(diào)整表,其輸入為步長索引,輸出為步長q。編碼時,首先用上一個采樣點的步長索引查步長調(diào)整表求出步長q,然后根據(jù)下式來確定4位ADPCM編碼值I:
再將編碼值I作為索引調(diào)整表的輸入,查表輸出索引調(diào)整,并和結(jié)構(gòu)變量中原步長索引相加,產(chǎn)生新的步長索引,在下一個采樣值的編碼中使用。編碼器輸出I后,還需要重復(fù)進(jìn)行與解碼完全一樣的計算過程,求出新的預(yù)測采樣值Sp。
解碼過程:首先通過步長索引查步長調(diào)整表得到量化步長,差值量化編碼I經(jīng)逆量化得到語音差值d,這是求I的逆過程;然后與前次預(yù)測值Sp。一起重建當(dāng)前語音信號Sc;最后利用Sp=Sc,更新預(yù)測值Sp,用I更新量化步長索引。
設(shè)計完成后,對ADPCM編解碼器進(jìn)行仿真,仿真結(jié)果如圖6所示。AD_DataBus為編碼前輸入信號,采用Testbench產(chǎn)生。在編碼使能信號P1_7為“0”時,開始編碼,P1_7跳變到“1”時,編碼被屏蔽。此時解碼使能信號P1_4為“0”,開始解碼,P1_4跳變到“1”時,解碼被屏蔽。可以看出編碼前輸入信號AD_DataBus和解碼器輸出DA_DataBus基本符合要求。由于ADPCM算法本身是有損壓縮,可以確定本部分的設(shè)計是正確可靠的。
4.2 單片機(jī)部分
單片機(jī)是整個系統(tǒng)的控制中心.負(fù)責(zé)檢測危險并判斷其類型以選擇播放相應(yīng)的報警信息。其工作流程如圖7所示。本文給出了采用3個按鍵代表3種危險的發(fā)生,供單片機(jī)檢測。
選擇常用的51系列單片機(jī)AT89C52,用C51語言編程可完成程序設(shè)計,實驗效果理想。
5 結(jié)束語
本系統(tǒng)設(shè)計是單片機(jī)與FPGA配合使用,充分發(fā)揮各自的優(yōu)點。獲得理想效果,具有很強(qiáng)的實用性,同時還證明了采用可編程邏輯器件實現(xiàn)語音數(shù)字壓縮處理的高效性。實驗證明,本系統(tǒng)可以很好地再現(xiàn)錄入的報警語音,具有較高的保真度。駕駛員可以根據(jù)自己的喜好隨意改變報警聲音。危急情況下,本系統(tǒng)會自動發(fā)出明確的報警提示,大大提高了駕駛的安全性。
評論