<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > FPGA與單片機實現(xiàn)低頻數(shù)字式相位測量儀

          FPGA與單片機實現(xiàn)低頻數(shù)字式相位測量儀

          作者: 時間:2011-08-08 來源:網絡 收藏

          摘要:提出了以AVR ATmega128和Altera公司的Cyclone系列EP1C3T100為核心的系統(tǒng)設計方案。分析了數(shù)字式相位的測量原理和測量誤差及其消除的方法。主要介紹了系統(tǒng)的軟硬件設計。實踐表明,此方案設計的相位儀對正弦波信號精確測頻和測相位差,具有處理速度快、穩(wěn)定可靠、精度高等優(yōu)點。

          本文引用地址:http://www.ex-cimer.com/article/150391.htm

            關鍵詞:數(shù)字相位儀;;;誤差;頻率;相位差

            本設計采用MCU和相結合的系統(tǒng)方案,以AVRATmega128和Altera公司的Cyclone系列EP1C3T100為核心,充分發(fā)揮各自的優(yōu)勢,如AVR單片機先進的RISC結構和強勁的運算、控制功能,Altera公司的運算速度快、資源豐富以及易編程的特點,合理設計,此方案的相位儀具備速度快、穩(wěn)定可靠、精度高等優(yōu)點,而且容易“智能化”和“自動化”。

            1 系統(tǒng)方案設計

            1.1 測量方法的比較與選擇

            目前相位測量的方法主要有兩種:

            1)DFT測相法即將待測信號通過A/D轉換得到f(n),f(n)按離散傅里葉變換得出離散頻譜F(k),f(n)和F(k)為傅里葉變換對,通過運算得到兩路信號的基波相位,從而計算出相位差。DFT測相法的精度受限于ADC的采樣精度,需要高速ADC對信號進行過采樣,測量方案復雜,可以通過采集卡在計算機上虛擬儀器,所以主要應用在精度要求很高的場合和虛擬儀器中。

            2)填充計數(shù)測相法 即兩路同頻的正弦信號經過信號整形電路后得到方波信號,方波信號經過鑒相器后,得到兩路輸入信號的相位差信號,用固定頻率的采樣脈沖進行填充并計數(shù),從而計算出相位差。填充計數(shù)測相法主要應用在要求一定的精度,測量的頻率不是太高但實時性要求很強的場合,易于實現(xiàn)數(shù)字化和自動化,數(shù)字相位儀適合用填充計數(shù)法。

            填充計數(shù)測相法的基本算法:若正弦波整形后的方波信號頻率為f,周期為T,采樣脈沖周期為TC,方波一個周期內對采樣脈沖計數(shù)為,n則被測信號頻率f=1/T=1/nTC。同樣的方法測出兩個同頻正弦波起點之間的時間差為△t,則兩信號的相位差△θ=△t·360°/T。

            1.2 系統(tǒng)方案的確定

            由系統(tǒng)測量方法可知,數(shù)據需要采集、運算及顯示,考慮到Field Programmable Gate Array(FPGA)集成度高、I/O資源豐富、穩(wěn)定可靠,選擇余地大,外圍元件很少,近年來價格下降等優(yōu)勢,以及MCU良好的人機接口和運算控制功能,所以本系統(tǒng)由MCU和FPGA相結合構成測控主體。FPGA負責采集測頻和測相位差的脈沖信號,MCU負責讀FPGA采集的數(shù)據,計算待測信號頻率和相位差并在LCD上顯示。

            所以,系統(tǒng)由4個部分組成:待測信號調理電路、FPGA數(shù)據采集電路、MCU數(shù)據運算控制電路和LCD數(shù)據顯示電路,如圖1所示。

            2 測量誤差的分析與消除

            相位的完善設計,不僅要有合適的測量方法和系統(tǒng)實現(xiàn)方案,還需要著重分析誤差產生的原因和確定消除的方法。

            1)填充時鐘頻率(即數(shù)據采樣信號)的影響與確定本相位的測頻范圍為20 Hz~20 kHz,相位差的范圍為△θ=0°~359.9°,相位差的顯示分辨率為0.1°,要求測量相位的絕對誤差≤2。

            被測頻率20 Hz≤f≤20 kHz,則周期50μs≤T≤50 ms。

            T=50 μs,絕對誤差取0.1°~2°。

            則填充時鐘信號周期:0.1°x50 μs/360°≤TC≤2°x50 μs/360°即:1/72(μs)≤TC≤1/3.6(μs),可以得出填充時鐘頻率:

            3.6 MHz≤fC≤72 MHz。

            T=50ms內對TC=1/3.6(μs)的填充脈沖計數(shù),計數(shù)值Nmin=180000≤218;對TC=1/72(μs)的填充脈沖計數(shù),計數(shù)值Nmax=3600000≤ 222。

            本設計考慮MCU的計算及分頻取得信號的方便,填充時鐘信號頻率fC=20 MHz,測量絕對誤差1°,F(xiàn)PGA在20 MHz時鐘信號作用下對待測信號周期和相位對應的時間差進行計數(shù),F(xiàn)PGA采樣的二進制數(shù)據位為20 bit,可以保證測量的精度。

            2)待測信號調理電路中零點漂移的影響與消除待測信號調理電路主要作用是把輸入信號整形變換成矩形波,通常采用過零比較器或者施密特觸發(fā)器。

            過零比較器在零點電位附近可能會有振蕩,輸入信號在零點電位附近時,電壓比較器處于放大區(qū),整形后的矩形波在邊沿會產生抖動,使系統(tǒng)無法進行測量。要消除這種抖動,可以采用施密特觸發(fā)器。為了保證測量的精度,施密特觸發(fā)器必須符合兩個條件:一是兩路被測信號幅度基本相等,二是門限電平要基本接近。

            3)整形后方渡邊沿的陡峭程度的影響與消除信號經過整形后輸出的矩形脈沖信號直接送給FPGA,則FPGA不能立即獲取穩(wěn)定的數(shù)字脈沖信號,就會使系統(tǒng)的精度受到很大影響。這主要是由于整形后方波邊沿不夠陡峭造成的。要解決此問題,一是選取具有較大壓擺率的器件,二是在比較器的后端加一級微分電路來提升脈沖信號的邊沿。

            4)中低頻測量精度的影響與消除采用20 MHz數(shù)據采樣信號來循環(huán)計數(shù)被測信號的周期及相位差對應的時間差,精度達到0.05 μs,20位數(shù)字量的單位是0.05μs。利用被測信號刷新采樣計數(shù),實現(xiàn)高頻多測量,低頻少測量,時間計數(shù)精確可靠,這樣,F(xiàn)PGA可以為MCU提供穩(wěn)定的數(shù)據。

            3 系統(tǒng)硬件電路的設計

            3.1 前端信號調理電路的設計

            施密特觸發(fā)器(遲滯比較器)雖然可以很好地消除比較器過零引起的抖動,但是其輸出信號和輸入信號存在相位差,如果兩路被測信號的幅度基本相等且兩個施密特觸發(fā)器的門限電平又很接近,則施密特觸發(fā)器引入的相位誤差對測量系統(tǒng)誤差幾乎無影響。

            采用LM339內部有4個獨立的電壓比較器,該電壓比較器的特點是:失調電壓小,典型值為2 mV;電源電壓范圍寬,雙電源電壓為±1~±18 V;對比較信號源的內阻限制較寬。同相和反相輸入端電壓差別大于10 mV就能確保輸出能從一種狀態(tài)可靠地轉換到另一種狀態(tài),輸出端相當于一只不接集電極電阻的晶體三極管,在使用時輸出端到正電源一般須接一只電阻。在跳變電壓值附近的干擾不超過回差AU,輸出電壓的值就將是穩(wěn)定的。正反饋可以加快比較器的響應速度。由于遲滯比較器加的正反饋很強,遠比電路中的寄生耦合強得多,所以可免除由于電路寄生耦合而產生的自激振蕩。通過調節(jié)電位器,使兩個施密特觸發(fā)器的門限電平基本相等,保證輸入電路對相位差測量不帶來誤差。電路如圖2所示。


          上一頁 1 2 3 下一頁

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();