




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、高等(godng)數(shù)值分析第一次實驗第一(dy)題:構(gòu)造例子說明CG的數(shù)值(shz)形態(tài)。當(dāng)步數(shù) = 階數(shù)時CG的解如何?當(dāng)A的最大特征值遠(yuǎn)大于第二個最大特征值,最小特征值遠(yuǎn)小于第二個最小特征值時,方法的收斂性如何?解:用Housholder變換和對角陣構(gòu)造1000階正定對稱矩陣A:構(gòu)造對角陣D = diag( linspace(1, 1000, 1000) );構(gòu)造Householder陣H。取單位向量w=1,0,0,.0T,I為1000階單位矩陣,H = I wTw。構(gòu)造對稱正定矩陣A。A = HTDH。由于D是對角陣,H是對稱的,所以A對稱;且A與D具有相同的特征值linspace(1,
2、 1000, 1000) 0,因此A對陣正定。b=rand(1000,1);取初始解x0=zeros(1000,1);1.計算Ax = b利用matlab編程實現(xiàn)CG算法。由于實際計算存在機(jī)器誤差,因此迭代1000步后的殘差不等于0,因此不能用rk=0作為停機(jī)準(zhǔn)則,否則matlab會無休止地計算下去。本例采用停機(jī)準(zhǔn)則為:迭代步數(shù)=1000步。當(dāng)D = diag( linspace(1, 1000, 1000) )時,條件數(shù)k=1000;當(dāng)D = diag( linspace(1, 100, 1000) )時,條件數(shù)k=100;當(dāng)D = diag( linspace(1, 10, 1000) )
3、時,條件數(shù)k=10;分別計算上述三種條件數(shù)下的CG算法,得到迭代步數(shù)與殘差的曲線圖。圖1:log(rk)與步數(shù)關(guān)系曲線。橫坐標(biāo)是迭代步數(shù),縱坐標(biāo)是殘差的對數(shù)值。圖 SEQ 圖 * ARABIC 1如圖1所示,矩陣(j zhn)A的條件數(shù)k越小,CG法收斂(shulin)速度越快。附matlab程序(chngx)1-1:clear allclc%條件數(shù)k=1000D=diag(linspace(1,1000,1000);w=eye(1,1000);I=eye(1000);H=I-w*w;A=H*D*H;%生成1000階的對稱矩陣b=rand(1000,1);x=zeros(1000,1);%初始
4、解r=b-A*x;%初始?xì)埩縫=r;%初始搜索方向k=0;semilogy(0,norm(r),r-);hold on;while k1000 alpha = r*p/(p*A*p); x = x+alpha*p; rold = r; r = rold-alpha*A*p; beta = r*r/(rold*rold); p = r+beta*p; semilogy(k,norm(r),r-); hold on; k=k+1;end%條件數(shù)k=100clear allD=diag(linspace(1,100,1000);w=eye(1,1000);I=eye(1000);H=I-w*w;A=
5、H*D*H;%生成1000階的對稱矩陣b=rand(1000,1);x=zeros(1000,1);%初始解r=b-A*x;%初始?xì)埩縫=r;%初始搜索方向k=0;semilogy(0,norm(r),b-);hold on;while k1000 alpha = r*p/(p*A*p); x = x+alpha*p; rold = r; r = rold-alpha*A*p; beta = r*r/(rold*rold); p = r+beta*p; semilogy(k,norm(r),b-); hold on; k=k+1;end%條件(tiojin)數(shù)k=10clear allD=di
6、ag(linspace(1,10,1000);w=eye(1,1000);I=eye(1000);H=I-w*w;A=H*D*H;%生成1000階的對稱(duchn)矩陣b=rand(1000,1);x=zeros(1000,1);%初始(ch sh)解r=b-A*x;%初始?xì)埩縫=r;%初始搜索方向k=0;semilogy(0,norm(r),black-);hold on;while k1000 alpha = r*p/(p*A*p); x = x+alpha*p; rold = r; r = rold-alpha*A*p; beta = r*r/(rold*rold); p = r+be
7、ta*p; semilogy(k,norm(r),black-); hold on; k=k+1;endtitle(條件數(shù)的大小對CG法收斂特性的影響);xlabel(迭代步數(shù))ylabel(殘差對數(shù)log(|rk|) 2.構(gòu)造特殊特征值分布構(gòu)造對稱正定矩陣A1和A2。D1=diag( linspace(1, 1000, 1000) )時,條件數(shù)k=1000,特征值均勻分布;D2=diag(1,linspace(500,600,998),1000)時,條件(tiojin)數(shù)仍為k=1000,最大特征值1000遠(yuǎn)大于第二個最大特征值600,最小特征值1遠(yuǎn)小于第二個最小特征值500。圖2:矩陣特征
8、值分布對CG算法(sun f)收斂性的影響圖 SEQ 圖 * ARABIC 2如圖2所示,A1和A2的條件(tiojin)數(shù)均為1000,但A2的收斂速度遠(yuǎn)高于A1。這是因為,在CG算法中,系數(shù)矩陣的中間特征值分布對CG的收斂速度有巨大的影響。經(jīng)過幾步后,CG的收斂因子將是:=0.046而非:=0.939因此,A2矩陣的收斂速度快得多。附matlab程序1-2:clear allclc%條件數(shù)k=1000,特征值均勻分布D=diag(linspace(1,1000,1000);w=eye(1,1000);I=eye(1000);H=I-w*w;A=H*D*H;%生成(shn chn)1000階
9、的對稱矩陣b=rand(1000,1);x=zeros(1000,1);%初始(ch sh)解r=b-A*x;%初始(ch sh)殘量p=r;%初始搜索方向k=0;semilogy(0,norm(r),r-);hold on;while k1000 alpha = r*p/(p*A*p); x = x+alpha*p; rold = r; r = rold-alpha*A*p; beta = r*r/(rold*rold); p = r+beta*p; semilogy(k,norm(r),r-); hold on; k=k+1;end%條件數(shù)k=1000,最大特征值遠(yuǎn)大于第二個最大特征值,最
10、小特征值遠(yuǎn)小于第二個最小特征值clear allD=diag(1,linspace(500,600,998),1000);w=eye(1,1000);I=eye(1000);H=I-w*w;A=H*D*H;%生成1000階的對稱矩陣b=rand(1000,1);x=zeros(1000,1);%初始解r=b-A*x;%初始?xì)埩縫=r;%初始搜索方向k=0;semilogy(0,norm(r),b-);hold on;while k1000 alpha = r*p/(p*A*p); x = x+alpha*p; rold = r; r = rold-alpha*A*p; beta = r*r/(
11、rold*rold); p = r+beta*p; semilogy(k,norm(r),b-); hold on; k=k+1;endtitle(特征值分布對CG法收斂(shulin)特性的影響);xlabel(迭代(di di)步數(shù))ylabel(殘差對數(shù)(du sh)log(|rk|) 第二題對于同樣的例子,比較CG和Lanczos的計算結(jié)果解:采用和第一題相同的構(gòu)造方法,構(gòu)造三個1000階正定對稱矩陣,使條件數(shù)k分別為:1000,100,10。分別采用CG和Lanczos方法計算Ax=b,且都設(shè)置停機(jī)準(zhǔn)則為:norm(rk)1 bita(j)=norm(r0); Q(:,j+1)=r0
12、/bita(j); end for k=1:j T(k,k)=alpha(k); end for k=1:j-1 T(k+1,k)=bita(k); T(k,k+1)=bita(k); %生成三對角陣T end e(1)=1; e(2:j)=0; y1=T(y*e); W=Q(:,1:j); X=X0+W*y1; r=norm(b-A*X); %求解(qi ji)第k步生成的X及r F(j)=r; if r/norm(b)1e-8 break; end %r的精度達(dá)到要求后停止迭代,得到(d do)最終X end semilogy(F,r);hold on;j %迭代(di di)步數(shù)toc%
13、=CG算法=ticp=R0;for i=1:n R=R0; a=(R*R)/(p*(A*p); x=x+a*p; R=R-a*(A*p); G(i)=norm(R); if G(i)/norm(b)=1e-8 break; end beta=(R*R)/(R0*R0); p=R+beta*p; R0=R; endsemilogy(G,b);toci %迭代步數(shù)legend(Lanczos,CG)title(Lanczos與CG算法收斂性對比,條件數(shù)k=10)xlabel(迭代步數(shù))ylabel(殘差對數(shù)log(|rk|) 第三題當(dāng)A只有m個不同特征值時,對于大的m和小的m,觀察有限精度下Lan
14、czos方法如何收斂。解: 分別(fnbi)構(gòu)建m = 10、50、100、1000四個矩陣A,設(shè)置停機(jī)準(zhǔn)則為:norm(rk)1 bita(j)=norm(r0); Q(:,j+1)=r0/bita(j); end for k=1:j T(k,k)=alpha(k); end for k=1:j-1 T(k+1,k)=bita(k); T(k,k+1)=bita(k); %生成三對角陣T end e(1)=1; e(2:j)=0; y1=T(y*e); W=Q(:,1:j); X=X0+W*y1; r=norm(b-A*X); %求解第k步生成的X及r F(j,i)=r; if r/norm
15、(b)300后,迭代步數(shù)遠(yuǎn)小于m。而同樣由于計算精度限制,在m較小時,迭代步數(shù)可能溢出m步,比如本例m=65和80的情形。另外,m值大于一定值后,隨著m的增加,收斂步數(shù)逐漸趨于定值,可能的原因是:隨著m的增大,特征向量線性相關(guān)性逐漸增強(qiáng)。附matlab程序4:clear allclcn=1000; D=diag(linspace(1,1000,n);P1=rand(n);Q1,R=qr(P1);A=Q1*D*Q1;%生成1000階的對稱矩陣V,D1=eig(A);for i=1:7M=10,50,65,80,300,800,1000;m=M(i);b=m*mean(V(:,1:m),2);X0
16、=zeros(n,1);%初始解x=X0; r0=b-A*X0; R0=r0; %=Lanczos解法 =ticy=norm(r0);F(1)=norm(r0); Q(:,1)=r0/norm(r0); r0=A*Q(:,1); alpha(1)=Q(:,1)*r0; r0=r0-alpha(1)*Q(:,1); bita(1)=norm(r0); Q(:,2)=r0/bita(1); %給各變量賦初始值 for j=2:n r0=A*Q(:,j)-bita(j-1)*Q(:,j-1); alpha(j)=Q(:,j)*r0; r0=r0-alpha(j)*Q(:,j); if norm(r0
17、)1 bita(j)=norm(r0); Q(:,j+1)=r0/bita(j); end for k=1:j T(k,k)=alpha(k); end for k=1:j-1 T(k+1,k)=bita(k); T(k,k+1)=bita(k); %生成(shn chn)三對角陣T end e(1)=1; e(2:j)=0; y1=T(y*e); W=Q(:,1:j); X=X0+W*y1; r=norm(b-A*X); %求解(qi ji)第k步生成的X及r F(j,i)=r; if rsqrt(eps) break; end %r的精度(jn d)達(dá)到要求后停止迭代,得到最終X end
18、tocjclear e y1 X r Tendsemilogy(F(:,1),r);hold on;semilogy(F(:,2),b);hold on;semilogy(F(:,3),y);hold on;semilogy(F(:,4),black);hold on;semilogy(F(:,5),g);hold on;semilogy(F(:,6),m);hold on;semilogy(F(:,7),c);hold on;legend(m=10,m=50,m=65,m=80,m=300,m=800,m=1000)title(b由不同特征向量個數(shù)組成時Lanczos的收斂性)xlabel(迭代步數(shù))ylabel(殘差對數(shù)log(|rk|)第五題構(gòu)造對稱不定矩陣,驗證Lanczos方
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 新疆維吾爾哈密地區(qū)巴里坤哈薩克自治縣2025屆五下數(shù)學(xué)期末考試模擬試題含答案
- 2025-2030家私行業(yè)市場深度分析及供需形勢與投資價值研究報告
- 新疆職業(yè)大學(xué)《數(shù)據(jù)挖掘與統(tǒng)計應(yīng)用》2023-2024學(xué)年第二學(xué)期期末試卷
- 邢臺市新河縣2024-2025學(xué)年三下數(shù)學(xué)期末學(xué)業(yè)質(zhì)量監(jiān)測模擬試題含解析
- 2025至2031年中國秸稈氣化機(jī)行業(yè)投資前景及策略咨詢研究報告
- 2025-2030年中國CNG纏繞瓶行業(yè)市場投資商機(jī)與風(fēng)險評估報告
- 2025-2030寵物玩具行業(yè)競爭格局及“”企業(yè)投資戰(zhàn)略研究報告
- 2024-2025企業(yè)安全培訓(xùn)考試試題附完整答案(考點梳理)
- 2025年職工安全培訓(xùn)考試試題帶解析答案
- 2025工廠職工安全培訓(xùn)考試試題【奪冠】
- 【人衛(wèi)九版內(nèi)分泌科】第十一章-甲狀腺功能減退癥課件
- “當(dāng)代文化參與”學(xué)習(xí)任務(wù)群相關(guān)單元的設(shè)計思路與教學(xué)建議課件(共51張PPT)
- 提高臥床患者踝泵運動的執(zhí)行率品管圈匯報書模板課件
- 同理心的應(yīng)用教學(xué)教材課件
- DB4102-T 025-2021海綿城市建設(shè)施工與質(zhì)量驗收規(guī)范-(高清現(xiàn)行)
- 城市軌道交通安全管理隱患清單
- 錫膏使用記錄表
- 兒童保健學(xué)課件:緒論
- 中小學(xué)校園安全穩(wěn)定工作崗位責(zé)任清單
- 校園安全存在問題及對策
- NY∕T 309-1996 全國耕地類型區(qū)、耕地地力等級劃分
評論
0/150
提交評論