jacobi 迭代法與gauss-seidel迭代法算法比較_第1頁(yè)
已閱讀1頁(yè),還剩9頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論