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

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論