新聞中心

EEPW首頁 > 汽車電子 > 設計應用 > 基于ADPCM算法的汽車智能語音報警系統(tǒng)

基于ADPCM算法的汽車智能語音報警系統(tǒng)

作者: 時間:2008-07-10 來源:網(wǎng)絡 收藏

  為了防止汽車發(fā)生交通事故,當汽車探測到前方有危險時,必須向駕駛員發(fā)出警告信息。語音報警向駕駛員明確提示危險,以便駕駛員能及時準確地采取措施。因此,本文提出數(shù)字語音處理技術,先將各種狀況的報警信息進行數(shù)字化采集、存儲,遇到危險時,將判斷危險類型并自動選擇播放存儲的報警信息。由于語音信息量大,直接存儲需占用龐大的存儲空間,為此,本文采用FPGA實現(xiàn)(Adaptive Differential Pulse CodeModulation,自適應差分脈沖調(diào)制)編解碼器設計,對語音信息進行壓縮存儲.從而使存儲信息量增大了一倍。

  2 系統(tǒng)結構及原理

  本系統(tǒng)設計是以單片機和FPGA為核心。單片機控制系統(tǒng)的工作狀態(tài)、啟動錄放音并對錄放音時間進行計時、顯示。FPGA對采集到的數(shù)據(jù)進行壓縮、存儲、解壓。單片機與FPGA協(xié)調(diào)工作,提高了系統(tǒng)的工作效率和穩(wěn)定性。系統(tǒng)結構如圖1所示。

  

  首先,將所希望采集的各種報警聲音經(jīng)前向通道(話筒、、濾波器、加法器)再由A/D轉換器轉換為數(shù)字信號并送人FPGA進行壓縮處理,然后存儲到靜態(tài)存儲器SRAM中。遇到危險時,單片機對危險進行判斷,控制FPGA將相應的語音數(shù)據(jù)從SRAM中取出并進行解碼,然后送至8 位的D/A轉換器,轉換為模擬信號,再經(jīng)后向通道(濾波器、校正電路、功率放大器、揚聲器)復現(xiàn)報警聲音。

  3 系統(tǒng)主要硬件設計

  3.1 前置放大器

  采用駐極體話筒采集語音信號,轉換其信號幅值為毫伏級的電信號,系統(tǒng)前級對其處理時,要盡可能提高放大器輸入端的信噪比,保證放大電路具有精確、穩(wěn)定的增益。為此,本文設計了如圖2所示的檢測放大電路。該電路前級采用電壓跟隨器,利用輸入電阻為無窮大而輸出趨于零的特性,提供高輸入電阻,實現(xiàn)阻抗變換與隔離;后級采用,獲得較高的比,增強電路抗干擾性。

  

  電壓跟隨器由性能優(yōu)良的低噪聲音頻放大器NE5532構成,工作電壓為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轉換器采樣量化。

  3.2

  語音信號經(jīng)放大傳輸后容易拾取噪聲,因此在數(shù)據(jù)采集之前,需要通過濾除掉帶外雜波。人的語音頻率范圍為300 Hz~3.4 kHz,故濾波器的通帶范圍應為300 Hz~3.4kHz。如此寬的頻帶,必須采用低通部分與高通部分相級聯(lián)的方式實現(xiàn)。

  高通濾波器:通帶截止頻率fp=300Hz,通帶允許最大衰減αp≤3 dB;為消除工頻干擾,確定阻帶截止頻率fs=50 Hz,阻帶允許最小衰減as>40 dB。選用兩級二階Butterworth高通濾波器相級聯(lián)構成.仿真結果如圖3所示。

  

  為:通帶截止頻率fp=3 400 Hz,通帶允許最大衰減αp≤3 dB;為抑制采樣混疊失真,確定阻帶截止頻率fs=4 000 Hz,阻帶允許最小衰減as≥40 dB。由于橢圓濾波器可以獲得較其他濾波器窄的過渡帶寬,故適用該系統(tǒng)設計。利用濾波器輔助設計軟件Filter Wiz Pro獲得五階橢圓電路如圖4、仿真結果如圖5所示。

  

  級聯(lián)高通和,即可得到300 Hz~3.4 kHz,實驗表明,該濾波器效果良好,達到。后向通道的帶通濾波器的設計與此相同。

  4 系統(tǒng)軟件的設計

  4.1 FPGA部分

  選用Altera公司的Cyclone系列的EPlC6Q-240C8實現(xiàn)器和解碼器。該器件含有120 000典型門資源、5 980個邏輯單元、6個RAM模塊、92 160 Bit RAM或ROM、2個數(shù)字PLL、185個可編程I/O口,最高工作時鐘可達300 MHz以上,并通過JTAG接口實現(xiàn)在系統(tǒng)配置。

  ADPCM是一種利用樣本間的高度相關性和量化階自適應壓縮數(shù)據(jù)的波形編碼技術。ADPCM綜合了APCM的自適應特性和DPCM的差分特性。它的核心思想是利用自適應改變量化階的大小,即就是使用小的量化階編碼小的差值,使用大的量化階來編碼大的差值;使用過去的樣本值估算下一個輸入樣本的預測值,實際樣本值和預測值之間的差值總是最小。ADPCM編解碼器的輸入信號是G.711 PCM代碼,若采樣頻率為8 kHz,每個代碼為8位,則它的數(shù)據(jù)率為64 Kb/s,而ADPC M的輸出代碼是“自適應量化器”的輸出,該輸出是4位的差分信號,它的采樣頻率仍是8 kHz,數(shù)據(jù)率為32 Kb/s,這樣就獲得了2:1的數(shù)據(jù)壓縮。

  編碼過程:計算8位的二進制補碼的當前采樣值Sc和上一預測采樣值Sp之間的差值d,該差值經(jīng)量化編碼輸出4位ADPCM代碼I。在算法中,定義一個結構變量存儲預測采樣值Sp和量化q,并制定了兩個表:一個表為索引調(diào)整表,其輸入為差值量化編碼I,用于更新索引;另一個表為調(diào)整表,其輸入為步長索引,輸出為步長q。編碼時,首先用上一個采樣點的步長索引查步長調(diào)整表求出步長q,然后根據(jù)下式來確定4位ADPCM編碼值I:

  

  再將編碼值I作為索引調(diào)整表的輸入,查表輸出索引調(diào)整,并和結構變量中原步長索引相加,產(chǎn)生新的步長索引,在下一個采樣值的編碼中使用。編碼器輸出I后,還需要重復進行與解碼完全一樣的計算過程,求出新的預測采樣值Sp。

  解碼過程:首先通過步長索引查步長調(diào)整表得到量化步長,差值量化編碼I經(jīng)逆量化得到語音差值d,這是求I的逆過程;然后與前次預測值Sp。一起重建當前語音信號Sc;最后利用Sp=Sc,更新預測值Sp,用I更新量化步長索引。

  設計完成后,對ADPCM編解碼器進行仿真,仿真結果如圖6所示。AD_DataBus為編碼前輸入信號,采用Testbench產(chǎn)生。在編碼使能信號P1_7為“0”時,開始編碼,P1_7跳變到“1”時,編碼被屏蔽。此時解碼使能信號P1_4為“0”,開始解碼,P1_4跳變到“1”時,解碼被屏蔽??梢钥闯鼍幋a前輸入信號AD_DataBus和解碼器輸出DA_DataBus基本符合要求。由于ADPCM算法本身是有損壓縮,可以確定本部分的設計是正確可靠的。

  

  4.2 單片機部分

  單片機是整個系統(tǒng)的控制中心.負責檢測危險并判斷其類型以選擇播放相應的報警信息。其工作流程如圖7所示。本文給出了采用3個按鍵代表3種危險的發(fā)生,供單片機檢測。

  

  選擇常用的51系列單片機AT89C52,用C51語言編程可完成程序設計,實驗效果理想。

  5 結束語

  本系統(tǒng)設計是單片機與FPGA配合使用,充分發(fā)揮各自的優(yōu)點。獲得理想效果,具有很強的實用性,同時還證明了采用可編程邏輯器件實現(xiàn)語音數(shù)字壓縮處理的高效性。實驗證明,本系統(tǒng)可以很好地再現(xiàn)錄入的報警語音,具有較高的保真度。駕駛員可以根據(jù)自己的喜好隨意改變報警聲音。危急情況下,本系統(tǒng)會自動發(fā)出明確的報警提示,大大提高了駕駛的安全性。



評論


相關推薦

技術專區(qū)

關閉