雅克比迭代算法(Jacobi Iterative Methods) -- [ mpi , c++]

雅克比迭代,通常用來對線性方程組,進行求解。形如:
\(a_{11}*x_{1} + a_{12}*x_{2} + a_{13}*x_{3} = b_{1}\)  
\(a_{21}*x_{1} + a_{22}*x_{2} + a_{23}*x_{3} = b_{2}\)  
\(a_{31}*x_{1} + a_{32}*x_{2} + a_{33}*x_{3} = b_{3}\)  
咱們須要求解出\(x_{1}\) ,\(x_{2}\) ,\(x_{3}\),咱們對這組方程進行變換:
\(x_{1}=\frac{1}{a_{11}}(b_{1} -a_{12}*x_{2} -a_{13}*x_{3})\)
  \(x_{2}=\frac{1}{a_{21}}(b_{2} -a_{21}*x_{1} -a_{23}*x_{3})\)
\(x_{3}=\frac{1}{a_{31}}(b_{3} -a_{31}*x_{1}-a_{32}*x_{2})\)spa

咱們不妨假設 \(x_{0}^{0}=(X_{1}^{0},X_{2}^{0},X_{3}^{0})\) ,當咱們代入上述公式的時候,咱們就會獲得一組新的 \(x_{0}^{1}=(X_{1}^{1},X_{2}^{1},X_{3}^{1})\) ,此刻咱們稱之爲一次迭代.
而後咱們將獲得的X1,X2,X3再次代入公式,咱們將會獲得第二次迭代, 當咱們重複這種迭代的時候,咱們會獲得第K次迭代:
\(x^{k}=(X_{1}^{k},X_{2}^{k},X_{3}^{k})\) , \(k = 1,2,3...n\)
咱們將其概括成通常式子:
3d

eg: 對於方程組:

求解:
咱們先將其變形:

而後,咱們假設:
並將其代入獲得:

咱們將獲得的X1,x2,x3再次代入方程中,反覆迭代,將會獲得以下:

最終咱們將會獲得一個收斂值,該組值,就是咱們獲得的解(會很是的逼近真實解)blog

那麼這種方法,也能夠用來求解矩陣:
對於方程: Ax =b ; 咱們設定 A矩陣爲: ,b矩陣爲: , x矩陣爲:
到這裏,每一個人都有本身的解法,直接的解法是將 x = \(A^{-1}\)b,可是A的逆矩陣\(A^{-1}\),計算較爲複雜,咱們這裏須要一點小的tricks ,咱們將A矩陣拆分紅爲一個對角矩陣D,下三角矩陣L,上三角矩陣U,即

這樣的話,公式 Ax = b 就變成了 ( D - L -U )
x = b ,而後咱們就能夠獲得:
Dx = b + (L+U)x ,當咱們獲得這個公式的時候,求解D的逆矩陣就容易了不少,咱們獲得D的逆矩陣爲:get

而後,咱們將D移到右邊變成:
class

這個公式,和咱們上面描述的雅克比迭代是否是長得很像,而後咱們能夠將其通常化爲:
pdf

咱們知道A是一個已知的常量矩陣,於是D,L,U都是已知矩陣,那麼咱們能夠簡化爲:
\(T = D^{-1}*( L +U)\) , \(c = D^{-1}*b\) ;
方法

根據這一個思想,咱們能夠獲得一個僞代碼:
im

實現代碼爲:d3

參考資料爲:
https://www3.nd.edu/~zxu2/acms40390F12/Lec-7.3.pdfcms

相關文章
相關標籤/搜索