基于FPGA的高速數(shù)據(jù)采集系統(tǒng)的設計方案
1.引言
傳統(tǒng)的數(shù)據(jù)采集系統(tǒng),通常采用MCU或DSP作為控制模塊,來控制A/D,存儲器和其他一些外圍電路。這種方法編程簡單,控制靈活,但缺點是控制周期長,速度慢。特別是當A/D本身的采樣速度比較快時,MCU的慢速極大地限制了A/D高速性能的使用。MCU的時鐘頻率較低并且用軟件實現(xiàn)數(shù)據(jù)的采集,軟件運行時間在整個采樣時間中占的比例很大,使得采樣速率較低。
隨著數(shù)據(jù)采集對速度性能的要求越來越來高,傳統(tǒng)的采集系統(tǒng)的弊端越來越明顯。本設計采用FPGA,各模塊設計使用VHDL語言,其各進程間是并行的關系。它有MCU無法比擬的優(yōu)點。FPGA的時鐘頻率高,全部控制邏輯由硬件完成,實現(xiàn)了硬件采樣,速度快。
2.系統(tǒng)的總體設計
本數(shù)據(jù)采集系統(tǒng),采用FPGA+MCU的結構,主控邏輯模塊用FPGA來實現(xiàn),在系統(tǒng)中對A/D器件進行采樣控制,起到連接采樣電路和MCU的橋梁作用,數(shù)據(jù)處理、遠程通信及液晶顯示控制等由MCU來完成。FPGA把傳統(tǒng)的純粹以單片機軟件操作形式的數(shù)據(jù)采集變成硬件采集。
首先用VHDL語言來設計狀態(tài)機,用MCU來啟動狀態(tài)機,使其控制A/D器件,實現(xiàn)數(shù)據(jù)采集。并將采集到的數(shù)據(jù)存儲到FPGA內部的數(shù)據(jù)緩存區(qū)FIFO中。當FIFO存儲已滿時,狀態(tài)機控制FIFO停止數(shù)據(jù)寫入,并通知單片機取走采集數(shù)據(jù)進行下一步處理。這種設計思想大大減輕了單片機的軟件運行時間,提高了采集速率。這里,把6路模擬信號采集任務作為快任務,把用于系統(tǒng)自檢的6路檢測量信號作為慢任務。為了使快任務的優(yōu)先級高于慢任務,本系統(tǒng)設計兩個狀態(tài)機分別實現(xiàn)快任務和慢任務的數(shù)據(jù)采集,并由單片機生成PWM波,分別控制兩個狀態(tài)機。系統(tǒng)的總體框圖如圖1所示:
3.系統(tǒng)主要器件的選擇
3.1 FPGA芯片選型及依據(jù)
FPGA實現(xiàn)主控邏輯控制,要求響應速度快,效率高。可采用ALTERA公司的ACEX1K系列EP1K5O芯片,最高工作頻率可達250MHz.
該系列芯片的特點是將LUT(查找表)和EAB(嵌入式陣列)相結合,提供了效率最高而又廉價的結構?;贚UT的邏輯對數(shù)據(jù)路徑管理、寄存器強度、數(shù)學計算或數(shù)字信號處理的設計提供優(yōu)化的性能和效率,而EBA可實現(xiàn)RAM(隨機讀寫存儲器)、ROM(只讀存儲器)、雙口RAM或FIFO(先人先出存儲器)功能,使得ACEX1K適合復雜邏輯以及有存儲、緩沖功能的數(shù)據(jù)采集系統(tǒng)。
3.2 ADC芯片選型及依據(jù)
數(shù)據(jù)采集系統(tǒng)的輸入信號多數(shù)都來源于現(xiàn)場傳感器的輸出信號,傳感器種類不一,致使信號特性也不同,各通道信號的幅度與頻率范圍有很大的不同,高精度的、大動態(tài)范圍的A/D轉換芯片使設計更能滿足測量的需要。本設計中A/D轉換模塊選用的AD574A是美國模擬數(shù)字公司(Analog)推出的單片高速12位逐次比較型A/D轉換器,轉換速率:25us,內置雙極性電路構成的混合集成轉換顯片,具有外接元件少,功耗低,精度高等特點,并且具有自動校零和自動極性轉換功能,只需外接少量的阻容件即可構成一個完整的A/D轉換器。
4.FPGA方案設計
4.1 設計思想
用VHDL語言來設計兩個狀態(tài)機,狀態(tài)機1來控制A/D實現(xiàn)快任務的采集,狀態(tài)機2來完成慢任務采集。兩個狀態(tài)機的時鐘信號CLK(高電平有效)均來自單片機生成的PWM波,狀態(tài)機1直接由單片機控制,狀態(tài)機2則是由單片機經(jīng)反向器來控制。首先置P1.0口為高電平,并用定時器來產生中斷,使P1.0口產生PWM波。當P1.0口為高電平時啟動狀態(tài)機1,此時狀態(tài)機2不動作;當快任務采樣完成后,由定時器產生中斷,將P1.0口置為低電平,此時狀態(tài)機2動作,來完成慢任務采集。下一個周期完成同樣的操作。對應快任務的采集數(shù)據(jù)緩存在快任務FIFO,慢任務的采集數(shù)據(jù)緩存在慢任務FIFO里,單片機讀對應的FIFO數(shù)據(jù)來進行相應處理。
4.2 各模塊的設計
根據(jù)以上的設計思想,F(xiàn)PGA系統(tǒng)的硬件設計模塊主要有狀態(tài)機模塊,F(xiàn)IFO設計模塊[4-5].
下面具體給出硬件原理設計。
4.2.1 狀態(tài)機的設計
該設計過程主要是建立采集所需要的硬件電路,等待時鐘信號的到來便立刻啟動A/D進行工作。了解了AD574A的工作時序,就可以寫出狀態(tài)機的采樣控制狀態(tài)。控制狀態(tài)編碼表如表1所示。
評論