基于A(yíng)T89S52和K9F6408U0A的語(yǔ)音數字系統設計
數據采集技術(shù)涉及領(lǐng)域廣,采集信號的動(dòng)態(tài)范圍寬,處理數據量大,對系統實(shí)時(shí)性能要求高。以數字信號的形式對信號進(jìn)行處理,具有處理速度快、靈活、精確、抗干擾能力強、體積小及可靠性高等優(yōu)點(diǎn),滿(mǎn)足了對信號快速、精確、實(shí)時(shí)處理及控制的要求。本設計利用了數字電路的這些優(yōu)點(diǎn),對傳統的模擬錄音電路進(jìn)行了改進(jìn),以較低的成本使性能得到了提高。
1 方案論證
本設計以數字化信號的形式對音頻信號進(jìn)行處理,有以下3種方案可供選擇:
1)直接利用語(yǔ)音芯片進(jìn)行語(yǔ)音錄放。Winbond公司的ISD系列語(yǔ)音芯片采用了Chip-Corded專(zhuān)利技術(shù),聲音無(wú)需A/D轉換和壓縮就可直接存儲,不存在A(yíng)/D轉換誤差,在一個(gè)記錄位(BIT)可存儲多達250級聲音信號,相當于通常A/D技術(shù)記錄容量的8倍。片內集成了晶體振蕩器、麥克風(fēng)前置放大器、自動(dòng)增益控制、抗混疊濾波器、平滑濾波器、聲音功率放大器等,只需很少的外圍器件,就可構成一個(gè)完整的聲音錄放系統。
2)利用DSP對采樣信號進(jìn)行處理。DSP是專(zhuān)門(mén)為快速實(shí)現各種信號處理算法而設計的、具有特殊結構的微處理器,其處理速度遠遠超過(guò)一般的CPU。
3)利用AT89S52作為系統主控芯片,利用ADC0809對音頻信號進(jìn)行采集和A/D轉換,將轉換得到的數字化音頻信號存儲到擴展的數據存儲器中,利用軟件對信號進(jìn)行數字濾波,最后通過(guò)單片機輸出PWM信號來(lái)完成放音。
從經(jīng)濟和技術(shù)等因素考慮對上述3種方案進(jìn)行比較:直接利用語(yǔ)音芯片可以減少很多外圍電路,電路設計方便,但語(yǔ)音芯片使用不夠靈活。DSP具有強大的數字信號處理功能,使用靈活,但該芯片價(jià)格較高,不適于一般的應用。方案3)中器件均為常用芯片,易于獲取,且價(jià)位不高。因此,方案3)為最佳設計方案。
2 硬件設計
圖1為系統硬件結構圖。音頻信號通過(guò)拾音器將聲音信號轉換為可以處理的電信號,前置放大電路用來(lái)對拾音器的輸出進(jìn)行放大,與A/D轉換電路匹配,A/D轉換電路實(shí)現對模擬信號的編碼。微處理器是系統的核心,它用來(lái)對數字化音頻信號進(jìn)行處理和存儲,協(xié)調系統各個(gè)部分的工作,輸出PWM波來(lái)驅動(dòng)輸出電路。
2.1 單片機
單片機是系統的控制中心,它主要實(shí)現以下的功能:控制LCD顯示語(yǔ)音信號的相關(guān)信息,控制按鍵識別和功能選擇;控制音頻數據的采集并存儲在Flash ROM,放音時(shí)讀取Flash ROM中數據,用軟件方法產(chǎn)生PWM脈沖信號,實(shí)現語(yǔ)音的存儲和回放。
2.2 聲音信號拾取、放大電路
聲音信號拾取電路就是將聲音信號轉換為電信號的裝置。本設計選用麥克風(fēng),它是一種聲敏電阻,其阻值隨外界聲音信號的變化而變化,將其串聯(lián)在電路中,電阻的變化形成電壓的變化,經(jīng)過(guò)電容通交隔直,就得到了表征聲音信號特征的電信號。
然而由于聲音信號拾取電路輸出電壓的幅值很小,為20~25 mV,若將該信號直接與A/D轉換電路相連,由于A(yíng)/D轉換器最小分辨電壓也為毫伏數量級,會(huì )產(chǎn)生很大的誤差,為了保證系統的精度,在和A/D轉換電路相連之前,需串聯(lián)一個(gè)放大電路,考慮到聲音信號拾取電路的輸出信號很小,放大電路的失真度和噪聲對系統的精度影響最大,故將其設計為抗共模干擾強的并聯(lián)負反饋放大電路,由于音頻信號的頻寬較大,故選用寬頻帶,低輸出阻抗的雙運放NE5532。
2.3 A/D轉換電路
A/D轉換電路由A/D轉換器ADC0809與系統處理器AT89S52組成,主要實(shí)現對放大后的聲音信號進(jìn)行采樣。ADC0809與AT89S52的電路連接如圖2所示。
從圖2中可以看到,把ADC0809的ALE信號與START信號接在一起,這樣可使得在信號的前沿寫(xiě)入(鎖存)通道地址,緊接著(zhù)在其后沿就啟動(dòng)轉換。啟動(dòng)A/D轉換只需要一條P2.7=0指令。在此之前,要將P2.7清零并將最低3位與所選的通道對應的地址送入數據指針DPTR中。ADC0 809的轉換結束信號EOC取反后與AT89S52的相連,采用中斷方式讀取A/D轉換結果,并啟動(dòng)下一次A/D轉換。也可定時(shí)啟動(dòng)A/D轉換,并讀取上次轉換結果。
2.4 聲音編碼存儲電路
在采樣時(shí)每一采樣點(diǎn)都會(huì )產(chǎn)生1字節的數字編碼信號,由于采樣的頻率為8 kHz,若錄音15 min,則所需的存儲空間為7.031 25 MB,故系統選用8 MB的Flash存儲器K9F6408U0A,由于該存儲器的地址線(xiàn)和數據線(xiàn)可復用,這樣可節省I/O接口。K9F6408UOA的最大優(yōu)點(diǎn)在于其命令、數據和地址均可通過(guò)8條I/O接口線(xiàn)與主控制器進(jìn)行通信,大大簡(jiǎn)化了系統的連線(xiàn),增強了系統的穩定性。除8條I/O接口線(xiàn)外,K9F6408 UOA還包括以下控制線(xiàn),1)CLE:命令鎖存使能端,高電平有效。在信號的上升沿,命令信號可通過(guò)I/O口鎖入命令寄存器;2)ALE:地址鎖存使能端,高電平有效。在
信號的上升沿,地址信號可通過(guò)I/O口鎖入地址寄存器;3)
:片選線(xiàn),低電平有效。在頁(yè)編程或塊擦除操作期間或器件處于忙狀態(tài)時(shí),
高電平將被忽略。4)
:寫(xiě)使能口,命令、地址和數據在
信號的上升沿被鎖定;5)
:讀使能口,在該口的下降沿將數據送到I/0口線(xiàn)上,并使內部列地址寄存器加1;6)WP:寫(xiě)保護口,低電平有效,當其為低時(shí),編程擦除操作禁止;7)R/B:操作狀態(tài)指示信號。為低時(shí),表示正在編程、擦除或讀操作,操作結束后變高。利用上述控制線(xiàn),從而方便實(shí)現系統主控制器對K9F6 408U0A的控制。AT89S52單片機與K9F6408UOA存儲接口電路如圖3所示。
2.5 PWM輸出電路
本設計采用單片機輸出PWM信號驅動(dòng)音頻放大電路,PWM輸出電路如圖4所示。PWM是一種利用微處理器的數字輸出控制模擬電路的有效技術(shù),對一系列脈沖的寬度進(jìn)行調制,等效獲得所需波形,并且由于沒(méi)有使用D/A轉換器,系統成本減少很多。PWM的優(yōu)點(diǎn)是從處理器到被控系統信號都是數字形式的,無(wú)需進(jìn)行D/A轉換。讓信號保持為數字形式可將噪聲影響降到最小。此外PWM信號很容易通過(guò)MCU的軟件進(jìn)行控制,即使電路稍微有些系統誤差,易于通過(guò)軟件進(jìn)行校正。
圖4中,利用單片機的P1.7引腳輸出一定寬度的PWM信號,通過(guò)三極管整形后,作用在慣性環(huán)節上,得到的輸出信號PWMOUT將作用在音頻功放電路上,還原為聲音。
2.6 音頻功率放大電路
為了使系統有足夠大的輸出,驅動(dòng)揚聲器發(fā)聲,便于調節音量,在PWM輸出電路后使用了音頻信號功率放大器LM386構建功率放大電路,如圖5所示。
LM386型音頻功率放大器主要應用于低電壓消費類(lèi)產(chǎn)品。為使外圍元件最少,電壓增益內置為20。但在其引腳1和8之間外接電阻和電容,便可將電壓增益調為任意值,直至200。輸入端以地位參考,同時(shí)輸出端被自動(dòng)偏置到電源電壓的一半,在6 V電源電壓下,其靜態(tài)功耗僅為24 mW,使得LM386特別適用于電池供電的場(chǎng)合。PWMOUT為PWM輸出電路的輸出,揚聲器為8 Ω,0.5 W。經(jīng)過(guò)調試發(fā)現將電源+5 V用10μF和0.1μF的電容濾波后,會(huì )減小很多噪聲,效果較好。
3 系統軟件設計
系統具有錄音、放音、暫停、清除存儲內容等功能,各種功能由按鍵來(lái)選擇,系統首先掃描各個(gè)按鍵的狀態(tài),如果有按鍵按下,就轉往相應的處理程序,系統程序流程如圖6所示。
3.1 系統初始化程序
系統初始化程序主要對單片機中斷、定時(shí)器、LCD初始化、鍵盤(pán)、PWM、K9F6408UOA存儲接口,以及ADC0809地址、程序中要用到的各個(gè)變量進(jìn)行設置。
3.2 按鍵掃描程序
由于錄音和暫停是由和外部中斷引腳相連的2個(gè)按鍵來(lái)設置,一旦按鍵按下就進(jìn)入錄音或放音程序,所以按鍵掃描程序用于掃描放音鍵和清除鍵是否按下。
3.3 錄音程序
與外部中斷O相連的按鍵按下,則進(jìn)入錄音程序。
[next]
錄音過(guò)程實(shí)質(zhì)上是啟動(dòng)ADC0809對模擬音頻信號進(jìn)行采樣,并將A/D轉換結果存儲到外圍數據存儲器中的過(guò)程,故其主要包含對ADC0809進(jìn)行讀取,對外圍數據存儲器進(jìn)行寫(xiě)入兩個(gè)部分。
提取聲音數據時(shí),要注意采樣頻率、采樣位數、存儲容量與存儲時(shí)間的關(guān)系,通常8 kHz的采樣頻率和8位的采樣位數可獲得清晰的語(yǔ)音以及較好的音樂(lè )聲,并且占有較少的存儲空間。
以8 kHz的采樣頻率啟動(dòng)ADC0809,并讀取上次采樣結果,寫(xiě)到外擴Flash存儲器的代碼片段如下:
3.4 放音程序
若P1.O按下,則執行放音程序。放音過(guò)程實(shí)質(zhì)上是讀取外圍數據存儲器中的數據,將其轉化為一定寬度的PWM波,進(jìn)行輸出的過(guò)程。讀取K9F6408UOA的子函數如下:
產(chǎn)生PWM波形的步驟:1)設置定時(shí)器,產(chǎn)生定時(shí)中斷,若采樣率為11.025 kHz,則設置定時(shí)器的定時(shí)中斷頻率為11.025 kHz;2)初始化PWM模塊,產(chǎn)生11.025 kHz的PWM波形;3)等待定時(shí)器中斷,在中斷處理程序中取采樣數據,并設置PWM占空比寄存器,判斷聲音是否播放完成。若完成,則關(guān)定時(shí)器中斷,并停止PWM輸出。
3.5 暫停程序
在錄音過(guò)程中,如果需要暫時(shí)停止錄音可以按下暫停鍵進(jìn)入暫停狀態(tài),再次按下暫停鍵可以返回暫停以前的狀態(tài)。程序中設置了一個(gè)變量來(lái)指示現在是應該暫停還是恢復。
3.6 存儲器內容清除程序
當存儲器內容已滿(mǎn),而又需要錄音時(shí),可以按下清除按鍵,清除一定容量的內容,供用戶(hù)再次使用。
擦除:以塊為單位進(jìn)行擦除。代碼片段如下。
4 調試注意事項
系統進(jìn)行調試時(shí),應注意以下方面:
1)由于在PCM(Pulse Code Modulation)編碼及DPCM編碼模式下都要采用8 kHz的采樣率,所以,每次壓縮中斷服務(wù)程序必須在不超過(guò)125 μs的時(shí)間內完成,因此,壓縮錄音處理程序的代碼必須進(jìn)行最大可能的優(yōu)化,以減少程序執行時(shí)間,以免采樣和數據處理或信息顯示發(fā)生沖突,也可避免在中斷采樣時(shí)造成采樣點(diǎn)的丟失。
2)在選擇ADC0809的時(shí)鐘時(shí),經(jīng)典選擇是640 kHz左右,最初選擇將單片機的ALE端4分頻后作為ADC0809的時(shí)鐘信號,但發(fā)現影響了LCD的輸出顯示。將ALE改為2分頻后(用1 M觸發(fā))作為ADC0809的時(shí)鐘信號,問(wèn)題得到解決。
3)使用MAX813L復位芯片替代RC復位電路,使電路可靠復位.結合軟件監控實(shí)現看門(mén)狗功能。
4)當采樣頻率為8 kHz,字長(cháng)為8位時(shí),存儲語(yǔ)言時(shí)長(cháng)超過(guò)15 min,回放語(yǔ)音質(zhì)量良好。
5 結束語(yǔ)
利用K9F6408UOA 8 MB NAND Flash存儲器和單片機PWM功能可為單片機的應用增加語(yǔ)音功能。對聲音采樣數據的存儲方式是用直接的、原始的采樣數據。在具體的實(shí)際應用中,可選用內嵌A/D轉換器的STC12C5A08AD,可省去外擴ADC0809,使電路更簡(jiǎn)潔。創(chuàng )新之處在于不使用專(zhuān)用的語(yǔ)音芯片,實(shí)現使單片機應用系統語(yǔ)音的存儲與回放。
評論