楊世佳,李云鵬
(蘭州空間技術(shù)物理研究所,蘭州 730000)
靜電懸浮加速度計主要用于衛(wèi)星精密定軌需要,測量由太陽光壓引起的衛(wèi)星攝動加速度,為衛(wèi)星定軌和軌道補償提供數(shù)據(jù)支持[1]。靜電懸浮加速度計是測量航天器受到的準穩(wěn)態(tài)微小加速度的基本設備[2],屬于差分電容式慣性加速度傳感器,主要由傳感器探頭單元和測量控制單元兩部分組成。測量控制單元的主要作用是對傳感器單元的敏感結(jié)構(gòu)進行伺服反饋控制,并采集傳感器的電容位移數(shù)據(jù)和所受的微小加速度數(shù)據(jù)。測量控制單元主要包括信號采集模塊、載波信號產(chǎn)生模塊、基準電壓產(chǎn)生模塊以及主控模塊等。
靜電懸浮加速度計作為精密測量設備,主要用于測量空間擾動引起的微小加速度,目前關(guān)于該領域的研究文獻,主要關(guān)注于對加速度測量分辨率和穩(wěn)定性的提高以及傳感器的精密加工和裝配等,對于靜電懸浮加速度計控制系統(tǒng)及控制器相關(guān)文獻較少。硬件層面一般不會存在較大的差別,例如上海交通大學研制的靜電懸浮加速度計中采用TI公司32位浮點型DSP作為六軸微加速度計的控制芯片,用于數(shù)據(jù)采集和控制算法的實現(xiàn),其采用模糊PID控制算法,可以根據(jù)加速度計的運行情況,實時調(diào)整PID控制參數(shù)[3]。長春理工大學采用DSP+FPGA的架構(gòu)來實現(xiàn)加速度計控制器,DSP作為主控芯片,主要用于實現(xiàn)控制算法等,FPGA作為輔助控制芯片,用于實現(xiàn)ADC芯片和DAC芯片的時序控制等[4]。法國的等效原理驗證衛(wèi)星-顯微鏡衛(wèi)星(MICROSCOPE),主要載荷也是靜電懸浮加速度計[5],其采用單獨的接口控制單元用于實現(xiàn)加速度計的數(shù)據(jù)采集和接口控制,其接口控制單元同樣采用的是DSP+FPGA的架構(gòu)來實現(xiàn)的,主要也是硬件層面的介紹,關(guān)于軟件算法以及控制策略等介紹較少。
對靜電懸浮加速度計這樣的高精密測量設備,如何實現(xiàn)加速度信號的采集處理、量程的切換、穩(wěn)定的反饋控制等,對靜電懸浮加速度計的在軌可靠工作至關(guān)重要。本文基于DSP+FPGA的架構(gòu)設計了靜電懸浮加速度計控制器,基于此架構(gòu),提出了一種工作模式切換控制策略,可以實現(xiàn)加速度計在軌捕獲和大小量程切換控制,并設計了一種基于此架構(gòu)的系統(tǒng)復位控制策略,可以實現(xiàn)雙芯片控制器的在軌復位和同步協(xié)調(diào)工作。針對加速度計特殊應用,設計開發(fā)了PID控制算法和FIR數(shù)字濾波算法,用于實現(xiàn)對檢驗質(zhì)量的在軌穩(wěn)定控制和數(shù)據(jù)處理。
數(shù)字信號處理器[6]是專門為快速實現(xiàn)各種數(shù)字信號處理算法而設計的,具有特殊結(jié)構(gòu)的微處理器芯片。DSP芯片根據(jù)數(shù)據(jù)處理格式的不同,分為定點型和浮點型兩種[7]。浮點運算的動態(tài)范圍較大,加速度計中采用TI公司生產(chǎn)的32位浮點處理器SMJ320VC33芯片。FPGA芯片是現(xiàn)場可編程門陣列的簡稱,根據(jù)FPGA架構(gòu)的不同,FPGA芯片分為SRAM(static random-access memory,SRAM)型、FLASH型以及反熔絲型[8],SRAM型是一種應用范圍較廣的FPGA芯片。在加速度計控制器設計中,采用的是國產(chǎn)抗輻射300萬門SRAM型FPGA芯片。
基于DSP和FPGA的靜電懸浮加速度計控制器整體架構(gòu)如圖1所示。DSP作為主處理器,主要負責系統(tǒng)的初始化和任務調(diào)度、工作模式切換控制、數(shù)據(jù)采集交換、數(shù)據(jù)處理和組包功能以及1553B總線通信功能和在軌維護功能。FPGA作為輔助處理器,主要承擔對時序要求嚴格的模數(shù)轉(zhuǎn)換器(analog-digital converter,ADC)、數(shù)模轉(zhuǎn)換器(digital-analog converter,DAC)接口控制、PID控制器、FIR數(shù)字濾波器、可調(diào)移相控制、1553B總線橋接與DSP數(shù)據(jù)交互以及DSP加載方式的設置等。
圖1 靜電懸浮加速度計控制器整體架構(gòu)Fig.1 The overall architecture of the electrostatic levitation accelerometer controller
DSP芯片的外設包括片外SRAM芯片,主要用于緩存DSP程序和數(shù)據(jù)。PROM(programmable read-only memory,PROM)芯片作為一種高可靠非易失性存儲器,主要用于存儲經(jīng)過反復驗證的DSP軟件程序,確保DSP能夠在軌進行程序可靠加載?;谏鲜鯠SP工作特點及功能需求,在DSP外設中,增加一片F(xiàn)LASH芯片,一方面用于DSP軟件地面測試,可以反復進行程序燒寫。另外,也可以進行軟件在軌上注和控制參數(shù)在軌重構(gòu),從而確保加速度計工作在最佳狀態(tài),執(zhí)行特定的在軌測試任務。
FPGA芯片的外設包括片外FLASH芯片和PROM芯片。由于靜電懸浮加速度計中采用的是SRAM型FPGA芯片,芯片掉電后,內(nèi)部程序丟失,所以為了方便地面硬件調(diào)試和軟件測試,為FPGA增加一片F(xiàn)LASH芯片,用于地面測試。FPGA軟件最終測試完成后,在軟件最后落焊前,拆掉FLASH芯片,將測試完成的FPGA軟件燒錄進PROM芯片。FPGA主要完成芯片時序控制、相敏解調(diào)控制以及PID算法和FIR數(shù)字濾波算法的實現(xiàn),加速度計在軌應用時,并不需要對FPGA軟件進行修改,所以對FPGA來說,僅僅采用一次可編程的PROM芯片,用于存放FPGA的配置數(shù)據(jù),上電時,直接從PROM芯片加載。
DSP和FPGA之間通過地址和數(shù)據(jù)總線進行連接,進行數(shù)據(jù)交換,如圖1所示。同時FPGA為DSP芯片提供兩個硬件中斷,分別為數(shù)據(jù)采集中斷和通信中斷,DSP為FPGA提供復位信號及外設控制接口。
如前文所述,為了方便DSP進行程序的存儲以及大量數(shù)據(jù)的存儲和讀取,在DSP主控芯片電路設計中,外擴了SRAM、FLASH以及PROM芯片,其中SRAM芯片采用法國3D-plus公司生產(chǎn)的宇航級芯片,該芯片內(nèi)部共有8個基片,每個基片的容量為4Mbit(256K×16),總共32Mbit的存儲容量,基地址為0xC00000h。原理如圖2所示,包括A1~A17共17根地址線,HA0和LA0兩根高位和低位地址線以及I/O0~I/O31共32根數(shù)據(jù)線。同時,該芯片共有CS0~CS7共8個片選信號。通過將高位地址線HA0和低位地址線LA0連接在一起以及將片選信號CS0和CS4、CS1和CS5、CS2和CS6、CS3和CS7連接在一起,將其拼接成4個容量分別為256K×32的存儲空間,用于與DSP進行數(shù)據(jù)交換,存儲加速度計位移檢測數(shù)據(jù)和科學讀出數(shù)據(jù)。
圖2 DSP外擴SRAM芯片原理圖Fig.2 Schematic diagram of DSP external expansion SRAM chip
FLASH芯片選用美國的Aeroflex公司生產(chǎn)的ACT-F512K8N,共有A0~A16共17根地址線,容量為4Mbit,另外由8根數(shù)據(jù)線以及1根片選信號和兩根讀寫控制信號,片選信號與FPGA的I/O接口相連,讀寫控制信號與DSP芯片的讀寫控制端口連接。DSP的PROM芯片選擇北京軒宇的XY28F256,該PROM芯片包括15根地址線,8根數(shù)據(jù)線,還包括編程使能、片選使能以及輸出使能3個控制信號。另外在DSP外擴存儲電路設計時,由于PROM芯片和FLASH芯片為5V供電的芯片,SRAM芯片為3.3V供電,所以對于PROM和FLASH,需要在數(shù)據(jù)接口增加電平轉(zhuǎn)換芯片,使得PROM、FLASH芯片與數(shù)據(jù)總線接口之間的電平相匹配。
FPGA的外部擴展芯片包括一個用于地面測試時使用的FLASH芯片和一個用于在軌程序燒錄的PROM芯片。其中FLASH芯片采用的是Xilinx公司生產(chǎn)的存儲空間為16Mbit的工業(yè)級XCF16PV0G48C芯片,PROM采用的同樣也是Xilinx公司生產(chǎn)的抗輻射高等級16Mbit的XQR17V16芯片。地面上使用時,通過JTAG接口,ISE軟件將生成的.mcs文件燒錄到FLASH芯片,用于地面上開展FPGA程序測試,包括PID控制算法、FIR數(shù)字濾波算法、靜電懸浮加速度計高壓懸浮測試以及裝星電測等,產(chǎn)品正式交付出廠時,再將測試無誤的FPGA程序落焊到PROM芯片。
另外基于靜電懸浮加速度計的工作特性以及空間環(huán)境的復雜性,在靜電懸浮加速度計電路設計中,需要著重考慮加速度計控制器中DSP芯片和FPGA芯片的供電和軟件監(jiān)控以及相應的復位邏輯。在該加速度計控制器中,DSP和FPGA芯片均采用中電58所生產(chǎn)的看門狗芯片對兩個芯片的上電、掉電進行監(jiān)控,確保當芯片的電源電壓達到一定閾值才進行復位,同時當電源電壓下降到一定閾值時,同樣也輸出低電平復位信號。如圖3和圖4所示分別為DSP復位監(jiān)控電路和FPGA復位監(jiān)控電路原理圖,在圖3中J1為DSP復位斷開接口,用于DSP軟件地面分步調(diào)試,在圖4中JP1為FPGA軟件手動復位接口,用于對FPGA軟件進行手動復位。
1) 試驗時間及地點。試驗于2016年4-9月在貴州省安順市西秀區(qū)山京畜牧場煙草根結(jié)線蟲病發(fā)病嚴重的連作煙地進行。土壤類型為黃砂壤,土壤肥力中等,烤煙種植品種為K326,2016年4月25日采用“井窖式”小苗移栽。
圖3 DSP復位監(jiān)控電路原理圖Fig.3 Schematic diagram of DSP reset monitoring circuit
圖4 FPGA復位監(jiān)控電路原理圖Fig.4 Schematic diagram of FPGA reset monitoring circuit
從圖3和圖4可以看出,整個系統(tǒng)中,不僅包括看門狗芯片1、看門狗芯片2對DSP芯片和FPGA芯片的電源的監(jiān)控,同時DSP軟件運行時,在大于0.3s,小于1s的時間間隔內(nèi),向看門狗芯片1周期性的發(fā)送喂狗信號,若超過1.6s,看門狗芯片1未收到DSP發(fā)送的喂狗信號,則輸出低電平復位信號。同時FPGA芯片對看門狗芯片1的復位信號進行監(jiān)測,當一定周期內(nèi)檢測到看門狗芯片1持續(xù)對DSP進行復位(5s內(nèi)連續(xù)復位3次)時,則認為DSP的軟件存在一定的BUG,需要配置DSP芯片的加載方式從FLASH切換到PROM啟動。DSP還可以通過對FPGA中啟動方式寄存器的設置,配置DSP在復位之后,從FLASH或PROM啟動,配置DSP從FLASH或者PROM啟動,其中看門狗復位信號的檢測優(yōu)先級高于啟動方式寄存器的檢測。
為了使DSP和FPGA兩者運行同步,當DSP軟件在上電或者復位完成后,DSP軟件在XF1接口置為低電平并保持超過6s時間,等待FPGA配置信息加載完成后,在XF1接口上輸出一個脈沖寬度大于1us的高電平脈沖,對FPGA內(nèi)部邏輯進行復位,脈沖輸出后,XF1接口應該保持低電平。如圖5所示為加速度計控制器復位邏輯框圖。
圖5 加速度計控制器復位邏輯框圖Fig.5 Accecerometer controller reset Logic Block Diagram
在復位操作期間,一方面需要對系統(tǒng)的1553B通信進行復位操作,還需要對DSP的中斷進行操作,防止DSP啟動期間,中斷有效導致DSP啟動失敗。
靜電懸浮加速度計控制器的軟件設計主要包括DSP軟件和FPGA軟件,根據(jù)前文DSP功能和FPGA功能描述,對DSP軟件來說,除工作模式切換控制以外,其余的功能均為通用的控制功能,對FPGA軟件來說,除基本的ADC、DAC時序控制以及其它的邏輯控制功能外,還需要承擔靜電懸浮加速度計控制器中PID控制算法和FIR數(shù)字濾波算法的實現(xiàn)。下面對DSP工作模式切換控制邏輯以及FPGA的PID控制算法和FIR數(shù)字濾波算法的實現(xiàn)進行描述。
在靜電懸浮加速度計中,根據(jù)工作環(huán)境以及測量狀態(tài)的不同,將其工作模式分為捕獲模式、大量程模式以及小量程模式,其中捕獲模式主要用于實現(xiàn)檢驗質(zhì)量的在軌捕獲控制,其位移檢測范圍和加速度測量范圍較大,但分辨率較低,所以主要應用于加速度計上電初始狀態(tài)時的檢驗質(zhì)量捕獲控制和較大擾動情況下的檢驗質(zhì)量捕獲控制。大量程模式和小量程模式則為測量模式,兩種測量模式的加速度測量范圍不同,因此測量分辨率也不同。上述三種工作模式的軟硬件工作流程和時序是完全一致的,但正弦檢測電壓、驅(qū)動增益以及PID控制參數(shù)則存在區(qū)別,所以加速度計控制器需要根據(jù)工作模式切換邏輯,對正弦檢測電壓的幅值、驅(qū)動放大電路的增益以及PID參數(shù)進行切換,從而實現(xiàn)加速度計正常工作和科學測量。三種工作模式之間的轉(zhuǎn)換邏輯如圖6所示,根據(jù)任務需求的不同,分為手動干預狀態(tài)和自動切換狀態(tài),其中T1~T3為自動切換時需要滿足的條件,主要包括持續(xù)時間、位移檢測輸出電壓閾值以及PID控制輸出電壓閾值,若其中一個通道的位移檢測電壓大于2.4V時,則自動進入到捕獲模式,若6個通道的位移檢測電壓均小于2V時,則進入到大量程測量模式,若6個通道PID控制電壓均小于0.5V時,則表明此時檢驗質(zhì)量所受的擾動加速度較小,則自動切換到小量程測量模式,進行高分辨率測量。L1、L2為手動干預三種工作模式的進入和退出條件,其中L1為捕獲模式和小量程模式的進入條件,L2為大量程模式的進入條件。在圖6中工作模式的切換只是適用于某衛(wèi)星平臺的切換邏輯,根據(jù)衛(wèi)星平臺、所處軌道以及任務需求的不同,需要專門制定加速度計工作模式切換邏輯,主要原則就是在加速度計正常工作的同時滿足衛(wèi)星測控需求。
圖6 工作模式切換邏輯框圖Fig.6 Operation mode switching logic block diagram
靜電懸浮加速度計PID控制算法主要是確保在不同的工作狀態(tài)時,控制檢驗質(zhì)量位于加速度計電極籠的中心位置,通過調(diào)整比例、微分、積分三個方面的參數(shù)來達到最佳的系統(tǒng)響應和控制效果,PID控制的基本方程如式(1)所列:
(1)
(2)
u(k)=u(k-1)+kp[e(k)-e(k-1)]+kie(k)+
kd[e(k)-2e(k-1)+e(k-2)]
(3)
整理后:
u(k)=u(k-1)+k0e(k)…+
k1e(k-1)+k2e(k-2)
(4)
其中:k0=kp+ki+kd,k1=kp-2kd,k2=2kd。
根據(jù)公式(1-3),得到PID控制算法的FPGA實現(xiàn)邏輯如圖7所示:
圖7 PID控制算法FPGA實現(xiàn)邏輯框圖Fig.7 PID control algorithm FPGA implementation logic block diagram
圖7為本文采用的PID控制算法結(jié)構(gòu)相同,該結(jié)構(gòu)為并行結(jié)構(gòu),在FPGA設計中,相當于以面積換取速度,擁有較快的運算速度,非常適合于加速度計這種對響應速度要求較高的系統(tǒng)。從圖7的控制算法框圖,可以得到公式(5),其主要是由四個加法器和三個乘法器組成,可以重復利用IP核進行實現(xiàn),降低了設計的難度。
(5)
式(5)中:r(k)標識設定值,y(k)標識實際值,p0~p2、s1~s2為暫存變量。
FIR數(shù)字濾波算法的實現(xiàn)如式(6)所列,FIR數(shù)字濾波主要是對科學讀出數(shù)據(jù)進行數(shù)字濾波處理,其中x(n)為輸入信號,h(n)為FIR數(shù)字濾波系數(shù),y(n)為經(jīng)過濾波后的信號;N表示FIR濾波器的抽頭個數(shù),濾波階數(shù)為N-1[12]。
(6)
根據(jù)靜電懸浮加速度計加速度測量頻帶的范圍,采樣率為1kHz,濾波器的通帶設置為0Hz~1Hz,過渡帶為1Hz~80Hz,通帶衰減為0.01dB,阻帶衰減為60dB。由上述參數(shù),應用MATLAB中的數(shù)字濾波器設計工具箱,采用等波紋的設計方法,得到一個最小階數(shù)為43階(N=44)的FIR濾波器[13-14],數(shù)字濾波器的幅值響應曲線如圖8所示。
圖8 FIR數(shù)字濾波器幅值響應Fig.8 FIR digital filter magnitude response
FIR數(shù)字濾波器在FPGA中的實現(xiàn)結(jié)果如下,主要包括延遲單元Z-1、乘法器和累加器組成,此結(jié)構(gòu)為直接型FIR數(shù)字濾波器結(jié)構(gòu),也稱作橫向結(jié)構(gòu)[15-16]。如圖9所示。
圖9 FIR數(shù)字濾波器結(jié)構(gòu)Fig.9 FIR digital filter structure
以上對靜電懸浮加速度計控制器中幾項關(guān)鍵的控制算法進行了描述,工作模式切換由DSP負責實現(xiàn),采用C語言編程設計,PID控制算法和FIR數(shù)字濾波算法則由FPGA實現(xiàn),采用Verilog語言設計,具體的實現(xiàn)代碼不再贅述。
基于上述對靜電懸浮加速度計控制器的設計,整個控制器的設計包括硬件設計以及軟件設計,在硬件設計中主要是主控芯片電路的設計、各個存儲外設電路的設計以及系統(tǒng)硬件復位電路設計。軟件設計則主要是基本控制接口的實現(xiàn)以及加速度計工作模式切換邏輯、PID控制算法以及FIR數(shù)字濾波器的實現(xiàn)。其中存儲外設的訪問、系統(tǒng)復位以及加速度計工作模式的切換邏輯,在本文的實驗結(jié)果中,不再贅述,其主要是時序邏輯和組合邏輯的實現(xiàn),在加速度計地面軟件測試和在軌工作中,均可以有效實現(xiàn)系統(tǒng)的復位以及工作模式的切換,其中工作模式的切換是由DSP軟件實現(xiàn),再由FPGA的I/O接口控制開關(guān)三極管,驅(qū)動繼電器的切換,進而完成對偏置電壓以及驅(qū)動增益的切換。
PID控制算法的驗證需要通過加速度計地面高壓懸浮實驗進行驗證。加速度計地面高壓懸浮實驗是通過在檢驗質(zhì)量的豎直方向上施加近千伏的高壓,抵消檢驗質(zhì)量所受的地面重力,采用微位移臺,進行地面重力傾角標定。豎直方向的高壓會將檢驗質(zhì)量一直控制在電極籠的中心位置,水平方向的PID計算結(jié)果則可以用來表征此時水平方向上檢驗質(zhì)量所受的加速度。如圖10所示為加速度計中PID控制算法實驗測試結(jié)果,圖中黑色曲線為Z1通道的位移檢測曲線,紅色曲線為Z1通道加速度讀出曲線(即加速度計驅(qū)動電壓),藍色曲線則為Z1通道實際PID控制器的輸出曲線,從實驗結(jié)果可以看出,施加在檢驗質(zhì)量上的驅(qū)動電壓,即放大以及濾波后的PID控制器輸出電壓,會隨著檢驗質(zhì)量上某一個方向重力分量的變化而變化,而此時檢驗質(zhì)量則始終位于電極籠的中心位置,說明當檢驗質(zhì)量的姿態(tài)或者受力情況發(fā)生變化時,PID控制算法可以實時調(diào)整加載在電極板上的驅(qū)動電壓,進而將檢驗質(zhì)量控制在電極籠的中心。如圖10所示紅色曲線和藍色曲線的階梯是由于階梯調(diào)整水平方向的重力分量而產(chǎn)生的。本文采用的數(shù)字PID具有參數(shù)易更新,算法易迭代,可以滿足多種工況下加速度計測控需求,可以通過地面測控站對6個通道的PID控制參數(shù)進行更新,相比于濾波算法的驗證是將FIR數(shù)字濾波器的系數(shù)導入到Origin9.0軟件里面,在Origin9.0軟件里面對上位機采集的數(shù)據(jù)進行數(shù)字濾波,從而得到經(jīng)過數(shù)字濾波的數(shù)據(jù)。
圖10 PID控制算法實際測試結(jié)果Fig.10 PID control algorithm actual test results
如圖11所示為FIR數(shù)字濾波算法實驗驗證結(jié)果,是基于加速度計Y通道的位移檢測數(shù)據(jù)進行驗證的,其中黑色曲線為Y通道未經(jīng)數(shù)字濾波的數(shù)據(jù),紅色曲線為濾波后的曲線,數(shù)字濾波器的通頻帶為0Hz~1Hz,從圖11中可以看出,該數(shù)字濾波器會大幅衰減頻率高于1Hz的信號和噪聲,從而減小高頻噪聲對低頻信號的影響,進一步提高加速度測量的分辨率和動態(tài)范圍。
圖11 FIR數(shù)字濾波算法測試結(jié)果Fig.11 FIR digital filtering algorithm test results
本文設計了一種基于DSP和FPGA的靜電懸浮加速度計控制器,可用于對空間用靜電懸浮加速度計的控制,實現(xiàn)衛(wèi)星在軌測控任務的需求,包括采用靜電懸浮加速度計進行太陽光壓的測量、衛(wèi)星軌道轉(zhuǎn)移以及微推力器標定測試等精密測控任務?;贒SP和FPGA架構(gòu)設計的系統(tǒng)復位邏輯,可以實現(xiàn)雙芯片架構(gòu)的系統(tǒng)復位,使二者同步工作。另外根據(jù)任務需求以及加速度計作為測量設備的工作特性,設計開發(fā)的工作模式切換(或量程切換)可以確保加速度計在軌正常工作,且實現(xiàn)不同應用場景下分辨率可調(diào)。在該控制器中,為DSP和FPGA主控芯片設計了豐富了外設資源,可以滿足靜電懸浮加速度計地面高壓懸浮標定測試以及開展程序在軌重構(gòu)和控制參數(shù)的在軌上注。開展靜電懸浮加速度計控制器的研究和設計,一方面可以為未來開展空間引力波探測等任務積累重要的工程經(jīng)驗,同時也可以為類似科學探測任務提供設計參考。