摘要:基于SoPC技術(shù)設(shè)計(jì)了一種專(zhuān)門(mén)激勵(lì)管道超聲導(dǎo)波的信號(hào)發(fā)生器。重點(diǎn)闡述了導(dǎo)波專(zhuān)用DDS IP核的設(shè)計(jì)方法。發(fā)生器以MicroBlaze軟核處理器為控制核心,單片F(xiàn)PGA輔以必要的少量外圍硬件電路,易于擴(kuò)展升級(jí)。實(shí)驗(yàn)結(jié)果表明,輸出的信號(hào)精度高、噪聲小、穩(wěn)定性好,頻率連續(xù)可調(diào),可方便地應(yīng)用于管道超聲導(dǎo)波檢測(cè)。
在管道缺陷檢測(cè)當(dāng)中,超聲導(dǎo)波檢測(cè)技術(shù)與傳統(tǒng)無(wú)損檢測(cè)方法相比具有沿傳播路徑衰減小,傳播距離遠(yuǎn),引起的質(zhì)點(diǎn)振動(dòng)能遍及構(gòu)件內(nèi)部和表面的特點(diǎn),因此表現(xiàn)出更大優(yōu)勢(shì)[1]。超聲導(dǎo)波在傳播過(guò)程中存在多模態(tài)和頻散特性,若激勵(lì)源選擇不當(dāng),導(dǎo)波發(fā)生嚴(yán)重頻散,會(huì)使回波信號(hào)變得極為復(fù)雜,不利于缺陷分析。根據(jù)導(dǎo)波頻散特性曲線(xiàn)可知,在50kHz~500kHz范圍內(nèi),L(0,2)模態(tài)超聲導(dǎo)波傳播速度最快最穩(wěn)定,幾乎不發(fā)生頻散。用漢寧窗調(diào)制該頻段內(nèi)一定周期數(shù)的單音頻信號(hào),形成窄帶脈沖作為激勵(lì)源,激勵(lì)出L(0,2)模態(tài)占主導(dǎo)的超聲導(dǎo)波,可最大限度地避免頻散帶來(lái)的不利影響[2]。
目前出現(xiàn)了多種超聲導(dǎo)波激勵(lì)信號(hào)發(fā)生器設(shè)計(jì)方案。一是利用多功能函數(shù)發(fā)生器如HP33120A[3]實(shí)現(xiàn)。由于HP33120A存儲(chǔ)長(zhǎng)度有限,長(zhǎng)距離檢測(cè)時(shí)脈沖間會(huì)出現(xiàn)干擾,最高調(diào)制頻率不高[4]。二是采用單片機(jī)控制DDS芯片設(shè)計(jì),精度較高,但定制性較弱,且一般需要兩片以上DDS芯片,成本昂貴。還有一種方法是用高速單片機(jī)控制D/A轉(zhuǎn)換芯片直接輸出信號(hào),方便易行,然而精度較低,激勵(lì)頻率受到單片機(jī)頻率限制,而且很難做到連續(xù)可調(diào)。為了解決上述設(shè)計(jì)方案的不足,本設(shè)計(jì)在Xilinx公司FPGA(現(xiàn)場(chǎng)可編程門(mén)陣列)上,以MicroBlaze軟核處理器為控制核心,借鑒直接數(shù)字頻率合成DDS(Direct Digital Frequncy Synthesis)技術(shù),給出了一種產(chǎn)生L(0,2)模態(tài)超聲導(dǎo)波激勵(lì)信號(hào)源的SoPC(System on Programmable Chip)實(shí)現(xiàn)方法。所得激勵(lì)源精度高,漢寧窗調(diào)制下的單音頻正弦波周期數(shù)可調(diào),頻率連續(xù)可調(diào)。
1 系統(tǒng)整體方案設(shè)計(jì)
本系統(tǒng)以Xilinx公司Spartan 3E-Starter開(kāi)發(fā)板為硬件平臺(tái)。此開(kāi)發(fā)平臺(tái)外設(shè)資源較為豐富,通過(guò)增加少量的外圍設(shè)備即可實(shí)現(xiàn)系統(tǒng)設(shè)計(jì)。Spartan 3E系列FPGA是Xilinx 公司性?xún)r(jià)比最高的FPGA芯片,可較好地滿(mǎn)足產(chǎn)品的高集成化與低成本化[5]。其內(nèi)部MicroBlaze軟核處理器采用功能強(qiáng)大的32位流水線(xiàn)RISC結(jié)構(gòu),包含32個(gè)32位的通用寄存器、2個(gè)32位特殊寄存器,可具有3/5級(jí)流水線(xiàn)。時(shí)鐘頻率高達(dá)150MHz。以IBM CoreConnect技術(shù)為基礎(chǔ),提供了豐富的接口資源。其中PLB(處理器本地總線(xiàn))總線(xiàn)提供對(duì)片上外設(shè)、外部存儲(chǔ)器以及基于硬件描述語(yǔ)言編寫(xiě)的算法模塊的訪問(wèn) ,和其他外設(shè)IP核一起,完成嵌入式的SoPC開(kāi)發(fā)。超聲導(dǎo)波激勵(lì)源的SoPC實(shí)現(xiàn)結(jié)構(gòu)如圖1所示。
FPGA實(shí)現(xiàn)所有數(shù)字電路部分。MicroBlaze軟核處理器是系統(tǒng)的控制核心,通過(guò)LMB(本地存儲(chǔ)器總線(xiàn))訪問(wèn)程序存儲(chǔ)空間BRAM,PLB總線(xiàn)掛載所需IP核。例化GPIO接口連接鍵盤(pán),負(fù)責(zé)激勵(lì)信號(hào)的頻率設(shè)置。LCD1602用于當(dāng)前頻率值顯示。自主編寫(xiě)的DDS IP為系統(tǒng)波形發(fā)生的核心,直接產(chǎn)生激勵(lì)源波形。MDM為系統(tǒng)的調(diào)試模塊,RS232用于和PC機(jī)通信或程序調(diào)試。使用Xilinx嵌入式開(kāi)發(fā)套件EDK自帶的數(shù)字時(shí)鐘管理DCM(Digital Clock Manager) IP核,把50MHz輸入時(shí)鐘分頻,分別為DDS模塊和外部高速數(shù)模轉(zhuǎn)換芯片DAC902提供穩(wěn)定的5MHz和50MHz時(shí)鐘信號(hào)。程序通過(guò)JTAG下載到FPGA內(nèi)部的BRAM,或者片外PROM中存儲(chǔ)。FPGA產(chǎn)生的數(shù)字信號(hào)經(jīng)過(guò)DAC902轉(zhuǎn)換為模擬信號(hào),再經(jīng)過(guò)低通濾波器去噪,即可獲得高質(zhì)量的超聲導(dǎo)波激勵(lì)信號(hào)源。
2 超聲導(dǎo)波DDS IP核設(shè)計(jì)
2.1 DDS算法原理
DDS是根據(jù)采樣定理,通過(guò)查找表方法產(chǎn)生波形。通常為正弦波、余弦波、三角波或方波等。完整的DDS結(jié)構(gòu)示意圖如圖2所示。在參考時(shí)鐘的驅(qū)動(dòng)下,N bit相位累加器對(duì)頻率控制字K進(jìn)行相位累加,得到的相位碼對(duì)波形存儲(chǔ)器尋址,使之輸出相應(yīng)的波形幅度值。將該值送給DAC和低通濾波器LPF,實(shí)現(xiàn)量化幅值到一個(gè)平滑信號(hào)的轉(zhuǎn)換。當(dāng)相位累加值大于2N時(shí),相位累加器產(chǎn)生一次溢出,溢出頻率就是DDS的輸出頻率。輸出信號(hào)頻率fout可表示為:
由DDS原理可知,相位累加器的位數(shù)N決定DDS的精度。N值越大,DDS的頻率間隔?駐f就越細(xì)。但N值增加,所需ROM容量也將成指數(shù)增加。實(shí)際上在一般系統(tǒng)中,D/A轉(zhuǎn)換器的位數(shù)m是一定的,通常選取累加器的輸出位數(shù)N=m+2,即可滿(mǎn)足需要[6]。設(shè)計(jì)中DAC902為12bit,取累加器為14bit,調(diào)制脈沖最大幅值為212,即4096。借助Matlab,生成由漢寧窗調(diào)制10個(gè)周期正弦波的窄帶脈沖波形,如圖3所示。
本設(shè)計(jì)基于DDS技術(shù),采用Verilog HDL硬件描述語(yǔ)言設(shè)計(jì)直接產(chǎn)生導(dǎo)波激勵(lì)波形的DDS模塊,頂層原理如圖4所示。
L(0,2)模態(tài)超聲導(dǎo)波的50kHz~500kHz頻率是指單音頻信號(hào)頻率(如圖3所示,10個(gè)周期,設(shè)單音頻率為f0),而非DDS輸出頻率fout。由Tout=10T0,得fout=f0/10。所以DDS輸出fout應(yīng)為5kHz~50kHz。系統(tǒng)主時(shí)鐘為50MHz,在DDS輸出最高頻率為50kHz時(shí),為實(shí)現(xiàn)0.3kHz(單音頻3kHz) 步進(jìn)值,10周期窄帶脈沖取樣點(diǎn)數(shù)不少于100點(diǎn),以減小失真,則時(shí)鐘頻率必須大于4.9MHz。將系統(tǒng)主時(shí)鐘10分頻,得到5MHz DDS時(shí)鐘頻率。頻率控制字取8bit就可滿(mǎn)足要求。
累加器模塊Accu對(duì)頻率控制字K累加,并將結(jié)果的低14位sum[13:0]送給下一級(jí)Reg寄存器,作為ROM地址。Accu的最高位sum[14]為判斷位。在累加過(guò)程中,當(dāng)相位sum[14]為1時(shí),累加器清零,完成一次脈沖發(fā)射。然后通過(guò)一個(gè)計(jì)數(shù)器實(shí)現(xiàn)延時(shí)功能,使激勵(lì)脈沖每隔1ms發(fā)射一次。
ROM模塊采用ISE中ROM IP核直接定制。如果在系統(tǒng)中添加多個(gè)ROM,每個(gè)ROM中分別載入不同周期的調(diào)制脈沖,可實(shí)現(xiàn)激勵(lì)源的周期可調(diào)。借助Matlab,把圖3窄帶脈沖量化成12bit的定點(diǎn)波形數(shù)值,形成.coe文件并加載到ROM中。
將頻率控制字K設(shè)為23時(shí),輸出頻率fout等于7kHz,對(duì)應(yīng)單音頻信號(hào)為70kHz。Modelsim仿真波形如圖5所示。
3 系統(tǒng)硬件實(shí)現(xiàn)
3.1 外設(shè)IP核掛載
利用EDK的XPS,創(chuàng)建MicroBlaze硬件平臺(tái)。通過(guò)Base System Builder Wizard快速添加配置,如RS232、GPIO、BRAM等。對(duì)于自主編寫(xiě)的DDS模塊,使用Create/Import Peripheral工具,適當(dāng)修改user logic和IPIF兩個(gè)自動(dòng)生成文件,可將自己的邏輯模塊掛接在PLB總線(xiàn)上,無(wú)需過(guò)多關(guān)心自定義IP與PLB總線(xiàn)的協(xié)議和接口邏輯。在XPS中添加自帶的DCM時(shí)鐘管理模塊,為DDS IP和DAC提供精確穩(wěn)定的時(shí)鐘輸入。最后為所有外設(shè)分配地址,建立端口連接。
4 軟件設(shè)計(jì)
軟件部分在SDK中通過(guò)C語(yǔ)言編寫(xiě)完成,主要包括初始化、GPIO口鍵盤(pán)值讀取、LCD顯示、DDS頻率字輸入和調(diào)節(jié)等。由于導(dǎo)波頻率在50kHz~500kHz,跨度較大。為方便實(shí)際檢測(cè),設(shè)計(jì)了頻率粗調(diào)和微調(diào)功能。系統(tǒng)鍵盤(pán)包括設(shè)置鍵(Set)、粗調(diào)鍵(Adjust)、微調(diào)鍵(Fine)、確認(rèn)鍵(OK)以及復(fù)位鍵(Reset)。上電后,頻率控制字K為初始值16,系統(tǒng)產(chǎn)生50kHz默認(rèn)頻率激勵(lì)信號(hào)。每按一次粗調(diào)鍵(Adjust),K值增加,分別對(duì)應(yīng)70kHz、120kHz、170kHz等基數(shù)頻率。用微調(diào)鍵(Fine)以3kHz為步進(jìn)值進(jìn)行細(xì)調(diào)。通過(guò)寫(xiě)寄存器語(yǔ)句DDS_IP_mWriteReg將K值賦給DDS模塊,產(chǎn)生相應(yīng)頻率激勵(lì)信號(hào)。程序流程如圖8所示。
5 實(shí)驗(yàn)結(jié)果分析
系統(tǒng)上電后,在鍵盤(pán)上選擇激勵(lì)頻率值為70kHz,使用NI PCI-5102數(shù)字化儀的虛擬示波器對(duì)輸出信號(hào)進(jìn)行采集和分析。捕捉到的激勵(lì)信號(hào)如圖9所示。由面板參數(shù)可知,波形最高幅值1.5V,包含10個(gè)周期單音頻信號(hào)的窄帶脈沖寬度約為0.142ms。改變鍵盤(pán)輸入,對(duì)輸出信號(hào)進(jìn)行FFT頻譜分析,如表1所示。實(shí)驗(yàn)結(jié)果表明,此設(shè)計(jì)產(chǎn)生的激勵(lì)信號(hào)精度高,波形純凈,性能良好,頻率連續(xù)可調(diào),較好地滿(mǎn)足了設(shè)計(jì)要求。
利用SoPC技術(shù),給出了一種新的超聲導(dǎo)波激勵(lì)信號(hào)發(fā)生器的設(shè)計(jì)方法。重點(diǎn)論述了導(dǎo)波專(zhuān)用DDS模塊的實(shí)現(xiàn)過(guò)程。把系統(tǒng)的主要功能集成在單片F(xiàn)PGA內(nèi),減少了外圍電路,體積小,功耗低,抗干擾能力強(qiáng),易于擴(kuò)展和升級(jí),有效降低了設(shè)計(jì)成本。產(chǎn)生的激勵(lì)信號(hào)精度高,穩(wěn)定性好,頻率連續(xù)可調(diào)。本設(shè)計(jì)可方便地應(yīng)用到管道超聲導(dǎo)波缺陷檢測(cè)中,并為開(kāi)發(fā)小型化、集成化的導(dǎo)波檢測(cè)系統(tǒng)提供了可能。
參考文獻(xiàn)
[1] 吳斌,鄧菲,何存富. 超聲導(dǎo)波無(wú)損檢測(cè)中的信號(hào)處理研究進(jìn)展[J].北京工業(yè)大學(xué)學(xué)報(bào),2007,33(4):342-348.
[2] 王軍陣,王建斌,王帥. 基于DS89C430的超聲導(dǎo)波激勵(lì)信號(hào)源的設(shè)計(jì)[J].電子設(shè)計(jì)工程,2010,18(10):136-138.
[3] 吳斌,王智,金山,等.用于激勵(lì)超聲導(dǎo)波的任意波形發(fā)生器[J].北京工業(yè)大學(xué)學(xué)報(bào),2002,28(4):389-393.
[4] 金傳喜,武新軍,夏志敏,等.導(dǎo)波檢測(cè)用激勵(lì)源的設(shè)計(jì)與應(yīng)用[J].制造業(yè)自動(dòng)化,2006,28(10):79-81.
[5] 田耘,胡彬,徐文波,等.Xilinx ISE Design Suite 10.xFPGA開(kāi)發(fā)指南——邏輯設(shè)計(jì)篇[M].北京:人民郵電出版社,2008:27-29.
[6] 王金明.數(shù)字系統(tǒng)設(shè)計(jì)與Verilog HDL(第三版)[M].北京:電子工業(yè)出版社,2009:285-286.