版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 題 目:高斯-賽德爾迭代法的算法及程序設(shè)計</p><p><b> 摘要</b></p><p> 本文通過理論與實例對線性方程組的解法、收斂性及誤差分析進(jìn)行了探討.在對線性方程組數(shù)值解法的討論下用到了高斯-賽德爾迭代法,進(jìn)一步研究和總結(jié)了高斯-賽德爾迭代法的理論與應(yīng)用,使我們在分析問題與編輯程序時能更好的把握對高斯-賽德爾迭代法的應(yīng)用
2、。</p><p> 關(guān)鍵詞 Gauss-Seidel迭代法;收斂性;誤差分析;流程圖;Mathematica編程 </p><p><b> 目錄</b></p><p> 第一章 高斯-賽德爾迭代法1</p><p> §1.1 高斯-賽德爾迭代法的提出1</p><p>
3、; §1.1.1 高斯-賽德爾迭代法的思想理論1</p><p> §1.1.2 高斯-賽德爾迭代法的定義及表達(dá)形式2</p><p> §1.2 高斯-賽德爾迭代法的收斂性1</p><p> §1.3 高斯-賽德爾迭代法的誤差分析1</p><p> 第二章 高斯-賽德爾迭代法的程
4、序設(shè)計..................................... 1</p><p> §2.1 高斯-賽德爾迭代法在上機中的應(yīng)用1</p><p> §2.1.1 高斯-賽德爾迭代法的流程圖1</p><p> §2.1.2 高斯-賽德爾迭代法的源程序1</p><p><b&
5、gt; 參考文獻(xiàn)22</b></p><p><b> 附錄23</b></p><p><b> 高斯-賽德爾迭代法</b></p><p><b> 考慮線性方程組</b></p><p> 其中為非奇異矩陣,對于由工程技術(shù)中產(chǎn)生的大型稀疏矩陣方程
6、組(的階數(shù)很大但零元素很多),利用迭代法求解線性方程組是合適的.在計算機內(nèi)存和運算兩方面,迭代法通常都可利用中有大量零元素的特點.</p><p> 本章將介紹迭代法中的高斯-賽德爾法的思想理論、收斂性及誤差分析.</p><p> §1.1 高斯-賽德爾迭代法的提出</p><p> §1.1.1 高斯-賽德爾迭代法的思想理論</p
7、><p> 在研究雅可比迭代法時,計算時,已得(這些分別為的第k+1次近似),Gauss-Seidel迭代法認(rèn)為在計算時啟用新值,從而產(chǎn)生</p><p><b> .</b></p><p><b> 具體原理如下圖所示</b></p><p> 圖1.1 基本迭代原理</p>
8、<p> §1.1.2 高斯-賽德爾迭代法的定義及表達(dá)形式</p><p> 定義1.1 我們注意到在雅可比迭代法中并沒有對新算出的分量,,,</p><p> 進(jìn)行充分利用.不妨設(shè)想,在迭代收斂的條件下,我們把</p><p> 式中第一個方程算出的立即投入到第二個方程中,代替進(jìn)行計算,當(dāng)算出后代替馬上投入到第三個方程中計算,依次進(jìn)行下
9、去,這樣也許會得到更好的收斂效果.根據(jù)這種思路建立的一種新的迭代格式,我們稱為高斯-賽德爾(Gauss-Seidel)迭代公式,</p><p> 高斯=賽德爾迭代法的分量形式:</p><p> 高斯-賽德爾迭代法的矩陣形式:</p><p><b> 其中</b></p><p><b> ,<
10、;/b></p><p> 稱為高斯-賽德爾迭代矩陣,稱為高斯-賽德爾迭代常量..</p><p> §1.2 高斯-賽德爾迭代法的收斂性</p><p> 根據(jù)上節(jié)所述,高斯-賽德爾迭代法的迭代格式為</p><p><b> ?。?-1)</b></p><p><
11、b> 其中</b></p><p> , . 本節(jié)要討論的問題就是任意選取初始值,利用迭代格式(1-1)得到的向量序列是否一定收斂,如果收斂的話需要滿足什么條件?</p><p> 下面我們給出一般迭代收斂的條件:</p><p> 定理1.2 簡單迭代法(1-1)收斂的充分必要條件是迭代矩陣的譜半徑.</p>&l
12、t;p> 定理1.3 若迭代矩陣的某種范數(shù)則(1-2-1)確定的迭代法對任意初值均收斂于方程組的唯一解。</p><p> 特殊線性方程組迭代法的收斂性定理:</p><p> 定理1.4 設(shè)對于方程組,若系數(shù)矩陣是嚴(yán)格對角占優(yōu)矩陣,則</p><p><b> (1)非奇異. </b></p><p>
13、?。?)Gauss-Seidel迭代法收斂.</p><p> 定理1.5 若系數(shù)矩陣對稱正定,則Gauss-Seidel迭代公式收斂.</p><p> 例1.1 已知方程組</p><p><b> ,</b></p><p> 用Gauss-Seidel迭代法解此方程組的收斂性.</p>&l
14、t;p><b> 方程組的系數(shù)矩陣</b></p><p><b> ,</b></p><p><b> 所以有</b></p><p><b> ,,</b></p><p><b> =</b></p>
15、;<p><b> ,</b></p><p><b> 得</b></p><p> 故,因此Gauss-Seidel迭代法不收斂.</p><p> §1.3 高斯-賽德爾迭代法的誤差分析</p><p> 科學(xué)計算的主要過程是:對給定的實際問題建立數(shù)學(xué)模型,通
16、過已獲得的有關(guān)基本數(shù)據(jù),建立近似數(shù)值方法,設(shè)計算法編制程序,最后上機進(jìn)行數(shù)值計算得到數(shù)值結(jié)果.其大致過程如下圖:</p><p> 圖1.2 誤差分析表</p><p> 定義1.2 假設(shè)某一量的標(biāo)準(zhǔn)值為近似解為,則與之差叫做近似解的絕對誤差(簡稱誤差),記為,即</p><p> 定義1.3 絕對誤差與準(zhǔn)確值之比</p><p>&l
17、t;b> 稱為的相對誤差.</b></p><p> 定理1.6 設(shè)是方程組的同解方程的準(zhǔn)確解,若迭代公式中迭代矩陣的某種范數(shù),則有</p><p><b> 1)</b></p><p><b> 2)</b></p><p> 第二章 高斯-賽德爾迭代法的程序設(shè)計&l
18、t;/p><p> 第二章 高斯-賽德爾迭代法的程序設(shè)計20世紀(jì)50年代是用數(shù)字計算機求解電力系統(tǒng)潮流問題的開始階段,人們普通采用以節(jié)點導(dǎo)納矩陣為基礎(chǔ)的高斯-賽德爾迭代法.此方法原理簡單,占用內(nèi)存量較小,編程容易實現(xiàn),特別是對于配網(wǎng)潮流有其獨特優(yōu)勢.但是此算法也有著其致命缺點那就是收斂速度比較慢,尤其是隨著電力系統(tǒng)的發(fā)展。網(wǎng)絡(luò)中的節(jié)點增多,這個問題將會更加突出.</p><p> 本章將
19、研究高斯-賽德爾迭代法的流程圖及程序應(yīng)用.</p><p> §2.1 高斯-賽德爾迭代法在上機中的應(yīng)用</p><p> §2.1.1 高斯-賽德爾迭代法的流程圖</p><p> 在實際應(yīng)用中,有時需解決的問題中運算很復(fù)雜且運算量也很大,這時我們就需要借助計算機的幫助解決實際問題,即利用高斯-賽德爾迭代法在C語言中的編程實現(xiàn).高斯-賽德
20、爾迭代法在計算機中的主要實現(xiàn)過程如下圖所示</p><p> 圖2.3 高斯-賽德爾迭代法流程圖</p><p> §2.1.2高斯-賽德爾迭代法在計算機中的應(yīng)用</p><p> 在C語言環(huán)境中解線性方程組的問題需要進(jìn)行程序編輯,如果解決每一個線性方程組都需要重新編輯程序,就沒體現(xiàn)計算機語言的簡便性,所以需要一個程序使其對大多數(shù)問題都適用.<
21、/p><p> 例2.1 設(shè)方程組的系數(shù)矩陣的對角線元素,為迭代次數(shù)容許的最大值,為容許誤差。</p><p> 1 取初始向量令k=0.</p><p> 2 對i=1,2,…,n計算 </p><p> 3 如果則輸出結(jié)束;否則執(zhí)行4</p><p> 4 如果則不收斂,終止程序;否則,轉(zhuǎn)2</p&g
22、t;<p><b> 源程序:</b></p><p> #include <stdio.h></p><p> #include <math.h></p><p> #define N 600</p><p> void main()</p><p&g
23、t;<b> {</b></p><p><b> int i;</b></p><p> double x[4];</p><p> double c[4][5]={10,-1,2,0,-11,0,8,-1,3,-11,2,-1,10,0,6,-1,3,-1,11,25};</p><p>
24、; void GaussSeidel(double *,int,double[]);</p><p> GaussSeidel(c[0],4,x);</p><p> for(i=0;i<=3;i++)</p><p> printf("x[%d]=%f\n",i,x[i]);}</p><p> void
25、 GaussSeidel(double *a,int n,double x[])</p><p><b> {</b></p><p> int i,j,k=1;</p><p> double d,dx,eps;</p><p> for(i=0;i<=3;i++)</p><p>
26、;<b> while(1)</b></p><p><b> {eps=0;</b></p><p> for(i=0;i<=3;i++)</p><p><b> {</b></p><p><b> d=0;</b></p>
27、;<p> for(j=0;j<=4;j++)</p><p><b> {</b></p><p> if(j==i)continue;</p><p> d+=*(a+i*(n+1)+j)*x[j];</p><p><b> }</b></p>&l
28、t;p> dx=(*(a+i*(n+1)+n)-d)/(*(a+i*(n+1)+i));</p><p> eps+=fabs(dx-x[i]);</p><p><b> x[i]=dx;</b></p><p><b> }</b></p><p> if(eps<1e-6
29、)</p><p> {printf("迭代次數(shù)是:%d\n",k);return;}</p><p><b> if(k>N)</b></p><p><b> {</b></p><p> printf("迭代發(fā)散n\n");</p&g
30、t;<p><b> return;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> 輸出結(jié)果</b><
31、/p><p><b> 結(jié)果分析:</b></p><p> 從輸出結(jié)果可以看出此方程組的迭代次數(shù)為1,此時能得到精確結(jié)果是</p><p> x[0]=-1.467391,x [1]=-2.358696,x[2] =0.657609,x[3] =2.842391</p><p> 從結(jié)果和原有知識可以知道其系數(shù)矩陣
32、是嚴(yán)格對角占優(yōu)的。所以此迭代解法有很好的收斂性.</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 賀俐、陳桂興.計算方法[M].武漢水利電力大學(xué)出版社.1998-8-1</p><p> [2] 袁慰平等.計算方法與實習(xí)[M].東南大學(xué)出版社.2000-7-1</p><p> [3] 徐士
33、良.數(shù)值方法與計算機實現(xiàn)[M].清華大學(xué)出版社.2006-2-1</p><p> [4] 李炳釗.數(shù)值分析基礎(chǔ)[M].上海:同濟大學(xué)出版,1998. </p><p> [5] 張光澄. 實用數(shù)值分析[M].四川:四川大學(xué)出版,2004. </p><p> [6] 劉春鳳.應(yīng)用數(shù)值分析[M].北京: 冶金工業(yè)出版社,2005</p><
34、p><b> 附錄 C語言編程</b></p><p><b> 源程序</b></p><p> #include <stdio.h></p><p> #include <string.h></p><p> #include <math.h>
35、;</p><p> #include <stdlib.h></p><p> #define N 3</p><p><b> main()</b></p><p><b> {</b></p><p> int i,j,k,s;</p>
36、<p> float a[N][N]={0},L[N][N]={0},U[N][N]={0},sigma1,sigma2;</p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> L[i][i]=1;</p><p><b> }&
37、lt;/b></p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> printf("請輸入矩陣第%d行元素:\n",i+1);</p><p> for(j=0;j<N;j++)</p><p>
38、 scanf("%f",&a[i][j]);</p><p><b> }</b></p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> U[0][i]=a[0][i];</p><p
39、> L[i][0]=a[i][0]/U[0][0];</p><p><b> }</b></p><p> for(k=1;k<N;k++)</p><p><b> {</b></p><p> for(j=k;j<N;j++)</p><p>
40、;<b> {</b></p><p><b> sigma1=0;</b></p><p> for(s=0;s<=k-1;s++)</p><p> sigma1+=L[k][s]*U[s][j];</p><p> U[k][j]=a[k][j]-sigma1;</p&g
41、t;<p><b> }</b></p><p> for(i=k;i<N;i++)</p><p><b> {</b></p><p><b> sigma2=0;</b></p><p> for(s=0;s<=k-1;s++)<
42、/p><p> sigma2+=L[i][s]*U[s][k];</p><p> L[i][k]=(a[i][k]-sigma2)/U[k][k];</p><p><b> }</b></p><p><b> }</b></p><p> printf("
43、;a矩陣為:\n");</p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> for(j=0;j<N;j++)</p><p> printf("%5.1f ",a[i][j]);</p><p&g
44、t; printf("\n");</p><p><b> }</b></p><p> printf("L矩陣為:\n");</p><p> for(i=0;i<N;i++)</p><p><b> {</b></p>&l
45、t;p> for(j=0;j<N;j++)</p><p> printf("%5.1f ",L[i][j]);</p><p> printf("\n");</p><p><b> }</b></p><p> printf("U矩陣為:\n&q
46、uot;);</p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> for(j=0;j<N;j++)</p><p> printf("%5.1f ",U[i][j]);</p><p> printf
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 高斯—賽德爾迭代法課程設(shè)計
- 高斯—賽德爾迭代法課程設(shè)計
- 高斯—賽德爾迭代法課程設(shè)計.doc
- 125趙連云-雅可比迭代法和高斯—塞德爾迭代法比較
- 數(shù)值分析課程設(shè)計--newton_迭代法
- 數(shù)值分析課程設(shè)計-- 松弛迭代法中松弛因子
- 課程設(shè)計---hermite 插值法的程序設(shè)計及應(yīng)用
- jacobi 迭代法與gauss-seidel迭代法算法比較
- 課程設(shè)計--unix程序設(shè)計課程設(shè)計
- 算法課程設(shè)計---中文分詞程序設(shè)計與實現(xiàn)
- 程序設(shè)計與算法語言課程設(shè)計
- 程序設(shè)計課程設(shè)計報告
- 程序設(shè)計課程設(shè)計報告
- 關(guān)于Z-矩陣的修正不完全高斯—塞德爾迭代法譜半徑的單調(diào)性.pdf
- matlab程序設(shè)計 課程設(shè)計
- java課程設(shè)計---java程序設(shè)計
- matlab程序設(shè)計 課程設(shè)計 (2)
- 程序設(shè)計課程設(shè)計--鏈表操作
- 《java程序設(shè)計》課程設(shè)計報告
- 【課程設(shè)計】面向?qū)ο蟪绦蛟O(shè)計
評論
0/150
提交評論