原智杰,張公平,崔 茅,唐 煒*
(1.西北工業(yè)大學(xué) 自動(dòng)化學(xué)院,西安 710129;2.中國(guó)空空導(dǎo)彈研究院,河南 洛陽(yáng) 471009;3.航空制導(dǎo)武器航空科技重點(diǎn)實(shí)驗(yàn)室,河南 洛陽(yáng) 471009)
導(dǎo)彈結(jié)構(gòu)的優(yōu)化是指根據(jù)導(dǎo)彈的氣動(dòng)性能以及設(shè)定的預(yù)期目標(biāo)設(shè)計(jì)導(dǎo)彈的氣動(dòng)布局,即對(duì)導(dǎo)彈的幾何外形參數(shù)進(jìn)行調(diào)整,確定導(dǎo)彈機(jī)械結(jié)構(gòu)中各個(gè)氣動(dòng)部件(彈頭、彈身、彈翼和舵面等)的形狀、尺寸以及安裝位置的工作過(guò)程[1]。導(dǎo)彈氣動(dòng)性能的優(yōu)良則反映出導(dǎo)彈的氣動(dòng)布局是否合理,是否需要進(jìn)一步優(yōu)化,而導(dǎo)彈飛行時(shí)的各種氣動(dòng)參數(shù)能直接反映出導(dǎo)彈的氣動(dòng)性能。傳統(tǒng)的直接獲取導(dǎo)彈氣動(dòng)參數(shù)的方法主要有三種[2]:理論計(jì)算法、風(fēng)洞試驗(yàn)法、飛行試驗(yàn)法。理論計(jì)算法過(guò)程復(fù)雜,風(fēng)洞試驗(yàn)法和飛行試驗(yàn)法存在過(guò)程費(fèi)用極其昂貴、測(cè)試周期長(zhǎng)等缺點(diǎn)[3-8]。
人工神經(jīng)網(wǎng)絡(luò)技術(shù)被應(yīng)用于模式識(shí)別、函數(shù)擬合、聚類問題等,飛行器氣動(dòng)參數(shù)辨識(shí)也成為其應(yīng)用的一個(gè)領(lǐng)域。1993年,Linse D J和Youssef H M等人相繼將神經(jīng)網(wǎng)絡(luò)理論與氣動(dòng)力參數(shù)的辨識(shí)問題相結(jié)合,應(yīng)用于氣動(dòng)參數(shù)的估計(jì)[9-10]。2000年,Richardson K A建立了基于徑向基函數(shù)的氣動(dòng)參數(shù)模型[11]。2011年,美國(guó)奧本大學(xué)教授Carpenter M等人提出了一種利用單隱含層神經(jīng)網(wǎng)絡(luò)進(jìn)行導(dǎo)彈氣動(dòng)參數(shù)預(yù)測(cè)的方法[12]。2016年,Carpenter M等人又提出了一種利用神經(jīng)網(wǎng)絡(luò)與雷達(dá)遙測(cè)系統(tǒng)相結(jié)合的快速識(shí)別導(dǎo)彈類型的方案[13]。張瑞民等人基于BP神經(jīng)網(wǎng)絡(luò)建立了飛機(jī)在大攻角狀態(tài)下的氣動(dòng)模型[14]。史志偉等人討論了基于徑向基函數(shù)神經(jīng)網(wǎng)絡(luò)的非線性非定常氣動(dòng)模型[15]。王博斌等人基于RBF神經(jīng)網(wǎng)絡(luò)模型展開研究,對(duì)翼面不同振幅下的頻域氣動(dòng)特性進(jìn)行預(yù)測(cè)[16]。朱莉等人采用BP神經(jīng)網(wǎng)絡(luò)對(duì)翼型進(jìn)行氣動(dòng)力建模,提出了一種翼型優(yōu)化設(shè)計(jì)方法[17]。
傳統(tǒng)的工程擬合法氣動(dòng)建模是根據(jù)氣動(dòng)力的物理特性、統(tǒng)計(jì)規(guī)律等,利用數(shù)學(xué)方法獲得氣動(dòng)力與飛行狀態(tài)、氣動(dòng)外形等參數(shù)之間的數(shù)學(xué)關(guān)系式,其適用于狀態(tài)范圍變化較小的局部氣動(dòng)建模。對(duì)于狀態(tài)參數(shù)變化范圍較大,且氣動(dòng)外形復(fù)雜的飛行器,氣動(dòng)力與狀態(tài)參數(shù)以及其他參數(shù)間的關(guān)系呈現(xiàn)高度非線性,傳統(tǒng)的數(shù)學(xué)建模方法很難給出準(zhǔn)確描述;而神經(jīng)網(wǎng)絡(luò)氣動(dòng)建模過(guò)程不需要考慮輸入輸出之間非線性程度,通過(guò)大量氣動(dòng)力數(shù)據(jù)的機(jī)器學(xué)習(xí),建立氣動(dòng)模型,具有良好的學(xué)習(xí)能力及非線性擬合能力,是處理非線性函數(shù)逼近的有效方法。
本文利用導(dǎo)彈DATCOM軟件計(jì)算已知外形幾何參數(shù)的導(dǎo)彈在設(shè)定的飛行條件下對(duì)應(yīng)的氣動(dòng)系數(shù),將幾何參數(shù)、飛行條件參數(shù)及氣動(dòng)系數(shù)作為研究數(shù)據(jù),基于BP神經(jīng)網(wǎng)絡(luò)建立氣動(dòng)模型,并驗(yàn)證利用該模型進(jìn)行氣動(dòng)參數(shù)預(yù)測(cè)的可行性。用神經(jīng)網(wǎng)絡(luò)氣動(dòng)模型獲取氣動(dòng)參數(shù)的方法較傳統(tǒng)方法節(jié)省了風(fēng)洞試驗(yàn)和飛行試驗(yàn)昂貴的試驗(yàn)費(fèi)用與時(shí)間成本,這在導(dǎo)彈研發(fā)過(guò)程中有著極為重要的意義。
氣動(dòng)模型是表征飛行器氣動(dòng)力/力矩與飛行狀態(tài)、氣動(dòng)外形等參數(shù)之間關(guān)系的函數(shù)。通??梢员硎緸?/p>
Ci=f(H,Ma,α,β,ωx,ωy,ωz,δe,δr,δa,…)
(1)
式中:H,Ma,α,β分別為高度、馬赫數(shù)、攻角、側(cè)滑角;ωx,ωy,ωz分別為滾轉(zhuǎn)、偏航和俯仰角速度;δe,δr,δa分別為升降舵、方向舵和副翼舵偏角。本文以Ci(i=N,M,A,Y,L,D)表示的氣動(dòng)力/力矩系數(shù),反映導(dǎo)彈的氣動(dòng)特性。
BP神經(jīng)網(wǎng)絡(luò)(Back Propagation Neural Network)是一種基于誤差反向傳播的神經(jīng)網(wǎng)絡(luò),其算法的核心部分是BP算法,由輸入信號(hào)的前向傳播和誤差的反向傳播組成了BP神經(jīng)網(wǎng)絡(luò)的整個(gè)學(xué)習(xí)過(guò)程。根據(jù)反向傳播的誤差信號(hào)對(duì)神經(jīng)網(wǎng)絡(luò)的閾值和權(quán)值進(jìn)行調(diào)整,神經(jīng)網(wǎng)絡(luò)訓(xùn)練結(jié)束的標(biāo)志,是誤差信號(hào)達(dá)到設(shè)定的訓(xùn)練目標(biāo)或者迭代次數(shù)達(dá)到設(shè)定值。BP神經(jīng)網(wǎng)絡(luò)雖然具有能夠逼近任意非線性函數(shù)的優(yōu)勢(shì),但也有一些缺陷制約其發(fā)展:收斂速度慢、易陷入局部最小、網(wǎng)絡(luò)的一些參數(shù)確定方法不定等[18]。
思維進(jìn)化算法(Mind Evolutionary Algorithm)是一種將計(jì)算機(jī)科學(xué)和生物進(jìn)化結(jié)合的一種隨機(jī)搜索算法,其基本思路為初始種群按照一定規(guī)則生成,并從中選擇出更適應(yīng)環(huán)境的個(gè)體組成優(yōu)勝群體;由選擇出的優(yōu)勝群體進(jìn)行個(gè)體的生成,產(chǎn)生更多的子群體;在生成的子群體內(nèi)部執(zhí)行操作過(guò)程中的趨同操作,直到子群體中的個(gè)體發(fā)展至成熟階段,同時(shí)記錄此時(shí)各群體具體的得分信息;在執(zhí)行趨同操作后,子群體中的個(gè)體均發(fā)展成熟,記錄的具體得分信息被不斷公布在公告板上,通過(guò)得分信息的對(duì)比,得到最優(yōu)的群體即得到問題的最優(yōu)解[19]。
利用思維進(jìn)化算法對(duì)BP神經(jīng)網(wǎng)絡(luò)的初始權(quán)值和閾值進(jìn)行優(yōu)化。首先,根據(jù)BP神經(jīng)網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu),將解空間映射到編碼空間,每個(gè)編碼對(duì)應(yīng)問題的一個(gè)解(即個(gè)體)。根據(jù)BP神經(jīng)網(wǎng)絡(luò)拓?fù)浣Y(jié)構(gòu)確定編碼長(zhǎng)度。然后,選取訓(xùn)練集的均方誤差的倒數(shù)作為各個(gè)個(gè)體與種群的得分函數(shù),利用思維進(jìn)化算法,經(jīng)過(guò)不斷迭代,輸出最優(yōu)個(gè)體,并以此作為初始權(quán)值和閾值,訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)。
根據(jù)上述設(shè)計(jì)思路,設(shè)計(jì)步驟如圖1所示。
圖1 設(shè)計(jì)步驟流程圖Fig.1 Flow chart of design steps
(1) 訓(xùn)練集/測(cè)試集導(dǎo)入
將神經(jīng)網(wǎng)絡(luò)的訓(xùn)練數(shù)據(jù)及驗(yàn)證數(shù)據(jù)導(dǎo)入工作空間。
(2) 初始種群產(chǎn)生
利用編寫好的初始種群產(chǎn)生函數(shù)以及子種群產(chǎn)生函數(shù)生成進(jìn)化所需種群。
(3) 子種群趨同操作
利用第(2)步中產(chǎn)生的各個(gè)種群進(jìn)行趨同操作,趨同操作結(jié)束與否由種群成熟判別函數(shù)判斷。
(4) 子種群異化操作
趨同操作完成后進(jìn)行種群的異化操作。
(5) 解析最優(yōu)個(gè)體
算法進(jìn)化過(guò)程結(jié)束后,根據(jù)編碼規(guī)則解析出最優(yōu)個(gè)體所對(duì)應(yīng)的BP神經(jīng)網(wǎng)絡(luò)的權(quán)值和閾值。
(6) 訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)
將算法優(yōu)化得到的權(quán)值和閾值設(shè)定為BP神經(jīng)網(wǎng)絡(luò)的初始權(quán)值和閾值,利用樣本數(shù)據(jù)對(duì)神經(jīng)網(wǎng)絡(luò)進(jìn)行訓(xùn)練。
(7) 仿真預(yù)測(cè)、結(jié)果分析
利用訓(xùn)練好的神經(jīng)網(wǎng)絡(luò)進(jìn)行參數(shù)預(yù)測(cè)。
導(dǎo)彈DATCOM軟件由美國(guó)空軍研究室開發(fā)研究。該軟件在已知飛行器幾何外形和飛行條件的前提下,能計(jì)算導(dǎo)彈縱向和橫向空氣動(dòng)力系數(shù)及導(dǎo)數(shù),具有良好精度。程序采用計(jì)算彈箭氣動(dòng)特性中常用的工程計(jì)算方法——部件組合法,該計(jì)算方法的核心是由理論分析和實(shí)驗(yàn)驗(yàn)證得到大量的經(jīng)驗(yàn)公式。由于充分利用了大量實(shí)驗(yàn)數(shù)據(jù),該方法能夠保證較高精度,滿足方案設(shè)計(jì)階段對(duì)氣動(dòng)力計(jì)算的要求。
本研究所用的樣本數(shù)據(jù)以及驗(yàn)證數(shù)據(jù)均由導(dǎo)彈DATCOM軟件計(jì)算生成。導(dǎo)彈外形為面對(duì)稱外形,如圖2所示。
圖2 導(dǎo)彈幾何結(jié)構(gòu)模型圖Fig.2 Model diagram of missile’s geometric structure
對(duì)導(dǎo)彈彈體幾何參數(shù)、彈翼幾何參數(shù)以及導(dǎo)彈的飛行條件進(jìn)行設(shè)置后,即可計(jì)算出特定彈型在所設(shè)定的飛行條件下的各個(gè)氣動(dòng)系數(shù)。在此,根據(jù)導(dǎo)彈DATCOM軟件中輸入?yún)?shù)間的獨(dú)立性,選取彈頭直徑、彈頭長(zhǎng)度、彈體直徑、彈體長(zhǎng)度、彈體中部彈翼弦長(zhǎng)、攻角6個(gè)相互獨(dú)立的參數(shù)作為神經(jīng)網(wǎng)絡(luò)模型的輸入變量。對(duì)于輸出參數(shù)的選擇,則選取氣動(dòng)性能分析中常用的氣動(dòng)系數(shù),選取法向力系數(shù)、俯仰力矩系數(shù)、軸向力系數(shù)、側(cè)力系數(shù)、升力系數(shù)及阻力系數(shù)6個(gè)氣動(dòng)力/力矩系數(shù)作為神經(jīng)網(wǎng)絡(luò)模型的輸出變量。通過(guò)編寫MATLAB程序調(diào)用導(dǎo)彈DATCOM軟件,利用程序循環(huán)結(jié)構(gòu)不斷改變6個(gè)輸入?yún)?shù)的值,計(jì)算得到導(dǎo)彈不同氣動(dòng)外形對(duì)應(yīng)的氣動(dòng)參數(shù),并將輸入?yún)?shù)及計(jì)算所得的氣動(dòng)參數(shù)保存為數(shù)據(jù)文件,以此方法獲取16 562組不同的外形參數(shù)及攻角值條件下對(duì)應(yīng)的氣動(dòng)參數(shù),將這些數(shù)據(jù)用于神經(jīng)網(wǎng)絡(luò)的訓(xùn)練及神經(jīng)網(wǎng)絡(luò)模型的性能驗(yàn)證。本文所要建立的氣動(dòng)模型正是6個(gè)輸入?yún)?shù)(導(dǎo)彈的幾何參數(shù)和飛行條件參數(shù))與6個(gè)輸出參數(shù)(導(dǎo)彈飛行時(shí)的氣動(dòng)參數(shù))間的復(fù)雜非線性函數(shù)關(guān)系。
根據(jù)1.4節(jié)的建模思路建立神經(jīng)網(wǎng)絡(luò)模型,在模型建立過(guò)程中需要對(duì)一系列參數(shù)進(jìn)行設(shè)置,主要包括設(shè)置BP神經(jīng)網(wǎng)絡(luò)模型的參數(shù)和思維進(jìn)化算法的參數(shù)。
本文以包含單個(gè)隱含層的BP神經(jīng)網(wǎng)絡(luò)為研究對(duì)象,BP神經(jīng)網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)由輸入數(shù)據(jù)與輸出數(shù)據(jù)的維數(shù)決定,由2.1節(jié)中所獲取的數(shù)據(jù)知道神經(jīng)網(wǎng)絡(luò)的輸入層節(jié)點(diǎn)數(shù)為6,輸出層節(jié)點(diǎn)數(shù)為6,隱含層的節(jié)點(diǎn)數(shù)由經(jīng)驗(yàn)公式M=2n+1(M為隱含層節(jié)點(diǎn)數(shù),n為輸入層節(jié)點(diǎn)數(shù))確定,因此隱含層節(jié)點(diǎn)數(shù)為13。所以,最終確定BP神經(jīng)網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)為6-13-6。表1為BP神經(jīng)網(wǎng)絡(luò)參數(shù)設(shè)置。
表1 BP神經(jīng)網(wǎng)絡(luò)參數(shù)Table 1 BP neural network parameters
思維進(jìn)化算法中需要將個(gè)體特征進(jìn)行編碼,在此選擇個(gè)體編碼方法為實(shí)數(shù)編碼法,即將每個(gè)個(gè)體的特征均編碼為一個(gè)實(shí)數(shù)串,該實(shí)數(shù)串包含神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)中各層神經(jīng)元的閾值以及各層之間的連接權(quán)值。當(dāng)神經(jīng)網(wǎng)絡(luò)的結(jié)構(gòu)確定之后,可以將思維進(jìn)化算法進(jìn)化選擇出的最優(yōu)初始權(quán)值、初始閾值賦值給神經(jīng)網(wǎng)絡(luò)中的對(duì)應(yīng)參數(shù),從而得到一個(gè)確定的BP神經(jīng)網(wǎng)絡(luò)。本研究中,由BP神經(jīng)網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)6-13-6可計(jì)算出個(gè)體編碼長(zhǎng)度為S=6×13+13+13×6+6=175。表2為思維進(jìn)化算法參數(shù)設(shè)置。
表2 思維進(jìn)化算法參數(shù)Table 2 Mind evolutionary algorithm parameters
將2.1節(jié)中所獲取的16 562組數(shù)據(jù)作為建模樣本輸入,建立氣動(dòng)模型。同時(shí),將神經(jīng)網(wǎng)絡(luò)模型的氣動(dòng)參數(shù)預(yù)測(cè)輸出與原始?xì)鈩?dòng)參數(shù)進(jìn)行對(duì)比。為了更為明顯地說(shuō)明模型的預(yù)測(cè)結(jié)果,又用導(dǎo)彈DATCOM軟件模擬計(jì)算出某特定尺寸的彈型在不同攻角條件的氣動(dòng)參數(shù),用于驗(yàn)證模型的預(yù)測(cè)能力。
2.3.1 樣本擬合結(jié)果
將神經(jīng)網(wǎng)絡(luò)氣動(dòng)模型對(duì)樣本數(shù)據(jù)的氣動(dòng)參數(shù)預(yù)測(cè)結(jié)果與原始?xì)鈩?dòng)參數(shù)進(jìn)行對(duì)比,對(duì)比結(jié)果如圖3所示。
圖3 氣動(dòng)力和力矩系數(shù)預(yù)測(cè)結(jié)果Fig.3 Prediction results of aerodynamic and moment coefficients
表3為神經(jīng)網(wǎng)絡(luò)模型對(duì)樣本數(shù)據(jù)中氣動(dòng)參數(shù)的預(yù)測(cè)精度情況。
由圖3樣本擬合結(jié)果可見,6個(gè)氣動(dòng)參數(shù)的預(yù)測(cè)輸出曲線與期望輸出曲線的一致性比較好。由表3可見,6個(gè)氣動(dòng)參數(shù)預(yù)測(cè)值中最大平均誤差為0.702 4,最大均方差為0.876 9,最大誤差百分比為5.55%,說(shuō)明建立的神經(jīng)網(wǎng)絡(luò)氣動(dòng)模型能夠較好地?cái)M合氣動(dòng)參數(shù)。
表3 樣本參數(shù)預(yù)測(cè)精度Table 3 Sample parameter prediction accuracy
2.3.2 單個(gè)彈型擬合結(jié)果
將單個(gè)彈型的幾何參數(shù)及攻角作為神經(jīng)網(wǎng)絡(luò)模型的輸入?yún)?shù),神經(jīng)網(wǎng)絡(luò)氣動(dòng)模型的氣動(dòng)參數(shù)預(yù)測(cè)輸出與期望輸出(氣動(dòng)參數(shù)原始值)對(duì)比結(jié)果如圖4所示。
表4為神經(jīng)網(wǎng)絡(luò)模型對(duì)單個(gè)彈型的氣動(dòng)參數(shù)預(yù)測(cè)精度情況。
由圖4中單個(gè)彈型的氣動(dòng)參數(shù)預(yù)測(cè)結(jié)果可見,6個(gè)氣動(dòng)參數(shù)預(yù)測(cè)輸出曲線與期望輸出曲線一致性較好,同時(shí)明顯可見各個(gè)氣動(dòng)參數(shù)隨攻角變化的趨勢(shì),符合氣動(dòng)特性規(guī)律。由表4可見,6個(gè)氣動(dòng)參數(shù)預(yù)測(cè)值中最大平均誤差為0.455 1,最大均方差為0.281 0,最大誤差百分比為6.87%,預(yù)測(cè)精度較好,利用該模型可以對(duì)氣動(dòng)參數(shù)進(jìn)行預(yù)測(cè),用于導(dǎo)彈設(shè)計(jì)初始階段的氣動(dòng)特性分析。
利用導(dǎo)彈DATCOM軟件計(jì)算已知幾何參數(shù)的導(dǎo)彈在設(shè)定飛行條件下的氣動(dòng)參數(shù)作為訓(xùn)練樣本,通過(guò)對(duì)所選取的6個(gè)輸入?yún)?shù)(幾何參數(shù)和飛行條件參數(shù))及6個(gè)輸出參數(shù)(氣動(dòng)參數(shù))進(jìn)行氣動(dòng)力建模,得到了對(duì)應(yīng)的神經(jīng)網(wǎng)絡(luò)氣動(dòng)力模型,并對(duì)模型的預(yù)測(cè)精度進(jìn)行說(shuō)明。通過(guò)建模及分析,得到如下結(jié)論:
(1) 利用神經(jīng)網(wǎng)絡(luò)建立的氣動(dòng)模型對(duì)導(dǎo)彈氣動(dòng)外形與氣動(dòng)參數(shù)間的復(fù)雜非線性關(guān)系具有很好的擬合效果,預(yù)測(cè)結(jié)果的平均誤差、誤差百分比和均方誤差均比較小。
(2) 利用思維進(jìn)化算法優(yōu)化的BP神經(jīng)網(wǎng)絡(luò)建立的氣動(dòng)模型,滿足導(dǎo)彈氣動(dòng)外形與氣動(dòng)參數(shù)間復(fù)雜非線性擬合要求,為導(dǎo)彈氣動(dòng)參數(shù)的獲取開辟了新的思路,同時(shí)也為導(dǎo)彈設(shè)計(jì)初始階段氣動(dòng)特性的分析提供了新的技術(shù)途徑。
(3) 該氣動(dòng)建模方法可快速融合已有的飛行試驗(yàn)數(shù)據(jù)、風(fēng)洞試驗(yàn)數(shù)據(jù),利用導(dǎo)彈DATCOM計(jì)算所得數(shù)據(jù)結(jié)果建立神經(jīng)網(wǎng)絡(luò)模型,對(duì)新的氣動(dòng)外形對(duì)應(yīng)的氣動(dòng)參數(shù)進(jìn)行預(yù)測(cè),可有效節(jié)省風(fēng)洞試驗(yàn)和飛行試驗(yàn)的費(fèi)用。在未來(lái)的研究中將增大訓(xùn)練數(shù)據(jù)的數(shù)量,利用導(dǎo)彈DATCOM計(jì)算時(shí)擴(kuò)大輸入?yún)?shù)類別及其變化范圍,以擴(kuò)大模型的預(yù)測(cè)范圍,直接利用其對(duì)所設(shè)計(jì)彈型的氣動(dòng)參數(shù)進(jìn)行預(yù)測(cè)。