一種基于FPGA的新型數字電壓表研究與設計
數字電壓表是大學(xué)物理教學(xué)和實(shí)驗中的重要儀表,其數字化是指將連續的模擬電壓量轉換成不連續、離散的數字量并加以顯示。傳統的實(shí)驗用模擬電壓表功能單一、精度低、體積大,且存在讀數時(shí)的視差,長(cháng)時(shí)間連續使用易引起視覺(jué)疲勞,使用中存在諸多不便。而目前數字萬(wàn)用表的內部核心多是模/數轉換器,其精度很大程度上限制了整個(gè)表的準確度,可靠性較差。本文采用National Semiconductor。公司性能優(yōu)越的8位A/D轉換器ADC0809對模擬電壓采樣,以一片高性能FPGA芯片為控制核心,以軟件實(shí)現了諸多硬件功能,對電壓信號的轉換結果進(jìn)行準確實(shí)時(shí)的運算處理并送出顯示。系統的主要功能都集成在一塊芯片上,大大減少了系統的分立元件數量,降低了功耗,增加了可靠性,較好地實(shí)現了電壓的精準測量。
1 設計方案比較
采用雙積分式模/數轉換器為核心器件,稱(chēng)為雙積分式電壓表。在一個(gè)測量周期內,將被測電壓Ui加到積分器的輸入端,在確定的時(shí)間內進(jìn)行積分。然后切斷輸入電壓,在積分器的輸入端加與Ui極性相反的電壓U,進(jìn)行定值積分,但積分方向相反,直到積分輸出達到起始電平為止,從而將Ui轉換成時(shí)間間隔量進(jìn)行測量。只要用計數器累計時(shí)間間隔內的脈沖數,即為Ui之值。電路簡(jiǎn)單,便于維護。但電壓表的測量精度完全受限于模/數轉換的精度。而且系統無(wú)升級空間。
另外,采用單片機作為系統的控制核心。輸入信號經(jīng)模/數轉換后送到單片機進(jìn)行數據處理,根據不同電壓信號計算出不同數值,并送出顯示。這種方案優(yōu)點(diǎn)是的單片機技術(shù)成熟、運算功能較強、編程靈活、設計成本也較低,能較準確地測量輸入電壓。但在單片機系統中必須使用許多分立元件組成其外圍電路,整個(gè)系統顯得十分復雜,可靠性較低,抗干擾能力差,而且功耗高。
采用現場(chǎng)可編程門(mén)陣列即FPGA為系統核心,是當今電子產(chǎn)品設計的熱門(mén)發(fā)展方向。系統最大限度地將所有器件集成在FPGA芯片上,體積大大減小、集成度高,可靠性高。而且邏輯單元控制靈活、適用范圍極廣,實(shí)現了大規模和超大規模電路的集成。其硬件功能完全由軟件編程實(shí)現,修改調試方便,在不改變原有電路的基礎上便可實(shí)現系統升級。較好地克服了另外兩種方案的缺陷,具有自己獨特的優(yōu)勢。綜合上述分析,采用FPGA技術(shù),優(yōu)勢明顯。
2 系統工作原理
首先,被測電壓信號進(jìn)入A/D轉換器,FPGA中控制信號模塊發(fā)出控制信號,啟動(dòng)A/D轉換器進(jìn)行轉換,其采樣得到的數字信號數據在相應的碼制轉換模塊中轉換為顯示代碼。最后譯碼驅動(dòng)模塊發(fā)出顯示控制與驅動(dòng)信號,驅動(dòng)外部的LCD模塊顯示相應的數據。通過(guò)外部的鍵盤(pán),可以手動(dòng)對系統進(jìn)行復位控制和檔位選擇,不同的檔位決定不同的電壓輸入范圍,在程序中實(shí)現自動(dòng)轉換?;竟ぷ髟砜驁D如圖1所示。
3 關(guān)鍵電路設計
3.1 A/D轉換電路
實(shí)現A/D轉換的方法比較多,常見(jiàn)的有計數法、雙積分法和逐次逼近法。由于逐次逼近式A/D轉換具有速度快,分辨率高等優(yōu)點(diǎn),而且采用該法的ADC芯片成本較低,因此在設計中采用該種方式。逐次逼近式A/D轉換器的原理如圖2所示。它由逐次逼近寄存器、D/A轉換器、比較器和緩沖寄存器等組成。當啟動(dòng)信號由高電平變?yōu)榈碗娖綍r(shí),逐次逼近寄存器清0,這時(shí),D/A轉換器輸出電壓V。也為O,當啟動(dòng)信號變?yōu)楦唠娖綍r(shí),轉換開(kāi)始,同時(shí),逐次逼近寄存器進(jìn)行計數。轉換原理如圖2所示。
逐次逼近寄存器工作時(shí)與普通計數器不同,它不是從低位向高位逐一進(jìn)行計數和進(jìn)位,而是從最高位開(kāi)始,通過(guò)設置試探值來(lái)進(jìn)行計數。在第一個(gè)時(shí)鐘脈沖到來(lái)時(shí),控制電路把最高位送到逐次逼近寄存器,使它的輸出為10000000,這個(gè)輸出數字一出現,D/A轉換器的輸出電壓V。就成為滿(mǎn)量程值的128/255。這時(shí),若Vo>Vi則作為比較器的運算放大器的輸出就成為低電平,控制電路據此清除逐次逼近寄存器中的最高位;若Vo≤Vi則比較器輸出高電平,控制電路使最高位的1保留下來(lái)。
若最高位被保留下來(lái),則逐次逼近寄存器的內容為10000000,下一個(gè)時(shí)鐘脈沖使次低位D6為1。于是,逐次逼近寄存器的值為11000000,D/A轉換器的輸出電壓Vo到達滿(mǎn)量程值的192/255。此后,若Vo>Vi則比較器輸出為低電平,從而使次高位域復位;若VoVi則比較器輸出為高電平,從而保留次高位為1。重復上述過(guò)程,經(jīng)過(guò)N次比較以后,逐次逼近寄存器中得到的值就是轉換后的數值。轉換結束后,控制電路送出一個(gè)低電平作為結束信號,此信號的下降沿將逐次逼近寄存器中的數字量送入緩沖寄存器,從而得到數字量輸出。
評論