數(shù)值分析報(bào)告之冪法及反冪法C語(yǔ)言程序?qū)嵗齙第1頁(yè)
數(shù)值分析報(bào)告之冪法及反冪法C語(yǔ)言程序?qū)嵗齙第2頁(yè)
數(shù)值分析報(bào)告之冪法及反冪法C語(yǔ)言程序?qū)嵗齙第3頁(yè)
已閱讀5頁(yè),還剩5頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

數(shù)值分析之幕法及反幕法C語(yǔ)言程序?qū)嵗?、算法設(shè)計(jì)方案:①求1、 501和s的值:S: s表示矩陣的按模最小特征值,為求得s直接對(duì)待求矩陣A應(yīng)用反幕法即可。1、 501:已知矩陣A的特征值滿足關(guān)系III,要求1、及501時(shí),可按如下方法求解:a.對(duì)矩陣A用幕法,求得按模最大的特征值ml°b.按平移量 m1對(duì)矩陣A進(jìn)行原點(diǎn)平移得矩陣m11,對(duì)矩陣B用反幕法c.則:求得B的按模最小特征值a.對(duì)矩陣A用幕法,求得按模最大的特征值ml°b.按平移量 m1對(duì)矩陣A進(jìn)行原點(diǎn)平移得矩陣m11,對(duì)矩陣B用反幕法c.則:求得B的按模最小特征值m3m2mlm2°1min(m1,m3)nmax(m1,m3)即為所求。②求和A的與數(shù)計(jì)最接近的特征值ik(k=0.1,…39):求矩陣A的特征值中與k最接近的特征值的大小,采用原點(diǎn)平移的方法:先求矩陣B=A-kI對(duì)應(yīng)的按模最小特征值k,則k+k即為矩陣A與k最接近的…39…39)的值。重復(fù)以上過程39次即可求得 ik(k=0,1,③求A的(譜數(shù))條件數(shù)cond(A)2和行列式detA:在(1)中用反幕法求矩陣 A的按模最小特征值時(shí),要用到 Doolittle分解方法,在Doolittle 分解完成后得到的兩個(gè)矩陣分別為 L和U,貝UA的行列式可由U陣求出,即:det(A)=det(U)°求得det(A)不為0,因此A為非奇異的實(shí)對(duì)稱矩陣,則:cond(A)2 呂,max和S分別為模最大特征值與模最小特征值。S2、程序源代碼:#include<stdio.h>#include<stdio.h>#include<math.h>#defineN501 // 列#defineM5 // 行#defineR2 // 下帶寬#defineS2 // 上帶寬#defineK39#definee1.0e-12 //誤差限floatA[M][N]; //初始矩陣floatu[N]; //初始向量floaty[N],yy[N];floatmaximum,value1,value2,value_1,value_N,value_s,value_abs_max;constfloatb=0.16f,c=-0.064f;intmax_sign,max_position;voidInit_matrix_A() //初始化矩陣A{inti;for(i=2;i<N;i++){A[0][i]=c;}for(i=1;i<N;i++){A[1][i]=b;}for(i=0;i<N;i++){A[2][i]=(1.64-0.024*(i+1))*sin(0.2*(i+1))-0.64*exp(0.1/(i+1));}for(i=0;i<N-1;i++){A[3][i]=b;}for(i=0;i<N-2;i++){A[4][i]=c;}}voidInit_u() //初始化迭代向量{inti;for(i=0;i<N;i++)u[i]=1.0;}voidGet_max() //獲得絕對(duì)值最大的數(shù)值的模{inti;max_position=0;maximum=fabs(u[O]);for(i=1;i<N;i++){if(maximum<fabs(u[i])){max_position=i;maximum=fabs(u[i]);}}if(u[max_position]<0)max_sign=-1;elsemax_sign=1;}voidGet_y() //單位化迭代向量{inti;for(i=0;i<N;i++)y[i]=u[i]/maximum;}voidGet_u() //獲得新迭代向量{inti;u[0]=A[2][0]*y[0]+A[1][1]*y[1]+A[0][2]*y[2];u[1]=A[3][0]*y[0]+A[2][1]*y[1]+A[1][2]*y[2]+A[0][3]*y[3];u[N-2]=A[4][N-4]*y[N-4]+A[3][N-3]*y[N-3]+A[2][N-2]*y[N-2]+A[1][N-1]*y[N-1];u[N-1]=A[4][N-3]*y[N-3]+A[3][N-2]*y[N-2]+A[2][N-1]*y[N-1];for(i=2;i<N-2;i++)u[i]=A[4][i-2]*y[i-2]+A[3][i-1]*y[i-1]+A[2][i]*y[i]+A[1][i+1]*y[i+1]+A[0][i+2]*y[i+2];}voidGet_value() //獲得迭代后特征值{value2=value1;value仁max_sign*u[max_position];}voidCheck_value()//幕法第二迭代格迭代{Init_u();Get_max();Get_y();Get_u();Get_value();while(1){Get_max();Get_y();Get_u();Get_value();if(fabs((value2-value1)/value1)<e)break;}}voidThe_value() //獲取絕對(duì)值最大的特征值入 _501{Check_value();value_abs_max=value1;}voidThe_Other_value()//獲取特征值入_1{inti;floatvalue_temp=value1;for(i=0;i<N;i++){A[2][i]-=value_temp;}Check_value();value1+=value_temp;

if(value1<value_temp){value_1=value1;value_N=value_temp;}else{value_N=value1;value_1=value_temp;}}//兩值中取最小////兩值中取最小//兩值中取最大{if(a<b)returna;elsereturnb;}intmax(inta,intb){if(a<b)returnb;elsereturna;}voidResolve_LU(){intk,i,j,t;floattemp;for(k=1;k<=N;k++){for(j=k;j<=min(k+S,N);j++){temp=0;for(t=max(max(1,k-R),j-S);t<=k-1;t++)temp+=A[k-t+S][t-1]*A[t-j+S][j-1];A[k-j+S][j-1]=A[k-j+S][j-1]-temp;}for(i=k+1;i<=min(k+R,N);i++){temp=0;for(t=max(max(1,i-R),k-S);t<=k-1;t++)temp+=A[i-t+S][t-1]*A[t-k+S][k-1];A[i-k+S][k-1]=(A[i-k+S][k-1]-temp)/A[S][k-1];voidBack_substitution()// 方程組回代過程{inti,t;floattemp=0;for(i=2;i<N+1;i++){for(t=max(1,i-R);t<i;t++)y[i-1]-=A[i-t+S][t-1]*y[t-1];}u[N-1]=y[N-1]/A[S][N-1];for(i=N-1;i>0;i--){temp=0;for(t=i+1;t<=min(i+S,N);t++)temp+=A[i-t+S][t-1]*u[t-1];u[i-1]=(y[i-1]-temp)/A[S][i-1];}}doubleDet_matrix()// 求矩陣行列式值{inti;doubledet=1;Init_matrix_A();Resolve_LU();for(i=0;i<N;i++)det=det*A[2][i];returndet;}floatGet_norm() //獲得迭代向量模{inti;floatnormal=0;for(i=0;i<N;i++)normal+=u[i]*u[i];normal=sqrt(normal);returnnormal;}voidGet_yy(floatnormal) //迭代向量單位化{inti;for(i=0;i<N;i++){y[i]=u[i]/normal;yy[i]=y[i];}}voidGet_value_s()//獲得絕對(duì)值最小的特征值{inti;value2=value1;value1=0;for(i=0;i<N;i++)value1+=yy[i]*u[i];value1=1/value1;}voidValue_min() //反幕法求絕對(duì)值最小的特征值{floatnorm=0;intcount=0;value1=0,value2=0;Init_u();norm=Get_norm();Get_yy(norm);Back_substitution();Get_value_s();while(count<10000){count++;norm=Get_norm();Get_yy(norm);Back_substitution();Get_value_s();if(fabs((value2-value1)/value1)<e)break;}value_s=value1;}floatGet_cond_A() //求矩陣條件數(shù){floatcond1;cond1=fabs(value_abs_max/value_s);returncond1;}voidValue_translation_min() //偏移條件下反幕法求特征值{inti,k;floattr;for(k=1;k<K+1;k++){tr=value_1+k*(value_N-value_1)/40;Init_matrix_A();for(i=0;i<N;i++)A[2][i]-=tr;Resolve_LU();Value_min();value_s+=tr;printf("k=%d=>>>入i%d=%.13e\n",k,k,value_s);}}voidmain(){floatcond;doublevalue_det;printf("Contactme:731363227qq.\n");Init_matrix_A(); // 初始化矩陣AThe_value(); //獲取絕對(duì)值最大的特征值入 _501The_Other_value(); // 獲取特征值入_1printf(" 入1=%.13e\n",value_1);printf(" 入501=%.13e\n",value_N);value_det=Det_matrix();//求矩陣行列式值Value_min(); //反幕法求絕對(duì)值最小的特征值printf("入s=%.13e\n",value_s);cond=Get_cond_A(); //求矩陣條件數(shù)Value_translation_min();〃 偏移條件下反幕法求特征值printf("cond_A=%.13e\n",cond);printf("value_det=%.13e\n",value_det);}3、程序運(yùn)行結(jié)果:ofNuaericalAnaly.口以*C:\DocuMentsandSettings\Ad>inistrator\^:面ITasik1ESH丄財(cái)1聊劉湄?cái)?shù)值分析大徐if丄ofNuaericalAnaly.0730092315G?4e+0911501=9-7247S1445312Se+ao0ls=-5.55?9231±20646e-0&3k=l=?>Xil=-l.01829338B0482e+061=?> 12=-9,585707B?82456tr*0e0J<=3=>?ki3=-9.17267238B6095e+060k=4=>?>i4=-R.fiS22R3717R7R2pr+nPHk=5->?Xi5=-8.09?4837^e4035e+000kf=?>Xi6=-?*6594052538276e+060](=?=?>y.i7—=■>?X16—6h-9=?>Xi9=-&.0Gtl033093929c+000k-10-?>X .5851011B34101e+000k=ll=?>\=?>入il2=-4.5?88?22643629e+000k=13=?> il3=-4.B964710377157c+000k=14=?>X.il^=-3.5542112756521e+000kT5=?>入±15^-3?9410?aS27312?e*008k=1ft=>?Xil6=-2.52643ft3ft4721fie+HRWk-1?-?>Xil7^-2.003233fl47"il83e*000k=18w”〉入i!8=-l.5035575726070c+000](=19=>〉》入il9=-9-9355ebl73B874e-001k-20-?>Xi2e—4.8?042t746?838e-001h-21->>>X121-B_231736JS223G7c602k=22-?>X122-5-3241?47G17722e-001k=S3=?>'123=1-0S28989899904e+000k=24=?>入124=1.589445903S9?3e+000k=25=>?'、125=2.06033B4t35733e+008k=26=?>X126=2.5580755751580e+B00k=27=?>X .08O24a402B364e*S00=>?'、、i2R=3.k=2?-?>Xi29-4*09137S5751?0?e+P00k-30->?X130=4.60303552821280+600k=3t->?入131=5.13292419&3103e*600k-32-?>入132-5-594906423240?e也001^93->>>X133H;-0e0933?347?4Ge*600k=34-?>X_6803541369736e+000k=3S=?>h135=7.2938773855567e+000k=36=?>X136=7.7171115fcl4474e+800k=37=?>hi3V=8-225219?4i4637e+000k=38=>?人

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(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)論