高斯-賽德爾迭代法的算法及程序設(shè)計課程設(shè)計_第1頁
已閱讀1頁,還剩12頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、<p>  題 目:高斯-賽德爾迭代法的算法及程序設(shè)計</p><p><b>  摘要</b></p><p>  本文通過理論與實例對線性方程組的解法、收斂性及誤差分析進行了探討.在對線性方程組數(shù)值解法的討論下用到了高斯-賽德爾迭代法,進一步研究和總結(jié)了高斯-賽德爾迭代法的理論與應用,使我們在分析問題與編輯程序時能更好的把握對高斯-賽德爾迭代法的應用

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 高斯-賽德爾迭代法的定義及表達形式2</p><p>  §1.2 高斯-賽德爾迭代法的收斂性1</p><p>  §1.3 高斯-賽德爾迭代法的誤差分析1</p><p>  第二章 高斯-賽德爾迭代法的程

4、序設(shè)計..................................... 1</p><p>  §2.1 高斯-賽德爾迭代法在上機中的應用1</p><p>  §2.1.1 高斯-賽德爾迭代法的流程圖1</p><p>  §2.1.2 高斯-賽德爾迭代法的源程序1</p><p><b&

5、gt;  參考文獻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迭代法認為在計算時啟用新值,從而產(chǎn)生</p><p><b>  .</b></p><p><b>  具體原理如下圖所示</b></p><p>  圖1.1 基本迭代原理</p>

8、<p>  §1.1.2 高斯-賽德爾迭代法的定義及表達形式</p><p>  定義1.1 我們注意到在雅可比迭代法中并沒有對新算出的分量,,,</p><p>  進行充分利用.不妨設(shè)想,在迭代收斂的條件下,我們把</p><p>  式中第一個方程算出的立即投入到第二個方程中,代替進行計算,當算出后代替馬上投入到第三個方程中計算,依次進行下

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ōu)矩陣,則</p><p><b> ?。?)非奇異. </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>  科學計算的主要過程是:對給定的實際問題建立數(shù)學模型,通

16、過已獲得的有關(guān)基本數(shù)據(jù),建立近似數(shù)值方法,設(shè)計算法編制程序,最后上機進行數(shù)值計算得到數(shù)值結(jié)果.其大致過程如下圖:</p><p>  圖1.2 誤差分析表</p><p>  定義1.2 假設(shè)某一量的標準值為近似解為,則與之差叫做近似解的絕對誤差(簡稱誤差),記為,即</p><p>  定義1.3 絕對誤差與準確值之比</p><p>&l

17、t;b>  稱為的相對誤差.</b></p><p>  定理1.6 設(shè)是方程組的同解方程的準確解,若迭代公式中迭代矩陣的某種范數(shù),則有</p><p><b>  1)</b></p><p><b>  2)</b></p><p>  第二章 高斯-賽德爾迭代法的程序設(shè)計&l

18、t;/p><p>  第二章 高斯-賽德爾迭代法的程序設(shè)計20世紀50年代是用數(shù)字計算機求解電力系統(tǒng)潮流問題的開始階段,人們普通采用以節(jié)點導納矩陣為基礎(chǔ)的高斯-賽德爾迭代法.此方法原理簡單,占用內(nèi)存量較小,編程容易實現(xiàn),特別是對于配網(wǎng)潮流有其獨特優(yōu)勢.但是此算法也有著其致命缺點那就是收斂速度比較慢,尤其是隨著電力系統(tǒng)的發(fā)展。網(wǎng)絡(luò)中的節(jié)點增多,這個問題將會更加突出.</p><p>  本章將

19、研究高斯-賽德爾迭代法的流程圖及程序應用.</p><p>  §2.1 高斯-賽德爾迭代法在上機中的應用</p><p>  §2.1.1 高斯-賽德爾迭代法的流程圖</p><p>  在實際應用中,有時需解決的問題中運算很復雜且運算量也很大,這時我們就需要借助計算機的幫助解決實際問題,即利用高斯-賽德爾迭代法在C語言中的編程實現(xiàn).高斯-賽德

20、爾迭代法在計算機中的主要實現(xiàn)過程如下圖所示</p><p>  圖2.3 高斯-賽德爾迭代法流程圖</p><p>  §2.1.2高斯-賽德爾迭代法在計算機中的應用</p><p>  在C語言環(huá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ōu)的。所以此迭代解法有很好的收斂性.</p><p><b>  參考文獻</b></p><p>  [1] 賀俐、陳桂興.計算方法[M].武漢水利電力大學出版社.1998-8-1</p><p>  [2] 袁慰平等.計算方法與實習[M].東南大學出版社.2000-7-1</p><p>  [3] 徐士

33、良.數(shù)值方法與計算機實現(xiàn)[M].清華大學出版社.2006-2-1</p><p>  [4] 李炳釗.數(shù)值分析基礎(chǔ)[M].上海:同濟大學出版,1998. </p><p>  [5] 張光澄. 實用數(shù)值分析[M].四川:四川大學出版,2004. </p><p>  [6] 劉春鳳.應用數(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)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論