基于FPGA的語音錄制與回放系統(tǒng)
0 引言
隨著微電子技術的發(fā)展,系統(tǒng)集成向高速、高集成度、低功耗發(fā)展已經(jīng)成為必然,同時SoPC技術也應用而生。SoPC將軟硬件集成于單個可編程邏輯器件平臺,使得系統(tǒng)設計更加簡潔靈活。SoPC綜合了SoC,PLD和FPGA的優(yōu)點,集成了硬核和軟核CPU、OSP、存儲器、外圍I/O及可編程邏輯,用戶可以利用SoPC平臺自行設計高速、高性能的CPU和DSP處理器,使得電子系統(tǒng)設計進入一個嶄新的模式。
該設計運用SoPC技術實現(xiàn)嵌入式數(shù)字化語音錄制與回放。其中,介紹了在FPGA上構建WM8731的I2C總線,以及數(shù)字化語音在SRAM中的存儲,并利用Matlab 7.0.4軟件對所采集的語音數(shù)據(jù)進行仿真。SoPC是現(xiàn)在電子技術、電子系統(tǒng)設計的匯聚點和發(fā)展方向。充分體現(xiàn)了其高性能、設計靈活和易用等特點。
1 系統(tǒng)整體方案
系統(tǒng)以Altera公司的FPGA芯片(CycloneⅡ系列)EP2C35F672C6NK為平臺,結合音頻編/解碼芯片WM8731實現(xiàn)語音錄制與回放。該FPGA芯片具有豐富的片內資源,大量的邏輯宏單元和多個硬件乘法器,大量的自定義I/O接口,此外還有4個鎖相環(huán),為系統(tǒng)提供實時時鐘。設計中充分利用了FPGA的高速并行和Avalon總線自定義硬件外設的優(yōu)勢,從而構建了一個高集成度、高性能的系統(tǒng)。
語音通過話筒輸入,由音頻編/解碼芯片WM8731以8 kHz的A/D采樣率轉換成16位PCM碼緩存。此外,為確保采集的語音數(shù)據(jù)不丟失,先將語音存儲在SRAM中,再作后續(xù)處理。整體系統(tǒng)框架圖1所示。
1.1 芯片工作原理
音頻編/解碼芯片WM8731上電后必須將工作模式設置在系統(tǒng)要求的狀態(tài)下,因此上電后需要用VERILOG HDL編寫程序模塊對芯片的工作模式進行設置。該語音編/解碼芯片有多種工作模式,A/D變換后,語音的采樣頻率與采樣位寬都需要根據(jù)系統(tǒng)的具體要求,合理配置。語音芯片的配置時序為I2C模式,芯片接口為主模式,即由WM8731提供位時鐘,A/D轉換和D/A轉換的左、右聲道控制相位時鐘,以及轉換后的數(shù)據(jù)PCM碼輸送給FPGA處理器。以下為芯片配置字列表,WM8731內部控制字寄存器有16個,在芯片初始化時,在制作ROM表格中完成。相應的程序設置如下:
1. 2 配置單元模塊
配置單元模塊綜合頂層圖如圖2所示。從程序編譯分析報告(見圖3)可以得出,該單元模塊消耗了101個邏輯單元,它作為語音采集模塊的一個子模塊。在配置電路中,模塊CLOCK_50將輸入的50 MHz系統(tǒng)時鐘分頻為1 MHz,作為I2C總線模塊的工作時鐘,CLOCK_50模塊中寫出的上面程序代碼是一個表格,存儲了配置的控制字。I2C總線模塊的I2C_SDAT和I2C_SCLK是數(shù)據(jù)線和時鐘線,DE2板固定分配了專門的I2C數(shù)據(jù)線和時鐘線的引腳線。
評論