- 相關推薦
非線性方程組的求解
非線性方程組的求解
摘要:非線性方程組求解是數學教學中,數值分析課程的一個重要組成部分,作為一門學科,其研究對象是非線性方程組。求解非線性方程組主要有兩種方法:一種是傳統的數學方法,如牛頓法、梯度法、共軛方向法、混沌法、BFGS法、單純形法等。傳統數值方法的優點是計算精度高,缺點是對初始迭代值具有敏感性,同時傳統數值方法還會遇到計算函數的導數和矩陣求逆的問題,對于某些導數不存在或是導數難求的方程,傳統數值方法具有一定局限性。另一種方法是進化算法,如遺傳算法、粒子群算法、人工魚群算法、差分進化算法等。進化算法的優點是對函數本身沒有要求,不需求導,計算速度快,但是精度不高。 關鍵字:非線性方程組、牛頓法、BFGS法、記憶梯度法、Memetic算法
1: 三種牛頓法:Newton 法、簡化Newton 法、修改的Newton 法【1-3】 求解非線性方程組的Newton 法是一個最基本而且十分重要的方法, 目前使用的很多有效的迭代法都是以Newton 法為基礎, 或由它派生而來。 n 個變量n 個方程的非線性方程組, 其一般形式如下:
?f1(x1,x2,...xn)?0?f(x,x,...x)?0?212n??...
??fn(x1,x2,...xn)?0 (1)
式(1)中,fi(x1,x2,...xn)( i=1, ?, n) 是定義在n 維Euclid空間Rn中開域 D上 的實值函數。若用向量記號,令:
?f1(x1,x2,...xn)?0??f1(X)??x1?????x??f(X)f(x,x,..x)?022212n???? X???,F(X)???...??...?...????????xf(X)f(x,x,...x)?0??n???n?n12??n
則方程組(1)也可表示為:
F(X)?0 (2)
其中:X?Rn,F∶Rn→R0, F(X) ∈Rn, Rn為賦值空間。一般地, 若在包含的某鄰域
D 內, 按某種近似意義,用線性函數:
lk(X)?AkX?bk (3)
近似地代替向量值函數F(X),此處Ak 是n 階矩陣,則可將線性方程組:
lk(X)?AkX?bk (4)
的解作為非線性方程組( 2) 的近似解。
1.1 Newton法[1]
Newton法的迭代公式為:
?Xk?1?Xk??Xkk?0,1,2,... (5)??F'(Xk)(?Xk)?-F(Xk)
其中?Xk?Xk?1-Xk.
1.2 簡化Newton 法[1]
盡管Newton 法具有較高的收斂速度,但在每一步迭代中,要計算n 個函數值f,以及n2個導數值f′形成Jacobi矩陣f'(Xk),而且要求f'(Xk)的逆陣或者解一個n 階線性方程組,計算量很大。為了減少計算量,在上述Newton 法中對一切k=0,1,2,...,取f'(Xk)為f'(X.),于是迭代公式修改為:
Xk?1?Xk??f'(Xk)?f(Xk),k?0,1,2... (6) ?1
式( 5) 即為簡化的Newton 法。該方法能使計算量大為減少,但卻大大降低了收斂速度。簡化的Newton 法的算法與Newton 法的算法區別就在于只由給定的初始近似值計算一次f'(X),以后在每一次迭代過程中不再計算f'(Xk),保持初始計算值。
1.3 修正的Newton 法
吸取Newton 法收斂快與簡化的Newton 法工作量省的優點,文獻【2】把m 步簡化的Newton 步合并成一次Newton 步。則可以得到下列迭代程序: [2]
Xk,0?Xk???1Xk,j?Xk,j?f'(Xk)f(Xk,j?1)? (7)
?Xk?1?Xk,m?
式中: j=1, 2, ?, m, k=0, 1, 2, ?, 該式稱為修正的Newton 法。
通過分析Newton 法、簡化的Newton 法和修正Newton 法的原理, 并通過對算例的分析比較,我們可知: Newton 法(5)式具有較高的收斂速度,但計算量大,在每一步迭代中,要計算n個函數值f,以及n2個導數值f'形成Jacobi 矩陣
而且要求f'(Xk)的逆陣或者解一個n 階線性方程組;簡化的Newton 法f'(Xk) ,
( 6) 式,它用迭代初值X0來計算f'(Xk),并在每個迭代步中保持不變,它能使每步迭代過程的計算量大為減少,但大大降低了收斂速度。修正Newton法(7)與Newton法(5)相比,在每步迭代過程中增加計算n個函數值,并不增加求逆次數,然而收斂速度提高了。
2: BFGS法【4-6】
非線性方程組一般形式為:方程組(1)將其轉化為一個全局優化問題。構造能量函數:?(X)求非線性方程組解的問題就轉化為??fi2(X),X?(x1,x2,...xn)
i?1n
求解能量函數極小值的問題。即給定一個充分小的實常數?,搜索
***使得?(X*)??則X*即是非線性方程組(1)對應的近似解。 X*?(x1,x2,...xn)
2.1 BFGS查分算法【4】
文獻【4】將傳統的BFGS算法和查分算法有機融合,用來求解非線性方程組,效果顯著,可以較為廣泛地應用于非線性方程組的求解。BFGS方法是由Broyden、
Fletcher、Goldfarb和Shanno 等人在1970年提出的。它是一個擬牛頓方法,具有二次終止性、整體收斂性和超線性收斂性,且算法所產生的搜索方向是共軛的。BFGS方法是一個有效的局部算法,用來求解極小值的。
例如方程組
?f1(x1,x2,...xn)?A1?f(x,x,...x)?A?212n2??...
??fn(x1,x2,...xn)?An (8)
可將它夠著適應度函數
F(X)??|fi(x)?Ai|
i?1n (9)
那么求非線性方程組(8)的根問題就轉化成了求適應度函數F(X) 最小值的優化問題。這就是它最基本的思想。
DE算法(差分進化算法)(文獻【5】)具有良好的全局搜索能力,并具有對初始值、參數選擇不敏感、魯棒性強、原理簡單、容易操作等優點,是一種較好的全局優化方法。但在優化后期DE算法的收斂速度明顯變慢,而且搜索結果僅獲得滿意解域而不是精確解。為了克服這些缺點,該文在DE算法的進化后期階段引入BFGS方法,利用BFGS 方法的整體收斂性和超收斂性來加快收斂速度。BFGS方法屬于局部算法,其優化結果的優劣在很大程度上取決于初始值的選取,為此可以利用具有全局搜索能力的DE算法提供給BFGS方法良好的初始值。
2.2 改進的BFGS 變尺度法【4】
對于高維的大型問題(維數大于100),變尺度法由于收斂快、效果好,被認為是最好的優化方法之一。其中BFGS 法的數值穩定性較好,是最成功的一種變尺度法。BFGS法中有2個非常關鍵的環節:求函數的偏導數和一維探索。這2個環
節的算法精度對最后結果的精度影響很大。
2.2.1 改進的遺傳算法【7】
遺傳算法的優越性主要表現在:算法具有固有的并行性,通過對種群的遺傳處理可處理大量的模式,并且容易并行實現。
(a) 選擇復制操作
采用保優操作與比例復制相結合, 即最優秀的個體被無條件保留下來,其余的以正比于個體適配值的概率來選擇相應的個體。
(b) 交叉操作
采用保優操作與算數交叉結合,即最優秀的個體被無條件保留下來,其余的以交叉概率進行算數交叉。算數交叉的方式為:
(10) X1??X1?(1??)X2,X2??X2?(1??)X1
式中??(0,1);X1,X2為父代個體;X1,X2為后代個體。
(c)變異操作
采用保優操作與擾動變異結合,即最優秀的個體被無條件保留下來,其余的以變異概率進行擾動變異。擾動變異的方式為X'?X???。式中?為滿足正態分布的隨機擾動;?為尺度參數; X為父代個體; X'為后代個體。
2.3 混合優化【7】
改進的BFGS 方法是一種非常有效而且收斂速度很快的局部搜索算法,而改進的遺傳算法實現并行搜索,有非常強的全局搜索的能力。文獻【7】將2種方法混合起來,實現了并行與串行,全局與局部的融合,極大地提高了優化性能、優化效率和魯棒性.。尤其對于高維復雜函數效果非常好。
混合法的步驟為:
(1)給定算法參數,初始化種群。(2)評價當前種群中各個體。(3)判斷算法收斂準則是否滿足。若滿足則輸出搜索結果,否則轉(4)。(4)執行改進的遺傳算法的選擇復制操作。(5)執行改進的遺傳算法的交叉操作。(6)執行改進的遺傳算法的變異操作。(7)以當前種群中各個個體作為改進的BFGS方法的初始解,分別用改進的BFGS方法進行搜索得到新的個體,將這些新的個體組成新的種群,轉
(2)。
3: 記憶梯度法[8-10]
考慮非線性方程組
(11) F(x)?0,x?Rn ,
其中F:Rn?Rn是非線性映射。
定義F(x)?(F1(x),F2(x),...F(xn))T,其雅可比矩陣J(X)。記憶梯度法(文獻【8-9】)是求解無約束優化問題非常有效的方法,該方法在每步迭代時不需計算和存儲矩陣,結構簡單,因而適于求解大型優化問題。
算法的基本思想是: 首先將非線性方程組問題(12)轉化為一個無約束極小化問題
minf(x),x?Rn, (12) 其中f(x)?1F(x)22。 這里采用二范數,然后利用記憶梯度法求解問題(13)。因為f( x) ≥ 0。所以如果x* 是無約束優化問題(12)的最優解,那么x* 必是非線性方程組(11) 的近似最優解。設f(X)的梯度為g(x),則g(x)=▽f(x)=J(x)F(x).求解無約束優化問題的記憶梯度法應用于求解非線性方程組,給出了一類新的求解非線性方程組的記憶梯度算法,并分析了算法的全局收斂性。該算法無需求雅克比矩陣的逆矩陣,
所以具有更廣泛的應用性。此外,算法在迭代過程中也無需每一步都計算F(X) 的雅克比矩陣,大大減少了算法的計算量,節省了運算時間。與牛頓法相比,記憶梯度法更適于求解大規模非線性方程組。
4: 基于Memetic算法的非線性方程組求解算法【11-12】
Memetic 算法是建立在模擬文化進化基礎上的優化算法,它實質上是一種基于種群的全局搜索和基于個體的局部啟發式搜索的結合體。Memetic 算法流程和GA 有很大的相似。其關鍵區別是Memetic算法在交叉和變異后多了一個局部搜索優化的過程。針對函數優化問題,傳統的遺傳算法雖然能夠全局尋優,但是它很容易早熟。對于傳統的局部搜索算法,它一個初始解開始,在其鄰域中搜尋比其更好的解,它可以快速求出較優解,其不足主要是只有當迭代初值在真實解附近時,其較快的局部搜索性能才能得以發揮。Memetic 算法充分吸收了遺傳算法和傳統局部搜索算法的優點,采用遺傳算法的操作流程,但是在每次交叉和變異后進行局部搜索,通過優化種群分布及早剔除不良種群,進而減少迭代次數,在Memetic算法的設計過程中各個參數的選擇策略對算法求解結果具有重要的影響。
仍然以方程組(1)為例,現在定義:
f(x)??f
i?1n2i(X) (13)
則求解方程組( 1) 等價于求解這樣一個極值優化問題: 若在方程組( 1) 的解空間內找到一組X?[X1,X2,...Xn],使得式(13)達到最小值則此時的X?[X1,X2,...Xn] 就是方程組( 1) 的解。
總結文獻【11】的算法大致思路:先初始化種群,看其是否滿足停止準則,是的話顯示結果,算法結束。否則的話,進行以下步驟:(1)適應度評價與選擇。
(2)染色體多點交叉。(3)擬牛頓局部搜索。(4)染色體隨機變異。(5)擬牛頓局部搜索。返回看是否滿足停止準則,滿足顯示結果,不滿足繼續循環。
Memetic算法充分發揮了Memetic算法大范圍搜索全局解的特點以及擬牛頓算子局部細致搜索的特點,對非單調多峰函數組成的非線性方程組,求到解的概率顯著高于擬牛頓法和GA,實驗表明基于Memetic算法求解非線性方程組具有較高的收斂可靠性和較高的精度。
綜上,非線性方程組求解是實際工程領域的一個重要問題,在數值天氣預報、石油地質勘探、計算生物化學、控制領域和軌道設計等方面均有較強的應用背景。從實際應用角度出發,有必要探索高效可靠的算法去求解,可以解決我們生活中的很多問題。
參考文獻
[1]謝世坤,段芳,李強征,羅志揚,鄭慧.非線性方程組求解的三種Newton法比較
[J].井岡山學院學報( 自然科學),2006,27(8):8-11.
[2]余芝云,陳爭,馬昌鳳.求解對稱非線性方程組基于信賴域的修正牛頓法[J].福建師范大學學報( 自然科學版),2010,26(1):22-27.
[3]Li D H,Cheng W Y. Recent progress in the global convergence of quasi-Newton methods for nonlinear equations[J]. Hokkaido Math J,2007, 36 ( 2) : 729-743.
[4]劉利斌,歐陽艾嘉,許衛明,李肯立.求解非線性方程組的BFGS差分進化算法
[J].2011,47(33):55-58.
[5]周麗,姜長生.非線性方程組求解的一種新方法[J].小型微型計算機系統,2008,9:1709-1713.
[6]張飛飛,馬群,黃家慶,佟曉君.求解非線性方程組的二分法[J].科技創新導報,2009,08(c):146-149.
[7]李濤,劉華偉,陳耀元.非線性方程組求解的新方法[J].武漢理工大學學報(交通科學與工程版),2009,33(3):569-572.
[8]李敏,蘇醒,時貞.求解非線性方程組的記憶梯度算法[J]. 工程數學學報,2009,26(3):563-566.
[9]Shi Z J. A new super-memory gradient method for unconstrained optimization[J]. Advances in Mathematics,2006,3( 35) : 265-273.
[10]陳長憶,葉永春.基于粒子群算法的非線性方程組求解[J].計算機應用與軟件,2006,23(5):137-139.
[11]屈愛平,李敏.MEMETIC算法在非線性方程組求解中的應用[J].湖南文理學院學 報(自然科學版),2009,21(4):13-15.
[12]Sudholt D.The impact of parametrization in memetic evolutionary algorithms[J] .Theoretical Computer Science, 2009, 26(410) : 2 511-2528.
。
【非線性方程組的求解】相關文章:
沿等壓路徑求解疏松材料Hugoniot關系的微分方程組及其求解04-26
求解非線性級數擬合問題的新模式搜索方法05-01
基于神經網絡的病態線性方程組求解04-30
奇異非線性邊界流耦合熱方程組的熄滅速率04-29
求解非線性動力系統周期解的改進打靶法05-01
解非線性方程組的神經網絡方法05-02
應用非線性規劃求解異面最優軌道轉移問題05-01