隨著(zhù)集成電路的發(fā)展,利用大規模集成電路來(lái)完成各種高速、高精度電子儀器的設計已經(jīng)成為一種行之有效的方法。采用這種技術(shù)制成的電子儀器電路結構簡(jiǎn)單、性能可靠、測量精確且易于調試。本文采用AlteraCycloneII系列FPGA器件EP2C5,設計了高精度相位測量?jì)x。測量相位差所需的信號源在FPGA內部運用DDS原理生成,然后通過(guò)高速時(shí)鐘脈沖計算兩路正弦波過(guò)零點(diǎn)之間的距離,最后通過(guò)一定的運算電路得到最終相位值,測相精度為1°。 系統硬件設計 該基于FPGA的相位測量?jì)x,硬件組成包括FPGA、高速DAC以及電壓比較器等部分。其系統硬件結構如圖1所示。 圖1相位測量?jì)x硬件結構圖 該測量?jì)x由按鍵來(lái)預置正弦波的頻率及相位。通過(guò)FPGA內部的控制模塊來(lái)計算并產(chǎn)生正弦波所需的頻率控制字和相位控制字,然后將控制字輸入DDS模塊以產(chǎn)生波形數據輸出,經(jīng)10位高速DACTHS5651輸出兩路正弦波。在測相位差時(shí),將圖1中移相正弦波輸出分為兩路,其中一路直接經(jīng)電壓比較器LM311整形后輸入測相模塊;另外一路先通過(guò)被測電路,然后再經(jīng)電壓比較器整形后輸入測相模塊,從而得到正弦波經(jīng)被測電路后產(chǎn)生的相移。 基于FPGA的硬件電路設計 DDS移相信號源設計 DDS的基本原理是利用采樣定理,通過(guò)查表法產(chǎn)生波形,本系統的移相信號發(fā)生模塊如圖2所示。 圖2基于DDS的數字移相信號發(fā)生模塊框圖 圖2中,加法器與寄存器級聯(lián)構成相位累加器。通過(guò)時(shí)鐘脈沖觸發(fā)相位累加器,從而將頻率控制字不斷累加。相位累加器產(chǎn)生一次溢出,就完成一次周期性的動(dòng)作,這個(gè)周期就是DDS合成信號的一個(gè)頻率周期。 用相位累加器輸出的數據作為波形存儲器的相位取樣地址,把存儲在波形存儲器內的波形抽樣值經(jīng)查找表查出,從而完成相位到幅值的轉換。然后將波形存儲器的輸出送到DAC,通過(guò)DAC將數字量形式的波形幅值轉換成合成頻率的模擬波形。 圖2中FWORD是10位頻率控制字;PWORD是10位相移控制字,用來(lái)控制正弦信號輸出的相移量;SINROM用來(lái)存放正弦波數據,有10位數據線(xiàn)和10位地址線(xiàn)。其中數據文件是MIF文件(數據深度1024,數據類(lèi)型為10進(jìn)制數),可由Matlab生成,存放數據的單元采用定制ROM的方法生成;POUT和FOUT都為10位輸出,分別和兩個(gè)高速DACTHS5651相連。 控制模塊的生成 在產(chǎn)生波形的過(guò)程中,DDS模塊所需的頻率和相位控制字由在FPGA內部編寫(xiě)的控制模塊來(lái)給定?刂颇K的頂層原理框圖如圖3所示。 圖3控制模塊頂層原理框圖 圖3中,B1、C10、D100、P1K分別為頻率步進(jìn)輸入端;Re為復位端;PW1、PW10分別為1?10?南轡徊澆?淙。其中fbcout為頻率控制字計算模塊,完成由頻率步進(jìn)值到二進(jìn)制頻率控制字的轉換。 cout360為相位輸入計算模塊,由相位輸入端的脈沖輸入計算出實(shí)際的移相值(0麀359)。add_data_rom是存放相位控制字的ROM,其數據文件是MIF文件,內部360個(gè)地址值分別對應0麀359?南轡,每個(gè)地址中的數據為每個(gè)相位值對應的正弦波ROM的地址值。由于正弦波ROM將一個(gè)波形分成了1024個(gè)點(diǎn),則0麀359?南轡恢刀雜α薙INROM中的360個(gè)點(diǎn)?紤]到1024/360=2。84非整,為了減小移相誤差,提高移相精度,本設計中采用分段處理的方法,將360個(gè)地址分成60組。第15、30、45、60組的6個(gè)地址中點(diǎn)與點(diǎn)之間的距離都為3;其余各組前5點(diǎn)之間的點(diǎn)距為3,第5點(diǎn)與第6點(diǎn)之間的點(diǎn)距為2。 相位測量模塊設計原理 本系統的相位測量采用由高速時(shí)鐘脈沖測量?jì)陕凡ㄐ芜^(guò)零點(diǎn)之間距離的方法。相位測量模塊原理框圖如圖4所示。 圖4相位測量模塊原理框圖 圖4中,A、B為兩路方波輸入,CLK為50MHz時(shí)鐘輸入,dfd2塊為下降沿觸發(fā)的2分頻模塊。A、B經(jīng)2分頻的目的是使測相范圍由0麀180蟮0麀360OR為異或門(mén),其輸出信號的脈寬為(b-a)。clxw為一高速計數器,通過(guò)25MHz的高頻時(shí)鐘來(lái)計算(b-a)的長(cháng)度。fb360模塊為倍乘模塊,主要完成(b-a)×360的運算。bpsc模塊為分頻模塊,將25MHz的時(shí)鐘信號進(jìn)行(b-a)×360倍的分頻,使其輸出信號脈寬為T(mén)clk×(b-a)×360(Tclk為25MHz的時(shí)鐘周期)。xwc為相位差計數模塊,通過(guò)A相輸入脈沖,計算Tclk×(b-a)×360的長(cháng)度,然后完成(b-a)×360/a的計算,進(jìn)而得出相位差值輸出,同時(shí)該模塊還將測得的相位差值送到數碼管顯示。 在對該模塊進(jìn)行仿真時(shí),人為設定了頻率為10KHz,相位差為72。 系統驗證調試 在整個(gè)系統的驗證中,由外部按鍵通過(guò)控制模塊來(lái)設定波形的頻率和相位值,并通過(guò)將DDS模塊的輸出端FOUT和POUT外接10位DACTHS5651來(lái)產(chǎn)生波形。通過(guò)在示波器觀(guān)察兩路波形發(fā)現,波形比較穩定,頻率與設定值一致。此外,為了測量DDS模塊產(chǎn)生的移相是否正確,還人為的通過(guò)相位輸入端設定相移值,并將參考波形輸出端和移相輸出端輸出的波形經(jīng)整形后,用測相模塊測量?jì)陕凡ㄐ蔚南辔徊,通過(guò)硬件調試發(fā)現測得的相位差與設定的相位差完全一致,從而證明了該系統是精確、穩定的。 結語(yǔ) 本系統選用Altera公司的quartusII4。1作為硬件開(kāi)發(fā)平臺,并采用VHDL語(yǔ)言進(jìn)行電路設計。在設計中按功能劃分模塊,方便了調試與修改,且易于升級。同時(shí),系統設計中還較多采用了同步時(shí)序電路來(lái)實(shí)現各個(gè)進(jìn)程模塊的功能,從而有效避免了電路毛刺現象。此外,在相位測量模塊中,相位差計數塊還帶有鎖存功能,從而有利于輸出的相位差值顯示穩定。 |