版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> Jacobi 迭代法與Gauss-Seidel迭代法算法比較</p><p><b> 目錄</b></p><p><b> 1 引言1</b></p><p> 1.1 Jacobi迭代法2</p><p> 1.2 Gauss-Seidel迭代法2</
2、p><p> 1.3 逐次超松弛(SOR)迭代法3</p><p><b> 2算法分析3</b></p><p><b> 3 結(jié)論5</b></p><p><b> 4 附錄程序5</b></p><p><b> 參考文獻(xiàn)
3、8</b></p><p> Jacobi 迭代法與Gauss-Seidel迭代法比較</p><p><b> 1 引言 </b></p><p> 解線(xiàn)性方程組的方法分為直接法和迭代法,直接法是在沒(méi)有舍入誤差的假設(shè)下,能在預(yù)定的運(yùn)算次數(shù)內(nèi)求得精確解,而迭代法是構(gòu)造一定的遞推格式,產(chǎn)生逼近精確值的序列。這兩種方法各有優(yōu)缺點(diǎn)
4、,直接法普遍適用,但要求計(jì)算機(jī)有較大的存儲(chǔ)量,迭代法要求的存儲(chǔ)量較小,但必須在收斂性得以保證的情況下才能使用。對(duì)于高階方程組,如一些偏微分方程數(shù)值求解中出現(xiàn)的方程組,采用直接法計(jì)算代價(jià)比較高,迭代法則簡(jiǎn)單又實(shí)用,所以比較受工程人員青睞。</p><p> 迭代法求解方程組就是構(gòu)造一個(gè)無(wú)限的向量序列,使它的極限是方程組的解向量。即使計(jì)算機(jī)過(guò)程是精確的,迭代法也不能通過(guò)有限次算術(shù)運(yùn)算求得方程組的精確解,而只能逐步逼
5、近它。因此迭代法存在收斂性與精度控制的問(wèn)題。</p><p> 迭代法是常用于求解大型稀疏線(xiàn)性方程組(系數(shù)矩陣階數(shù)較高且0元素較多),特別是某些偏微分方程離散化后得到的大型稀疏方程組的重要方法。設(shè)n元線(xiàn)性微分方程組</p><p> (1) </p><p> 的系數(shù)矩陣A非奇異,右端向量,因而方程組有唯一的非
6、零解向量。而對(duì)于這種線(xiàn)性方程組的近似解,前輩們發(fā)展研究了許多種有效的方法,有Jacobi迭代法、Gauss—Seidel迭代法,逐次超松弛迭代法(SOR法),這幾種迭代方法均屬一階線(xiàn)性定常迭代法,即若系數(shù)矩陣A分解成兩個(gè)矩陣N和P的差,即;其中N為可逆矩陣,線(xiàn)性方程組(1)化為:</p><p> 可得到迭代方法的一般公式:</p><p><b> ?。?)</b>
7、;</p><p> 其中:,,對(duì)任取一向量作為方程組的初始近似解,按遞推公式產(chǎn)生一個(gè)向量序列,,...,,...,當(dāng)足夠大時(shí),此序列就可以作為線(xiàn)性方程組的近似解。</p><p> 一階定常迭代法收斂的充分必要條件是: 迭代矩陣G的譜半徑小于1,即;又因?yàn)閷?duì)于任何矩陣范數(shù)恒有‖G‖,故又可得到收斂的一個(gè)充分條件為:‖G‖< 1。</p><p> 1.
8、1 Jacobi迭代法</p><p> 若D為A的對(duì)角素構(gòu)成的對(duì)角矩陣,且對(duì)角線(xiàn)元素全不為零。可以將系數(shù)矩陣A分解為: </p><p> 其中,D為系數(shù)矩陣A的對(duì)角元素構(gòu)成的對(duì)角陣,L為嚴(yán)格下三角陣,U為嚴(yán)格上三角陣。在迭代法一般形式中,取,,形成新的迭代公式</p><p><b> ,
9、</b></p><p> 其中任取,則Jacobi迭代的迭代公式為:</p><p><b> (3)</b></p><p> 式中: ; , 稱(chēng)為Jacobi迭代矩陣. 其計(jì)算公式為: </p><p> , (4)</p><p> 如果迭代矩陣的譜半
10、徑,則對(duì)于任意迭代初值,Jacobi迭代法收斂;如果‖GJ‖<1,則Jacobi迭代法收斂;如果方程組的系數(shù)矩陣是主對(duì)角線(xiàn)按行或按列嚴(yán)格占優(yōu)陣,則用Jacobi迭代法求解線(xiàn)性方程組必收斂。</p><p> 1.2 Gauss-Seidel迭代法</p><p> 從Jacobi迭代可以看出,用計(jì)算時(shí),需要同時(shí)保留這兩個(gè)向量。事實(shí)上如果每次獲得的分量能夠在計(jì)算下一個(gè)分量時(shí)及時(shí)更新
11、的話(huà),既節(jié)省了存儲(chǔ)單元,又能使迭代加速,這就是Gauss-Seidel方法。對(duì)于非奇異方程組,若D為A的對(duì)角素構(gòu)成的對(duì)角矩陣,且對(duì)角線(xiàn)元素全不為零;系數(shù)矩陣A的一個(gè)分解:</p><p><b> (5)</b></p><p> 在迭代法一般形式中,取,,形成新的迭代公式</p><p><b> ,</b><
12、;/p><p> 其中任取,則Gauss-Seidel迭代法的迭代公式為: (6)</p><p> 上式中: 是其右端常數(shù)項(xiàng);為Gauss-Seidel迭代法的迭代矩陣,其計(jì)算公式為:</p><p> , (7)</p><p> 若GS法收斂的充分必要條件是;如果‖GG‖<1,則GS法收斂;如
13、果線(xiàn)性方程組的系數(shù)矩陣A為主對(duì)角線(xiàn)按行或按列嚴(yán)格占優(yōu)陣,或者為正定矩陣,則對(duì)于任意初值用GS法求解必收斂。</p><p> 1.3 逐次超松弛(SOR)迭代法</p><p> 一般而言,因Jacobi迭代收斂速度不夠快,所以在工程中用的并不是太多。并且在Jacobi迭代收斂速度很慢的情況下,通常Gauss-Seidel迭代法也不會(huì)太快。可以對(duì)Gauss-Seidel迭代公式做適度修
14、改,提高收斂速度,這就是逐次超松弛迭代法。</p><p> 設(shè)線(xiàn)性方程組的系數(shù)矩陣A滿(mǎn)足,??蓪⑾禂?shù)矩陣A分解為</p><p><b> (8)</b></p><p> 其中實(shí)常數(shù)>0稱(chēng)為松弛因子。在迭代法一般形式中,取</p><p><b> , </b></p>
15、<p><b> 得到迭代公式 </b></p><p><b> , (9)</b></p><p> 其中任取。這就是逐次超松弛迭代法,當(dāng)=1時(shí)該式就是高斯法。SOR法迭代矩陣是</p><p> 整理后得到SOR迭代法的實(shí)際計(jì)算公式為:</p><p><b&
16、gt; ;(10)</b></p><p> SOR方法收斂的充分必要條件是;如果‖GS‖<1,則SOR方法收斂;SOR方法收斂的必要條件是;如果方程組的系數(shù)矩陣A是主對(duì)角線(xiàn)按行或者列嚴(yán)格占優(yōu)陣,則用的SOR方法求解必收斂;如果方程組的系數(shù)矩陣是正定矩陣,則用的SOR方法求解必收斂。</p><p><b> 2 算法分析</b></p&
17、gt;<p> 用雅可比迭代法求解下列方程組</p><p> 解 將方程組按雅可比方法寫(xiě)成</p><p><b> 取初始值按迭代公式</b></p><p> 進(jìn)行迭代,其計(jì)算結(jié)果如表1所示 。</p><p><b> 表1</b></p><
18、p> 例2 用高斯——塞德?tīng)柕ㄇ蠼饫?.</p><p> 解 取初始值,按迭代公式</p><p> 進(jìn)行迭代,其計(jì)算結(jié)果如下表2</p><p><b> 表2</b></p><p><b> 3 結(jié)論</b></p><p> 使用Ga
19、uss-Seidel迭代法迭代法,7次就可以求出方程的解,收斂速度要比Jacobi迭代法收斂快(達(dá)到同樣的精度所需迭代次數(shù)少);但是這個(gè)結(jié)論,在一定條件下才是對(duì)的,甚至有這樣的方程組,雅可比方法收斂,而高斯—塞德?tīng)柕▍s是發(fā)散的.</p><p><b> 4 附錄程序</b></p><p> /* 求解線(xiàn)性方程組--Gauss-Seidel迭代法 */<
20、;/p><p> #include <iostream></p><p> #include <cmath></p><p> using namespace std;</p><p> /* 二維數(shù)組動(dòng)態(tài)分配模板 */</p><p> template <class T>&
21、lt;/p><p> T** Allocation2D(int m, int n)</p><p><b> {</b></p><p><b> T **a;</b></p><p> a = new T*[m];</p><p> for (int i=0; i&l
22、t;m; i++)</p><p><b> {</b></p><p> a[i] = new T[n];</p><p><b> }</b></p><p><b> return a;</b></p><p><b> }&l
23、t;/b></p><p> /* 一維數(shù)組動(dòng)態(tài)分配模板 */</p><p> template <class T></p><p> T* Allocation1D(int n)</p><p><b> {</b></p><p><b> T *a;&
24、lt;/b></p><p> a = new T[n];</p><p><b> return a;</b></p><p><b> }</b></p><p> /* 求矩陣的一范數(shù) */</p><p> float matrix_category(
25、float* x, int n)</p><p><b> {</b></p><p> float temp = 0;</p><p> for(int i=0; i<n; i++)</p><p><b> {</b></p><p> temp = te
26、mp + fabs(x[i]);</p><p><b> }</b></p><p> return temp;</p><p><b> }</b></p><p> int main()</p><p><b> {</b></p&
27、gt;<p> const int MAX = 1000; // 最大迭代次數(shù)</p><p> int i,j,k; // 循環(huán)變量</p><p> int n; // 矩陣階數(shù)</p><p> float** a; // 增廣矩陣</p>&
28、lt;p> float* x_0; // 初始向量</p><p> float* x_k; // 迭代向量</p><p> float precision; // 精度</p><p> cout<<"輸入精度e:";</p><p>
29、 cin>>precision;</p><p> /* 動(dòng)態(tài)生成增廣矩陣 */</p><p> cout<<endl<<"輸入系數(shù)矩陣的階數(shù),N:";</p><p><b> cin>>n;</b></p><p> a = Allocat
30、ion2D<float>(n, n+1);</p><p> /* 輸入增廣矩陣的各值 */</p><p> cout<<endl<<"輸入增廣矩陣的各值:\n";</p><p> for(i=0; i<n; i++)</p><p><b> {</b
31、></p><p> for(j=0; j<n+1; j++)</p><p><b> {</b></p><p> cin>>a[i][j];</p><p><b> }</b></p><p><b> }</b>
32、;</p><p> /* 生成并初始化初始向量 */</p><p> x_0 = Allocation1D<float>(n);</p><p> cout<<endl<<"輸入初始向量:\n";</p><p> for(i=0; i<n; i++)</p>
33、;<p><b> {</b></p><p> cin>>x_0[i];</p><p><b> }</b></p><p> /* 生成迭代向量 */</p><p> x_k = Allocation1D<float>(n);</p>
34、;<p> float temp;</p><p> /* 迭代過(guò)程 */</p><p> for(k=0; k<MAX; k++)</p><p><b> {</b></p><p> for(i=0; i<n; i++)</p><p><b>
35、; {</b></p><p><b> temp = 0;</b></p><p> for(j=0; j<i; j++)</p><p><b> {</b></p><p> temp = temp + a[i][j] * x_k[j];</p>&l
36、t;p><b> }</b></p><p> x_k[i] = a[i][n] - temp;</p><p><b> temp = 0;</b></p><p> for(j=i+1; j<n; j++)</p><p><b> {</b><
37、/p><p> temp = temp + a[i][j] * x_0[j];</p><p><b> }</b></p><p> x_k[i] = (x_k[i] - temp) / a[i][i];</p><p><b> }</b></p><p> /*
38、求兩解向量的差的范數(shù) */</p><p> for(i=0; i<n; i++)</p><p><b> {</b></p><p> x_0[i] = x_k[i] - x_0[i];</p><p><b> }</b></p><p> if(mat
39、rix_category(x_0,n) < precision)</p><p><b> {</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> else</b></
40、p><p><b> {</b></p><p> for(i=0; i<n; i++)</p><p><b> {</b></p><p> x_0[i] = x_k[i];</p><p><b> }</b></p>&
41、lt;p><b> }</b></p><p><b> }</b></p><p> /* 輸出過(guò)程 */</p><p> if(MAX == k)</p><p><b> {</b></p><p> cout<<&
42、quot;迭代不收斂\n";</p><p><b> }</b></p><p> cout<<"迭代次數(shù)為:"<<k<<endl;</p><p> cout<<"解向量為:\n";</p><p> for(i
43、=0; i<n; i++)</p><p><b> {</b></p><p> cout<<"x"<<i<<": "<<x_k[i]<<endl;</p><p><b> }</b></p>
44、<p><b> return 0;</b></p><p><b> }</b></p><p><b> 參考文獻(xiàn)</b></p><p> [1]顏慶津. 數(shù)值分析[M]. 北京:航空航天大學(xué)出版社,1999.</p><p> [2]黎建玲,簡(jiǎn)金寶,
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 預(yù)條件Gauss-Seidel迭代法的收斂性分析.pdf
- 牛頓迭代法
- 牛頓迭代法分法
- 125趙連云-雅可比迭代法和高斯—塞德?tīng)柕ū容^
- 分法牛頓迭代法
- Jacobi和擬Jacobi梯度迭代法求解Sylvester矩陣方程.pdf
- 重力迭代法計(jì)算 最新.xls
- 重力迭代法計(jì)算 最新.xls
- 嚴(yán)格對(duì)角占優(yōu)l-矩陣的預(yù)條件jacobi迭代法
- 廣義交替二級(jí)迭代法和GAOR迭代法的收斂性分析.pdf
- 預(yù)條件迭代法和并行交替二級(jí)迭代法的收斂性分析.pdf
- 變分迭代法的若干研究.pdf
- 波概念迭代法的研究與應(yīng)用.pdf
- 簡(jiǎn)化的牛頓迭代法的matlab實(shí)現(xiàn)
- 廣義交替迭代法和Schur余研究.pdf
- 擴(kuò)散方程高階格式的分組迭代法.pdf
- 高斯—賽德?tīng)柕ㄕn程設(shè)計(jì)
- 第五講方程的近似根與迭代法
- 求解奇異問(wèn)題若干迭代法的研究.pdf
- 求解非線(xiàn)性方程的高階迭代法
評(píng)論
0/150
提交評(píng)論