高等數(shù)值分析課程設(shè)計(jì)--求解線性方程組ax=b的極小化方法比較_第1頁(yè)
已閱讀1頁(yè),還剩14頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  課程考核論文</b></p><p>  課程名稱: 高等數(shù)值分析 </p><p>  論文題目: 求解線性方程組Ax=b的極 </p><p>  小化方法比較 </p><p>  姓 名: <

2、/p><p>  學(xué) 號(hào): </p><p>  成 績(jī): </p><p><b>  摘要</b></p><p>  本文對(duì)求解線性方程組Ax=b的極小化方法進(jìn)行了理論上的闡述,并且選取三種具有代表性的方法:最速下降法、共軛梯度法(CG)

3、、預(yù)處理共軛梯度法(PCG),使用Matlab編程并分別求解相同的線性方程組,在準(zhǔn)確性和收斂速度方面進(jìn)行比較。結(jié)果表明,如果預(yù)處理矩陣選擇得當(dāng),使用預(yù)處理共軛梯度法(PCG)效果最好。</p><p><b>  極小化方法</b></p><p>  極小化方法的基本原理是變分原理。</p><p>  設(shè)A對(duì)稱正定,求解的方程組為</

4、p><p><b>  (1.1)</b></p><p>  其中,,??紤]2次函數(shù),定義為</p><p><b>  (1.2)</b></p><p><b>  有如下性質(zhì)</b></p><p><b> ?、?對(duì)一切,</b&g

5、t;</p><p><b>  (1.3)</b></p><p><b>  ⑵ 對(duì)一切,</b></p><p><b>  (1.4)</b></p><p> ?、?設(shè)為(1.1)的解,則</p><p><b>  而且對(duì)一切,有&

6、lt;/b></p><p><b>  (1.5)</b></p><p>  則有定理:設(shè)A對(duì)稱正定,則為(1.1)解的充分必要條件是滿足</p><p>  求,使取最小,這就是求解等價(jià)于方程組(1.1)的變分問(wèn)題。求解的方法一般是構(gòu)造一個(gè)向量序列,使。</p><p><b>  最速下降法<

7、;/b></p><p>  可通過(guò)求泛函的極小點(diǎn)來(lái)獲得式(1.1)的解。為此,可以從任一出發(fā),沿著泛函在處下降最快的方向搜索下一個(gè)近似點(diǎn),使得在該方向上達(dá)到極小值。</p><p>  由多元微積分知識(shí),在處下降最快的方向是在該點(diǎn)的負(fù)梯度方向,經(jīng)過(guò)簡(jiǎn)單計(jì)算,得:</p><p><b>  ,</b></p><p&

8、gt;  此處,也稱為近似點(diǎn)對(duì)應(yīng)的殘量。取,確定的值使取得極小值。由式(1.4),令</p><p><b>  ,</b></p><p><b>  得</b></p><p><b>  從上式求出并記為:</b></p><p><b>  (1.6)<

9、;/b></p><p>  綜合上述推導(dǎo)過(guò)程,可得最速下降法的算法描述:</p><p> ?、?給定初始點(diǎn),容許誤差,置。</p><p>  ⑵ 計(jì)算,若,停算,輸出作為近似解。</p><p> ?、?按式(1.6)計(jì)算步長(zhǎng)因子,置,,轉(zhuǎn)步驟⑵。</p><p>  最速下降法在理論上是可以收斂的,但是收

10、斂可能會(huì)比較緩慢,而且由于舍入誤差存在,實(shí)際算出的與理論上的最速下降方向可能有很大差別,使計(jì)算時(shí)出現(xiàn)數(shù)值不穩(wěn)定性。最速下降法在現(xiàn)代科學(xué)與工程中不再具有實(shí)用價(jià)值。</p><p><b>  共軛梯度法(CG)</b></p><p>  當(dāng)線性方程組Ax=b的系數(shù)矩陣A是對(duì)稱正定矩陣,可以采用共軛梯度法對(duì)該方程組進(jìn)行求解,可以證明,式(1.7)所示的n元二次函數(shù)<

11、;/p><p><b>  (1.7)</b></p><p>  取得極小值點(diǎn)x*是方程Ax=b的解。共軛梯度法是把求解線性方程組的問(wèn)題轉(zhuǎn)化為求解一個(gè)與之等價(jià)的二次函數(shù)極小化的問(wèn)題。從任意給定的初始點(diǎn)出發(fā),沿一組關(guān)于矩陣A的共軛方向進(jìn)行線性搜索,在無(wú)舍入誤差的假定下,最多迭代n次(其中n為矩陣A的階數(shù)),就可求得二次函數(shù)的極小點(diǎn),也就求得線性方程組Ax = b的解。其迭

12、代格式為公式(1.8)。</p><p><b>  (1.8)</b></p><p>  共軛梯度法中關(guān)鍵的兩點(diǎn)是迭代格式(21)中最佳步長(zhǎng)和搜索方向的確定。其中可以通過(guò)一元函數(shù)極小化來(lái)求得,其表達(dá)式為公式(22);取,則,要求滿足,可得到的表達(dá)式(23).</p><p><b>  (1.9)</b></p&

13、gt;<p><b>  (1.10)</b></p><p>  經(jīng)過(guò)一系列的證明和簡(jiǎn)化,最終可得共軛梯度法的計(jì)算過(guò)程如下</p><p> ?、?給定初始點(diǎn),容許誤差,計(jì)算,,置。</p><p><b> ?、?計(jì)算步長(zhǎng)因子</b></p><p><b>  置,。&

14、lt;/b></p><p> ?、?若,停算,輸出作為近似解。</p><p><b> ?、?計(jì)算</b></p><p><b>  置,,轉(zhuǎn)步驟⑵。</b></p><p>  1.3 預(yù)處理共軛梯度法(PCG)</p><p>  由于計(jì)算機(jī)存在舍入誤差,故

15、前述的共軛梯度法得到的向量會(huì)逐漸失去正交性,因而不大可能在n步之內(nèi)得到原方程組的精確解。此外,遇到求解大規(guī)模的線性方程組,即使能夠在n步收斂,收斂速度也不盡如人意。可以采用預(yù)處理技術(shù)改善收斂性質(zhì),加快收斂速度。</p><p>  預(yù)處理就是對(duì)原方程組進(jìn)行顯式或隱式的修正,使得修正后的方程組能夠更有效地求解。即構(gòu)造一個(gè)預(yù)處理矩陣M,然后用迭代法求解如下的同解方程組</p><p><

16、b>  (1.11)</b></p><p><b>  或</b></p><p><b>  (1.12)</b></p><p>  相應(yīng)得到的算法分別稱為左預(yù)處理迭代法或右預(yù)處理迭代法。將預(yù)處理技術(shù)和共軛梯度法結(jié)合,可以得到預(yù)處理共軛梯度法,算法如下:</p><p>  

17、⑴ 給定初始點(diǎn),容許誤差,計(jì)算,,置。</p><p><b>  ⑵ 計(jì)算步長(zhǎng)因子</b></p><p><b>  置,。</b></p><p> ?、?若,停算,輸出作為近似解。</p><p><b>  ⑷ 計(jì)算</b></p><p>&

18、lt;b>  置,,轉(zhuǎn)步驟⑵。</b></p><p>  預(yù)處理共軛梯度法成功與否,關(guān)鍵在于預(yù)處理矩陣M 是否選得合適。一個(gè)</p><p>  好的預(yù)處理矩陣應(yīng)該具有如下特征:</p><p><b>  ⑴ M 對(duì)稱正定;</b></p><p> ?、?M 與A 的稀疏性相近;</p>

19、;<p> ?、?方程組MSI = rI</p><p><b> ?、?易于求解;</b></p><p> ?、?的特征值分布比較“ 集中”,使較小。</p><p>  預(yù)處理矩陣的構(gòu)造方法有很多,這里介紹本次實(shí)驗(yàn)使用的兩種方法。</p><p><b> ?、?對(duì)角預(yù)處理法</b&g

20、t;</p><p>  若A 是嚴(yán)格對(duì)角占優(yōu)的矩陣,則可以選擇為預(yù)處理矩陣,若A是嚴(yán)格分塊對(duì)角占優(yōu)矩陣,則可以選擇為預(yù)處理矩陣;但是這樣簡(jiǎn)單的選擇,往往不能帶來(lái)很好的加速收斂效果。</p><p><b> ?、?矩陣分裂方法</b></p><p>  此方法的基本思想是將A 分裂為:;通過(guò)矩陣和來(lái)構(gòu)造預(yù)處理矩陣M,一般的做法是取線性穩(wěn)定迭

21、代法中相應(yīng)的A 的分裂。比如:Jacobi 分裂(),Gauss - Seidei 分裂(,L 是A 的嚴(yán)格下三角部分),SSOR 分裂等,下面介紹SSOR分裂。將A分裂為,其中,為嚴(yán)格下三角矩陣,它的元素是由A 相應(yīng)部分元素取負(fù)號(hào)以后構(gòu)成的。取:</p><p><b>  (1.13)</b></p><p>  其中()是參數(shù),一般取為1,本次實(shí)驗(yàn)中也取為1。&

22、lt;/p><p><b>  則預(yù)處理矩陣為:</b></p><p><b>  (1.14)</b></p><p>  從理論上講,此預(yù)處理矩陣可以使等于的平方根。</p><p><b>  2 實(shí)驗(yàn)與分析</b></p><p>  對(duì)于線性方程

23、組,首先使用matlab編寫最速下降法程序,并且隨機(jī)生成的對(duì)稱正定系數(shù)矩陣A和的矩陣b。多次運(yùn)行之后得到可以求出收斂解的矩陣并保存,則分別使用最速下降法、共軛梯度法、預(yù)處理共軛梯度法解決同一個(gè)線性方程組。以下是矩陣部分截圖,由于矩陣太大,不方便放在論文中,但是生成矩陣的程序在第三章中。</p><p><b>  圖1 系數(shù)矩陣A</b></p><p><b&

24、gt;  圖2 矩陣b</b></p><p>  最速下降法的實(shí)驗(yàn)結(jié)果</p><p>  由于結(jié)果矩陣x為的矩陣,在本文無(wú)法展示出截取計(jì)算出的最終收斂的結(jié)果,故截取前5個(gè)和后5個(gè)數(shù)值如下表:</p><p>  表1 最速下降法的部分結(jié)果</p><p>  圖3 Matlab顯示的工作區(qū)</p><p&g

25、t;  可以看出,使用最速下降法,迭代1821次之后得到收斂的結(jié)果。</p><p>  共軛梯度法的實(shí)驗(yàn)結(jié)果</p><p>  用共軛梯度法解同樣的線性方程組,截取部分結(jié)果如下:</p><p>  表2 共軛梯度法的部分結(jié)果</p><p>  圖4 Matlab顯示的工作區(qū)</p><p>  可以看出,使用共

26、軛梯度法,迭代112次之后得到收斂的結(jié)果。</p><p>  預(yù)處理共軛梯度法的實(shí)驗(yàn)結(jié)果</p><p>  首先將預(yù)處理矩陣M設(shè)為矩陣A的對(duì)角陣,得到數(shù)據(jù)如下:</p><p>  表3 M為A的對(duì)角陣時(shí)預(yù)處理共軛梯度法的部分結(jié)果</p><p>  圖5 Matlab顯示的工作區(qū)</p><p>  再用第二種方

27、法:用SSOR分裂法得到預(yù)處理矩陣M,部分結(jié)果如下:</p><p>  表4 用SSOR分裂法得到M的預(yù)處理共軛梯度法的部分結(jié)果</p><p>  圖6 Matlab顯示的工作區(qū)</p><p>  可以看出,使用預(yù)處理共軛梯度法,若預(yù)處理矩陣M取A的對(duì)角陣,需迭代123次之后得到收斂的結(jié)果;若預(yù)處理矩陣M用SSOR分裂法取得,需迭代90次之后得到收斂的結(jié)果。&

28、lt;/p><p>  比較上述解線性方程組的三種方法:</p><p>  ①最速下降法法是以殘向量作為解的修正方向,收斂速度可能很慢。若對(duì)應(yīng)系數(shù)矩陣A的最大、最小特征值,當(dāng)時(shí),收斂很慢;而且當(dāng)很小時(shí),因舍入誤差影響,計(jì)算會(huì)不穩(wěn)定。由實(shí)驗(yàn)也可以看出,最速下降法需要的迭代次數(shù)最多。</p><p>  ②共軛梯度法屬于變分方法的范圍,要求系數(shù)矩陣A對(duì)稱正定。使用CG法求

29、解n階方程組,理論上最多n步便可得到精確解。實(shí)驗(yàn)也證明,只需要112步便可得到精確解,比最速下降法快得多。</p><p> ?、?PCG法的使用效果,在于預(yù)處理矩陣的選擇;若預(yù)處理矩陣為系數(shù)矩陣的對(duì)角陣,用此方法效果可能不盡如人意,比如實(shí)驗(yàn)中迭代次數(shù)為123次,比CG法還慢些;而使用SSOR法對(duì)矩陣進(jìn)行預(yù)處理,再用CG法求解方程組會(huì)比較快,實(shí)驗(yàn)也可看出,90步迭代后,便可得到達(dá)到精確度要求的解。</p&g

30、t;<p>  3 實(shí)驗(yàn)用到的matlab程序</p><p><b>  生成隨機(jī)矩陣的程序</b></p><p><b>  N=1000;</b></p><p>  D = diag(rand(N,1));</p><p>  U = orth(rand(N,N));<

31、/p><p>  B = U' * D * U ;</p><p>  save('date_A.mat','B');</p><p>  b = rand(N,1);</p><p><b>  最速下降法程序</b></p><p>  A 最速下降法主程序

32、</p><p>  load date_A.mat</p><p>  load date_b.mat</p><p>  [x,iter] = mgrad(B,b);</p><p><b>  B 最速下降法模塊</b></p><p><b>  %最速下降法</b>

33、</p><p>  function [x,iter]=mgrad(A,b,x,ep,N)</p><p>  %用途:用最速下降法解線性方程組Ax=b</p><p>  %格式:[x,iter]=mgrad(A,b,x,ep,N) 其中A為系數(shù)矩陣,b為右端向量,x為初始向量</p><p>  %(默認(rèn)零向量),ep為精度(默認(rèn) 1e

34、-6),N為最大迭代次數(shù)(默認(rèn)1000次),返回參數(shù)</p><p>  %x,iter分別為近似解向量和迭代次數(shù)</p><p>  if nargin<5, N=1e12;end</p><p>  if nargin<4,ep=1e-6;end</p><p>  if nargin<3,x=zeros(size(b)

35、);end</p><p>  for iter=1:N</p><p><b>  r=b-A*x;</b></p><p>  if norm(r)<ep,break;end</p><p>  a=r'*r/(r'*A*r);</p><p><b>  x=

36、x+a*r;</b></p><p><b>  iter</b></p><p><b>  x</b></p><p><b>  end</b></p><p><b>  共軛梯度法程序</b></p><p>

37、  A 共軛梯度法主程序</p><p>  load date_A.mat</p><p>  load date_b.mat</p><p>  [x,iter]=mcg(B,b)</p><p><b>  B 共軛梯度法模塊</b></p><p>  function [x,iter]=

38、mcg(A,b,x,ep,N)</p><p>  %用途:用共軛梯度法解線性方程組Ax=b</p><p>  %格式:[x,iter]=mcg(A,b,x,ep,N)其中A為系數(shù)矩陣,b為右端向量,x為初始向量(默認(rèn)</p><p>  %零向量)ep為精度(默認(rèn)1e-6),N為最大迭代次數(shù)(默認(rèn)10000次),返回參數(shù)x,iter</p><

39、;p>  %分別為近似解向量和迭代次數(shù)</p><p>  if nargin <5,</p><p><b>  N=10000;</b></p><p><b>  end</b></p><p>  if nargin<4,</p><p><b

40、>  ep=1e-6;</b></p><p><b>  end</b></p><p>  if nargin<3,x=zeros(size(b));</p><p><b>  end</b></p><p><b>  r=b-A*x;</b>&

41、lt;/p><p>  for iter=1:N</p><p><b>  rr=r'*r;</b></p><p>  if iter==1</p><p><b>  p=r;</b></p><p><b>  else</b></p&

42、gt;<p>  beta=rr/rr1;</p><p>  p=r+beta*p;</p><p><b>  end</b></p><p><b>  q=A*p;</b></p><p>  alpha=rr/(p'*q);</p><p> 

43、 x=x+alpha*p;</p><p>  r=r-alpha*q;</p><p><b>  rr1=rr;</b></p><p>  if (norm(r)<ep),break;</p><p><b>  end</b></p><p><b>

44、  end</b></p><p>  3.4 預(yù)處理共軛梯度法程序</p><p>  A 得到預(yù)處理矩陣M的程序</p><p>  ① M為A的對(duì)角矩陣</p><p>  load date_A.mat</p><p>  M=diag(diag(B));</p><p>

45、  save('date_juzhenM1.mat','M');</p><p> ?、?M由SSOR分裂法得到</p><p>  load date_A.mat</p><p>  D=diag(diag(B));</p><p>  CL=tril(-B);</p><p>  L

46、=((D-CL)*D)^1/2;</p><p><b>  M=L*L';</b></p><p>  save('date_juzhenM.mat','M');</p><p>  B 預(yù)處理共軛梯度法主程序</p><p>  load date_A.mat</p>

47、;<p>  load date_b.mat</p><p>  [x,iter]=mpcg(B,b)</p><p>  C 預(yù)處理共軛梯度法模塊</p><p>  function [x,iter]=mpcg(A,b,x,ep,N)</p><p>  %用途:用預(yù)處理共軛梯度法解線性方程組Ax=b</p>

48、<p>  %格式:[x,iter]=mpcg(A,b,x,ep,N)其中A為系數(shù)矩陣,b為右端向量,x為初始向量(默認(rèn)</p><p>  %零向量)ep為精度(默認(rèn)1e-6),N為最大迭代次數(shù)(默認(rèn)10000次),返回參數(shù)x,iter</p><p>  %分別為近似解向量和迭代次數(shù)</p><p>  load date_juzhenM.mat<

49、;/p><p><b>  L=inv(M);</b></p><p>  if nargin <5,</p><p><b>  N=10000;</b></p><p><b>  end</b></p><p>  if nargin<4,

50、</p><p><b>  ep=1e-6;</b></p><p><b>  end</b></p><p>  if nargin<3,x=zeros(size(b));</p><p><b>  end</b></p><p>  r=

51、L*(b-A*x);</p><p>  for iter=1:N</p><p><b>  rr=r'*r;</b></p><p>  if iter==1</p><p><b>  p=r;</b></p><p><b>  else</b

52、></p><p>  beta=rr/rr1;</p><p>  p=r+beta*p;</p><p><b>  end</b></p><p><b>  q=L*A*p;</b></p><p>  alpha=rr/(p'*q);</p>

53、;<p>  x=x+alpha*p;</p><p>  r=r-alpha*q;</p><p><b>  rr1=rr;</b></p><p>  if (norm(r)<ep),break;</p><p><b>  end</b></p><p

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 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ì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論