幂法,反幂法求解矩阵最大最小特征值及其对应的特征向量(DOC)

幂法,反幂法求解矩阵最大最小特征值及其对应的特征向量(DOC)
幂法,反幂法求解矩阵最大最小特征值及其对应的特征向量(DOC)

数值计算解矩阵的按模最大最小特征值及对应的特征向量

一.幂法

1. 幂法简介:

当矩阵A 满足一定条件时,在工程中可用幂法计算其主特征值(按模最大)及其特征向量。矩阵A 需要满足的条件为: (1) 的特征值为A i n λλλλ,0||...||||2

1≥≥≥>

(2) 存在n 个线性无关的特征向量,设为n x x x ,...,,21 1.1计算过程:

i n

i i i u x

x αα,1

)

0()0(∑==,有对任意向量不全为0,则有

1

11111221

12111

1

1

11

1

011)()(...u u a u a u λu λαu αA x A Ax x k n n k n k k n

i i

k i i n

i i i k )(k (k))(k αλλλλλα++++=+=+++≈?

?

????+++======∑∑ 可见,当||1

2

λλ越小时,收敛越快;且当k 充分大时,有1)11

11)111

11λαλαλ=??????==+++(k )(k k

(k k )(k x x u x u x ,对应的特征向量即是)(k x 1+。

2 算法实现

.

,, 3,,1 , ).5()

5(,,,,||).4();max(,).3()

(max(;0,1).2(,).1()()

()

(停机否则输出失败信息转置若转否则输出若计算最大迭代次数,误差限,初始向量输入矩阵βλβεβλβλε←+←<<-←←=

←←k k N k y x Ay x x abs x y k N x A k k k

3 matlab 程序代码

function [t,y]=lpowerA,x0,eps,N) % t 为所求特征值,y是对应特征向量

k=1;

z=0; % z 相当于λ

y=x0./max(abs(x0)); % 规范化初始向量

x=A*y; % 迭代格式

b=max(x); % b 相当于β

if abs(z-b)

t=max(x);

return;

end

while abs(z-b)>eps && k

k=k+1;

z=b;

y=x./max(abs(x));

x=A*y;

b=max(x);

end

[m,index]=max(abs(x)); % 这两步保证取出来的按模最大特征值

t=x(index); % 是原值,而非其绝对值。

end

4 举例验证

选取一个矩阵A,代入程序,得到结果,并与eig(A)的得到结果比较,再计算A*y-t*y,验证y是否是对应的特征向量。结果如下:

结果正确,表明算法和代码正确,然后利用此程序计算15阶Hilb矩阵,与eig(A)的得到结果比较,再计算A*y-t*y,验证y是否是对应的特征向量。设

置初始向量为x0=ones(15,1),结果显示如下

可见,结果正确。得到了15阶Hilb 矩阵的按模最大特征值和对应的特征向量。

二.反幂法

1.反幂法简介及其理论

在工程计算中,可以利用反幂法计算矩阵按模最小特征值及其对应特征向量。其基本理论如下,与幂法基本相同:

x x A x A x x Ax λ

λλ1

)(11

==?=--则,

由,可知,A 和A -1的特征值互为倒数,

求A 按模最小特征值即求A -1的按模最大特征值,取倒数即为A 的按模最小特征

值所以算法基本相同,区别就是在计算

)

1()()1()(1-)1()()1()1(;,+++++===k k k k k k k k x LU A y Ax y A x Ay x x 分解,来计算做对具体计算时,变换为而是时,不是令

2.算法实现

.

, );

4( ,))

(max(, ,1,).7(),

7(,,,1

,||).6( ),max().5(),,().4().3(,

))

(max(,0 ,1).2(,,,,).1(000停机否则输出失败信息转置若否则转停机输出若解方程组作三角分解置最大迭代次数误差限初始向量输入矩阵x abs x

y k k N k y x z Ux y Lz y LUx LU

A x abs x

y k N x A ←←+←<<-←←====←←←λλλ

ελλμ

λμλε

3 matlab 程序代码

function [s,y]=invpower(A,x0,eps,n) % s 为按模最小特征值,y 是对应特征向量 k=1; r=0; % r 相当于0λ

y=x0./max(abs(x0)); % 规范化初始向量 [L,U]=lu(A); z=L\y; x=U\z; u=max(x);

s=1/u; % 按模最小为A -1按模最大的倒数.

if abs(u-r)

while abs(u-r)>eps && k

y=x./max(abs(x)); z=L\y; x=U\z;

u=max(x); end

[m,index]=max(abs(x)); % 这两步保证取出来的按模最大特征值

s=1/x(index); % 是原值,而非其绝对值。 end

4 举例验证

同幂法一样,选取一个矩阵A ,代入程序,得到结果,并与eig(A)的得到结果比较,再计算 A*y-t*y ,验证y 是否是对应的特征向量。

可见结果正确,然后利用此程序计算15阶Hilb 矩阵,eig(A)的得到结果比较,再计算 A*y-s*y ,验证y 是否是对应的特征向量。设置初始向量为

x0=ones(15,1),结果显示如下

可见,结果真确。得到了15阶Hilb矩阵的按模最大特征值和对应的特征向量。

三. 计算条件数

矩阵A的条件数等于A的范数与A的逆的范数的乘积,即cond(A)=‖A‖·‖A^(-1)‖,对应矩阵的3种范数,可以定义3种条件数。函数cond(A,1)、cond(A)或cond(A inf)是判断矩阵病态与否的一种度量,条件数越大表明矩阵的病态程度越大.

的最大和最小特征值

矩阵

分别为

范数,即

这里我们选择矩阵的

A

A

A

cond

T

2

1

2

1,

,

)

(

λ

λ

λ

=

, 而如果A为对称矩阵,如Hilb矩阵,A

A T的最大最小特征值,分别为A的最大最小特征值的平方。所以cond(A) 为A的最大最小特征值得比值。对于本例中的15阶Hilb矩阵来说,利用上面计算结果得其条件数(选择第二种条件数)为:3.0934e+017;这与直接利用cond(A)得到的结果:2.5083e+017在同一

数量级,再次表明了上述算得得最大最小特征值的正确性,同时又表明Hilb 矩阵是病态矩阵。

四.Aitken 商加速法

1.简介与原理

{}{}.

,??:2)( 2)(,,

;0lim ,122

1122

1222

1211加速法这种方法称为逼近用有充分大时当线性收敛即且收敛与若Aitken a a a

a a a a a a a x x x x x x y a

a a

a a a a a k a c a a a

a a a k k k

k k k k k n

n n n n n n k k k k k k

k k k =+---≈?+---

=--≈--≠=--+++++++++++++∞→

同幂法和反幂法计算最大和最小特征值类似,如果计算最大特征值,则迭代格式为)()

1(k k Ay x

=+;计算最小特征值时,迭代格式为

)1()()(1)1(,+-+==k k k k Ax y y A x 即。

2.算法实现

计算按模最大特征值算法如下:

.

,,),

3()

max(

,,1 , , ,,).6(),6(,,,).5(,

2)().4(,)max( , ).3(,

)

max( ,0.1 ,0 ,0 ,1).2(,,,),().1(0120100

122

0102010停机输出失败信息否则转置若否则转停机输出若计算置计算置最大迭代次数误差限初始向量输入y x x

k k N k y x Ay x x x

y k N x a A ij ??+???<<-+---=?=======λλααααλελλααααααλαλααε

类似幂法和反幂法可以写出按模最小特征值算法,此处不再赘述。

3.matlab 程序代码

function [r,y]=aitken(A,x0,eps,n) % r按模最大特征值,y为对应特征向量

k=1;

α

a0=0; % a 相当于0

α

a1=1; % a1 相当于1

r0=1; % 相当于2中的0λ

y=x0./max(abs(x0)); % 规范化初始向量

x=A*y;

α

a2=max(abs(x)); % a2相当于2

r=a0-(a1-a0)^2/(a2-2*a1+a0); % 相当于λ

if (a2-2*a1+a0)==0 % 若上式中分母为0,则迭代失败,返回disp "初始向量迭代失败"

return;

end

if abs(r-r0)

end

while abs(r-r0)>eps && k

k=k+1;

a0=a1;

a1=a2;

r0=r;

y=x./max(abs(x));

x=A*y; % 迭代格式

a2=max(abs(x));

if (a2-2*a1+a0)==0 % 若分母为0,则迭代失败,返回

return;

end

r=a0-(a1-a0)^2/(a2-2*a1+a0);

[m,index]=max(abs(eig(A))); % 以下代码保证取出来的按模最大特征值aa=eig(A); % 是原值,而非其绝对值。

if aa(index)>0 ||aa(index)==0

r=r;

e lse

r=-r;

end

end

end

类似可得按模最小特征值和特征向量的代码如下:与上面类似,所不同的只是迭代格式不同.

function [r,y]=invaitken(A,x0,eps,n)

k=1;

a0=0;

a1=1;

r0=1;

y=x0./max(abs(x0));

[L,U]=lu(A); % 迭代格式的不同

z=L\y;

x=U\z;

a2=max(abs(x));

r=a0-(a1-a0)^2/(a2-2*a1+a0);

i f (a2-2*a1+a0)==0

disp "初始向量迭代失败"

return;

end

if abs(r-r0)

end

while abs(r-r0)>eps && k

k=k+1;

a=b;

b=c;

r0=r;

y=x./max(abs(x));

z=L\y;

x=U\z;

a2=max(abs(x));

if (a2-2*a1+a0)==0

return;

end

r=a0-(a1-a0)^2/(a2-2*a1+a0);

end

[m,index]=min(abs(eig(A))); % 以下代码保证取出来的按模最大特征值aa=eig(A); % 是原值,而非其绝对值。

if aa(index)>0 ||aa(index)==0

r=1/r;

else

r=-1/r;

end

end

4.计算Hilb矩阵特征值

此处不再举例,而是直接应用于15阶Hilb矩阵,初始向量选为ones(15,1),结果如下,并将结果与幂法和反幂法得到结果比较

这与幂法得到的特征值和特征向量一致,表明算法和代码正确;同理,最小特征值结果如下:

这与反幂法得到的结果一致,表明结果正确。

五,对称矩阵的Rayleigh 商加速法 1.简介与原理

商的为关于则称为对称矩阵,设ayleigh )(,0R A x

x Ax

x x R x A T T =≠

原理如下:

)

max(,)()

()()()()max(0)()

()

(1)

()()()

1()()

()()

1()()

()

(i i k k k k k T k k T k k k k k k k i i i i x x y

y R Rayleigh y y x y y R Ay x

x x y X X AX X →

→????

?????====≠++λλλ其中商加速法。

这称为左乘上式有:用的特征向量,即为设

2. 算法实现

.

, );

3( ,))

(max(, ,1,).5(),5(,,,,||).4(,*).3(,

))(max(,0 ,1).2(,

,,,).1(000停机否则输出失败信息转置若否则转停机输出若置最大迭代次数误差限初始向量输入矩阵x abs x

y r r k k N k y r r r y

y x

y r y A x x abs x

y r k N x A T

T ←←+←<<-←←←←←εε

3. Matlab 程序代码

function [r,y]=rayleigh(A,x0,eps,n) % r 是特征值,y 是特征向量 k=1; r0=0;

y=x0./max(abs(x0));

x=A*y; % 迭代格式计算新的x r=dot(y,x)/dot(y,y); % Reyleigh 商 if abs(r-r0)

while abs(r-r0)>eps && k

y=x./max(abs(x)); x=A*y;

r=dot(y,x)/dot(y,y); end end

类似得计算按模最小特征值的Rayleigh 商加速法,如下: function [r,y]=invrayleigh(A,x0,eps,n) k=1;r0=0;

y=x0./max(abs(x0));

[L,U]=lu(A); % 迭代格式不同 z=L\y; x=U\z;

r=dot(y,x)/dot(y,y); if abs(r-r0)

while abs(r-r0)>eps && k

r0=r;

y=x./max(abs(x));

z=L\y;

x=U\z;

r=dot(y,x)/dot(y,y);

end

r=1/r;

end

4. 计算Hilb矩阵特征值

此处不再举例,而是直接应用于15阶Hilb矩阵,初始向量选为ones(15,1),结果如下,并将结果与幂法和反幂法得到结果比较

这与幂法得到结果一致,表明算法和代码正确。

同理,最小特征值如下:

与反幂法得到结果一致,表明代码和算法正确。

幂法,反幂法求解矩阵最大最小特征值及其对应的特征向量

数值计算解矩阵的按模最大最小特征值及对应的特征向量 —一 .幂法 1. 幕法简介: 当矩阵A 满足一定条件时,在工程中可用幕法计算其主特征值 (按模最大) 及其特征向量。矩阵A 需要满足的条件为: ⑴I 1 I I 2|n |- 0, i 为A 的特征值 (2)存在n 个线性无关的特征向量,设为 X i ,X 2,…,X n 1.1计算过程: n 对任意向量x (0),有x (0)八:-M —不全为0,则有 i 4 X (k 岀)=Ax (k)= = A k 岀乂。) n n A k 1 aq a 扌1 5 i =1 i =1 ■k 1 2 可见,当 1 — 1 越小时,收敛越快;且当k 充分大时,有 ? "1 2算法实现 ⑶.计算x Ay,… max(x); ⑷若| ?一十:;,输出-,y,否则,转(5) (5)若N ,置k 「k 1^ -,转3,否则输出失败信息,停机. 3 matlab 程序代码 (冲1 %叫 x (k 1) [x (k) k 二 u x (k) > (k+1) 1,对应的特征向量即是 x (1).输入矩阵A ,初始向量X ,误差限 最大迭代次数N (k) 0; y (k) max(abs(x (k ))

k=1; z=0; y=x0./max(abs(x0)); x=A*y; % z相当于■ %规范化初始向量%迭代格式 b=max(x); % b相当于: if abs(z-b)eps && k> y]=lpower (A, xO, eps, X)

实验6反幂法求矩阵按模最小特征值

西华数学与计算机学院上机实践报告 课程名称:计算方法A 年级:2010级 上机实践成绩: 指导教师:严常龙 姓名:李国强 上机实践名称:反幂法求矩阵按模最小特征值 学号:362011********* 上机实践日期:2013.12.18 上机实践编号:6 上机实践时间:14:00 一、目的 1.通过本实验加深对反幂法的构造过程的理解; 2.能对反幂法提出正确的算法描述编程实现,得到计算结果。 二、内容与设计思想 自选方阵,用反幂法求解其按模最小特征值。 可使用实例: ????? ??---=90688465441356133A 三、使用环境 操作系统:Win 8 软件平台:Visual C++ 6.0 四、核心代码及调试过程 #include #include #define MAX_N 20 //矩阵最大维数 #define MAXREPT 100 #define epsilon 0.00001 //求解精度 int main() { int n; int i,j,k; double xmax,oxmax; static double a[MAX_N][MAX_N]; static double l[MAX_N][MAX_N],u[MAX_N][MAX_N]; static double x[MAX_N],nx[MAX_N]; printf("\n 请输入矩阵阶数n:"); //输入矩阵维数 scanf("%d",&n); if(n>MAX_N)

{ printf("the input n is larger than MAX_N,please redefine the MAX_N.\n"); return 1; } if(n<=0) { printf("please input a number between 1 and %d.\n",MAX_N); return 1; } //输入A矩阵 printf("请输入矩阵的值a[i][j] i,j=0...%d;\n",n-1); for(i=0;ixmax) xmax=fabs(nx[j]); for(j=0;j

用QR算法求矩阵的特征值

一、实验名称:用QR 算法求矩阵的特征值 二、实验目的:1、通过实验进一步熟悉掌握求矩阵特征值的QR 方法及原理。 2、理解QR 方法的计算流程。 3、能够编程实现QR 方法。 三、实验内容:给定矩阵 ??? ? ? ??=111132126A , ?? ??? ?? ? ? ?=0100098 20 087630 7654465432H ,采用QR 方法计算A 和H 矩阵的全部特征值。 四、实验要求: (1) 根据QR 算法原理编写程序求矩阵A 及矩阵H 的全部特征值(要求误差<10 5 -)。 (2) 直接用MATLAB 的内部函数eig 求矩阵A 及矩阵H 的全部特征值,并与(1)的结果比较。 五、QR 方法计算矩阵特征值的程序: function [namda,time,data_na]=qr_tz(A,tol) if nargin==1; tol=1e-5; end wucha=1; time=0; while (wucha>tol)&(time<500) [q,r]=qr(A); A1=r*q; tz0=diag(A1); tz1=diag(A); wucha=norm(tz0-tz1); A=A1; time=time+1; data_na(time,:)=tz1; end namda=tz1; disp(‘特征值为’) namda disp(‘第一个特征在值’) time n1=length(data_na); n2=(1:n1)’; temp1=[n2,data_na]; subplot(2,2,1:2)

plot(date_na(:,1)) title(‘迭代次数为’) grid subplot(2,2,3) plot(data-na(:,2)) title(‘第二个特征值’)grid subplot(2,2,4) plot(data-na(:,3)) title(‘第三个特征值’) grid 六、实验结果: >> A=[6,2,1;2,3,1;1,1,1];[namda,time,data_na]=qr_tz(A,1e-5);特征值为 namda = 迭代次数为 time = 6 图 1

幂法求矩阵主特征值

!程序说明:幂法求矩阵主特征值 !日期:2010年11月30日 PROGRAM Matrix_EigenValue PARAMETER(N=3) REAL ARR(N,N) CALL INPUT(ARR,N) CALL MATEV(ARR,N) END PROGRAM SUBROUTINE INPUT(ARR,N) REAL ARR(N,N) OPEN(1,FILE='MAT.TXT') READ(1,*)((ARR(I,J),J=1,N),I=1,N) END SUBROUTINE SUBROUTINE MATEV(ARR,N) PARAMETER(EPS=1E-7) REAL :: ARR(N,N),X(N),X1(N),MAX=0 INTEGER :: K=0,P=0 X=RESHAPE((/1,1,1/),(/3/)) WRITE(1,*) ' 迭代次数 U(规范化向量) & & MAX(V)(主特征值)' DO WHILE(P/=N) WRITE(1,'(I6,A,F12.6,A,F12.6)') K,' (',X,' )',MAX P=0 MAX=0 DO I=1,N X1(I)=0 DO J=1,N X1(I)=X1(I)+ARR(I,J)*X(J) !迭代过程 ENDDO ENDDO DO I=1,N IF(ABS(X1(I))>ABS(MAX)) MAX=X1(I) !选取主特征值 ENDDO DO I=1,N IF(ABS(X(I)-X1(I)/MAX)

ENDDO K=K+1 ENDDO END SUBROUTINE 输出结果: 1 1 0.5 1 1 0.25 0.5 0.25 2 迭代次数 U(规范化向量) MAX(V)(主特征值) 0 ( 1.000000 1.000000 1.000000 ) 0.000000 1 ( 0.909091 0.81818 2 1.000000 ) 2.750000 2 ( 0.837607 0.743590 1.000000 ) 2.659091 3 ( 0.799016 0.703035 1.000000 ) 2.604701 4 ( 0.77741 5 0.680338 1.000000 ) 2.575267 5 ( 0.765108 0.66740 6 1.000000 ) 2.558792 6 ( 0.758025 0.659963 1.000000 ) 2.549406 7 ( 0.753925 0.655655 1.000000 ) 2.544003 8 ( 0.751544 0.653153 1.000000 ) 2.540876 9 ( 0.750158 0.651697 1.000000 ) 2.539060 10 ( 0.749351 0.650848 1.000000 ) 2.538003 11 ( 0.748880 0.650354 1.000000 ) 2.537387 12 ( 0.748606 0.650065 1.000000 ) 2.537028 13 ( 0.748445 0.649897 1.000000 ) 2.536819 14 ( 0.748352 0.649799 1.000000 ) 2.536697 15 ( 0.748298 0.649741 1.000000 ) 2.536626 16 ( 0.748266 0.649708 1.000000 ) 2.536584 17 ( 0.748247 0.649688 1.000000 ) 2.536560 18 ( 0.748236 0.649677 1.000000 ) 2.536546 19 ( 0.748230 0.649670 1.000000 ) 2.536537 20 ( 0.748226 0.649667 1.000000 ) 2.536533 21 ( 0.748224 0.649664 1.000000 ) 2.536530 22 ( 0.748223 0.649663 1.000000 ) 2.536528 23 ( 0.748222 0.649662 1.000000 ) 2.536527 24 ( 0.748222 0.649662 1.000000 ) 2.536527 25 ( 0.748222 0.649662 1.000000 ) 2.536526 26 ( 0.748221 0.649661 1.000000 ) 2.536526

幂法求矩阵A按模最大的特征值及其特征向量

数值分析 幂法求矩阵A按模最大的特征值及其 特征向量

幂法的主要思想 设 n n ij R a A ?∈=)( ,其特征值为i λ ,对应特征向量为),,,1(n i x i =即 i i i x Ax λ= ),,1(n i =,且 x 1,······,x n 线性无关。求矩阵A 的主特征值及对应的特征向量。 幂法的基本思想: 任取一个非零初始向量 v 0 ∈R n 且v 0≠0, 由矩阵A 的乘幂构造一向量序列: 称{ v k }为迭代向量, A 特征值中 λ1为强占优,即▕ λ1▕>▏λ2 ▏>······>▏λn ▏, {x 1,x 2,······,x n }线性无关,即{x 1,x 2,······,x n }为R n 中的一 个基,于是对任意的初始向量v 0 ∈R n 且 v 0≠0有展开式。 (v 0 用{x i } 的线性组合表示) (且设01≠α) 则 当k =2,3,… 时,v k = A v k-1 = A k v ? ?? 1Av v =0 212v A Av v ==01 1 v A Av v k k k ++==) ,,1,0(n k =∑==n i i i x v 1 α)(221101n n x x x A v A v ααα+++==n n x A x A x A ααα+++=2211n n n x x x λαλαλα+++=222111) (111 +≡x k αλk ε

其中 由假设▕ λ1▕>▏λ2 ▏>······>▏λn ▏,得 ,从而 即,0lim =∞→k k ε且收敛速度由比值||12λλ=r 确定。 所以有 说明,当k 充分大时,有1 11 x v k k αλ≈,或 k k v 1λ 越来越接近特征 向量 规范化幂法的算法 ①输入矩阵 A 、初始向量v (0),误差 eps ,实用中一般取 v (0)=(1,1,···,1)T ; ②k ←1; ③计算 v (k) ←Au (k-1); ④m k ←max{ v (k) },m k-1 ←{ v (k-1) }; ⑤u (k) ←v (k)/ m k ; ⑥如果▕ m k - m k-1▕<eps ,则显示特征值λ1←和对应的特征 向量x (1),终止; ⑦k=k+1,转③。 n k n n k k x x )()(1 2122λλαλλαε++=),,2(1||1 n i i =<λλ ),,,2(0)(lim 1n i k i k ==∞→λλ111 lim x v k k k αλ=∞ →。 11x α

matlab求矩阵特征值特征向量 乘幂法

摘 要 根据现代控制理论课程的特点, 提出并利用MATLAB 设计了现代控制理论课程的实验, 给出了设计的每个实验的主要内容及使用到的MATLAB 函数, 并对其中的一个实验作了详细说明。通过这些实验, 将有助于学生理解理论知识, 学习利用MATLAB 解决现代控制理论问题。 关键词:现代控制理论、MATLAB 、仿真。 1设计目的、内容及要求 1.1设计目的 本课程设计以自动控制理论、现代控制理论、MATLAB 及应用等知识为基础,求连续系统对应的离散化的系统,并用计算系数阵按模最大的特征根法判别离散系统的稳定性,目的是使学生在现有的控制理论的基础上,学会用MATLAB 语言编写控制系统设计与分析的程序,通过上机实习加深对课堂所学知识的理解,掌握一种能方便地对系统进行离散化的实现和分析系统的稳定性的设计的工具。 1.2设计内容及要求 1 在理论上对连续系统离散化推导出算法和计算公式 2 画出计算机实现算法的框图 3 编写程序并调试和运行 4 以下面的系统为例,进行计算 ??????????----=041020122A ,?? ?? ? ?????=100B ,[]111-=c 5 分析运算结果

6 幂法迭代精度为ep=0.001,离散系统展开项数为20 7 程序应具有一定的通用性,对不同参数能有兼容性。 2算法选择及推导 2.1连续系统离散化算法 书P67离散化意义 已知被控对象的状态方程为: ()()()()()()t t u t y t t u t =+=+ x Ax B Cx D 对方程求解,得: 0()()0()()()o t t t t t t e t e u d τττ --=+?A A x x B 设0t kT =,(1)t k T =+,代入上式,得: H 公式 若省略T 则为{ ? +-++Φ=+T k kT d kT Bu T k kt x T T k x )1()(])1[()()(])1([(τ τφ不改变与离散后时刻,即得连续离散化方程则:相当于)+=(上限相当于下限设令D C kT Du kT Cx kT y kT t kT u T H kT x T G T k x Bdt t Bdt e T H t T k T t kT d dt T k t Bd e T H e T T G T T AT T k kT T k A AT )()()()()()()(])1([(: )()(0 ,1,,)1()()()(0 )1(])1[(+==+=+Φ=====-=-+=?==Φ=???+-+τττττ τ

一些特殊矩阵特征值得求法与应用 (2)

本科毕业设计题目:一些特殊矩阵特征值的求法与应用 作者:高英 学号: 2010012491 所属学院:金融与数学书院 专业班级:应数1002班 指导教师:赵建中职称:院长 完成时间: 2014 年 4月 10日 皖西学院教务处制

独创性声明 本人郑重声明:所呈交的论文是本人在导师的指导下独立进行研究所取得的研究成果。除了文中特别加以标注引用的内容外,本论文不包含任何其他个人或集体已经发表或撰写的成果作品。对本文的研究做出重要贡献的个人和集体,均已在文中以明确方式标明。本人完全意识到本声明的法律后果由本人承担。 学生签名:日期:年月日 论文版权使用授权书 本人完全了解皖西学院有关保留、使用学位论文的规定,即:学校有权保留送交论文的复印件和磁盘,允许论文被查阅和借阅,可以采用影印、缩印或扫描等复制手段保存、汇编学位论文。同意皖西学院可以用不同方式在不同媒体上发表、传播学位论文的全部或部分内容。 (保密的学位论文在解密后应遵守此协议) 学生签名:日期:年月日 导师签名:日期:年月

目录 摘要 .......................................................... 错误!未定义书签。Abstract ...................................................... 错误!未定义书签。第1章绪论 .................................................. 错误!未定义书签。 1.1 课题研究背景及目的................................... 错误!未定义书签。 1.2 研究现状 (1) 1.3研究方法 (2) 1.4研究内容 (2) 第2章几类特殊矩阵的概念及主要性质............................ 错误!未定义书签。 2.1 正交矩阵............................................. 错误!未定义书签。 2.2 幂零矩阵 (2) 2.3 对称矩阵 (3) 2.4 三对角矩阵 (4) 第3章矩阵特征值的求法与应用 (4) 3.1 一般矩阵的求法与应用 (4) 3.2 特殊矩阵的求法与应用 (7) 结语 (20) 致谢 (20) 参考文献 (21)

数学建模 用幂法 和法 根法求特征值特征向量

数学建模作业 计算机学院信计1102班姜圣涛 (1)幂法求矩阵最大特征值及特征向量: 程序为: #include #include using namespace std; #define n 3 //三阶矩阵 #define N 20 #define err 0.0001 //幂法求特征值特征向量 void main(){ cout<<"**********幂法求矩阵最大特征值及特征向量***********"<>A[i][j]; //输入矩阵 cout<<"请输入初始向量:\n"; for(i=0;i>X[i]; //输入初始向量 k=1; u=0;

while(1){ max=X[0]; for(i=0;i

幂法反幂法求解矩阵大小特征值及其对应的特征向量

幂法反幂法求解矩阵大小特征值及其对应的特征向量

————————————————————————————————作者:————————————————————————————————日期:

数值计算解矩阵的按模最大最小特征值及对应的特征向量 一.幂法 1. 幂法简介: 当矩阵A 满足一定条件时,在工程中可用幂法计算其主特征值(按模最大)及其特征向量。矩阵A 需要满足的条件为: (1) 的特征值为A i n λλλλ,0||...||||21 ≥≥≥> (2) 存在n 个线性无关的特征向量,设为n x x x ,...,,21 1.1计算过程: i n i i i u x x αα,1 ) 0()0(∑==,有对任意向量不全为0,则有 1 11111221 12111 1 1 11 1 011)()(...u u a u a u λu λαu αA x A Ax x k n n k n k k n i i k i i n i i i k )(k (k))(k αλλλλλα++++=+=+++≈? ? ????+++======∑∑ 可见,当||1 2 λλ越小时,收敛越快;且当k 充分大时,有1)11 11)11111λαλαλ=??????==+++(k )(k k (k k )(k x x u x u x ,对应的特征向量即是)(k x 1+。 2 算法实现 . ,, 3,,1 , ).5() 5(,,,,||).4();max(,).3() (max(;0,1).2(,).1()() () (停机否则输出失败信息转置若转否则输出若计算最大迭代次数,误差限,初始向量输入矩阵βλβεβλβλε←+←<<-←←= ←←k k N k y x Ay x x abs x y k N x A k k k 3 matlab 程序代码

幂法求矩阵最大特征值

幂法求矩阵最大特征值 摘要 在物理、力学和工程技术中的很多问题在数学上都归结为求矩阵特征值的问题,而在某些工程、物理问题中,通常只需要求出矩阵的最大的特征值(即主特征值)和相应的特征向量,对于解这种特征值问题,运用幂法则可以有效的解决这个问题。 幂法是一种计算实矩阵A的最大特征值的一种迭代法,它最大的优点是方法简单。对于稀疏矩阵较合适,但有时收敛速度很慢。 用java来编写算法。这个程序主要分成了三个大部分:第一部分为将矩阵转化为线性方程组;第二部分为求特征向量的极大值;第三部分为求幂法函数块。其基本流程为幂法函数块通过调用将矩阵转化为线性方程组的方法,再经过一系列的验证和迭代得到结果。 关键词:幂法;矩阵最大特征值;j ava;迭代

POWER METHOD TO CALCULATE THE MAXIMUM EIGENV ALUE MATRIX ABSTRACT In physics, mechanics and engineering technology of a lot of problems in math boil down to matrix eigenvalue problem, and in some engineering, physical problems, usually only the largest eigenvalue of the matrix (i.e., the main characteristics of the value) and the corresponding eigenvectors, the eigenvalue problem for solution, using the power law can effectively solve the problem. Power method is A kind of computing the largest eigenvalue of real matrix A of an iterative method, its biggest advantage is simple.For sparse matrix is right, but sometimes very slow convergence speed. Using Java to write algorithms.This program is mainly divided into three most: the first part for matrix can be converted to linear equations;The second part is the eigenvector of the maximum;The third part is the exponentiation method of function block.Its basic process as a power law function block by calling the method of matrix can be converted to linear equations, then after a series of validation and iteration to get the results. Key words: Power method; Matrix eigenvalue; Java; The iteration

北航数值分析1-Jacobi法计算矩阵特征值

准备工作 ?算法设计 矩阵特征值的求法有幂法、Jacobi法、QR法等,其中幂法可求得矩阵按模最大的特征值(反幂法可求得按模最小特征值),Jacobi法则可以求得对称阵的所有特征值。 分析一:由题目中所给条件λ1≤λ2≤…≤λn,可得出λ1、λn按模并不一定严格小于或大于其他特征值,且即使按模严格小于或大于其他特征值,也极有可能出现|λs|<λ1|<|λn |或|λs|<λn|<|λ1 |的情况,导致按幂法和反幂法无法求解λ1或λn二者中的一者; 分析二:题目要求求解与数μk =λ1+k(λn-λ1)/40最接近的特征值λik(k=1,2,3…39),这个问题其实可以转换为求A-μk 按模最小的特征值的问题,但因为在第一个问题中无法确定能肯定的求得λ1和λn,所以第二个问题暂先搁浅; 分析三:cond(A) 2 = ||A|| * ||A-1|| =|λ|max * |λ|min,这可以用幂法和反幂法求得,det(A) =λ1 *λ2 * … *λn,这需要求得矩阵A的所有特征值。 由以上分析可知,用幂法和反幂法无法完成所有问题的求解,而用Jacobi法求得矩阵所有特征值后可以求解题目中所给的各个问题。所以该题可以用Jacobi法求解。 ?模块设计 由 ?数据结构设计 由于矩阵是对称阵,上下带宽均为2,所以可以考虑用二维数组压缩存储矩阵上半带或下半带。但由于Jacobi法在迭代过程中会破坏矩阵的形态,所以原来为零的元素可能会变为非零,这就导致原来的二维数组无法存储迭代后的矩阵。基于此的考虑,决定采用一维数组存储整个下三角阵,以此保证迭代的正确进行。 完整代码如下(编译环境windows10 + visual studio2010):

幂法和反幂法的matlab实现

幂法和反幂法的matlab实现

幂法求矩阵主特征值及对应特征向量 摘要 矩阵特征值的数值算法,在科学和工程技术中很多问题在数学上都归结为矩阵的特征值问题,所以说研究利用数学软件解决求特征值的问题是非常必要的。实际问题中,有时需要的并不是所有的特征根,而是最大最小的实特征根。称模最大的特征根为主特征值。 幂法是一种计算矩阵主特征值(矩阵按模最大的特征值)及对应特征向量的迭代方法,它最大的优点是方法简单,特别适用于大型稀疏矩阵,但有时收敛速度很慢。 用java来编写算法。这个程序主要分成了四个大部分:第一部分为将矩阵转化为线性方程组;第二部分为求特征向量的极大值;第三部分为求幂法函数块;第四部分为页面设计及事件处理。其基本流程为幂法函数块通过调用将矩阵转化为线性方程组的方法,再经过一系列的验证和迭代得到结果。

关键字:主特征值;特征向量;线性方程组;幂法函数块 POWER METHOD FOR FINDING THE EIGENVALUES AND CORRESPONDING EIGENVECTORS OF THE MATRIX ABSTRACT Numerical algorithm for the eigenvalue of matrix, in science and engineering technology, a

lot of problems in mathematics are attributed matrix characteristic value problem, so that studies using mathematical software to solve the eigenvalue problem is very necessary. In practical problems, sometimes need not all eigenvalues, but the maximum and minimum eigenvalue of real. The characteristic value of the largest eigenvalue of the modulus maximum. Power method is a calculation of main features of the matrix values (matrix according to the characteristics of the largest value) and the corresponding eigenvector of iterative method. It is the biggest advantage is simple method, especially for large sparse matrix, but sometimes the convergence speed is very slow. Using java to write algorithms. This program is divided into three parts: the first part is the matrix is transformed into linear equations; the second part for the sake of feature vector of the maximum; the third part is

带原点平移的反幂法解特征值

书P65 5、已知矩阵???? ??????----=43033101 3A 的一个特征值为5≈λ,试用反幂法求λ和相应的特征向量,要求.104 11 11-----≤-k k k βββ 解:根据原点平移的反幂法,先分解矩阵: LU I A =???? ? ??-----=-1303810185 L = 1.0000 0 0 -0.1250 1.0000 0 0 0.3810 1.0000 U = -8.0000 1.0000 0 0 -7.8750 -3.0000 0 0 0.1429 (1)取初始向量T u )0,0,1(0= 解方程组001)5(u y u I A ==- 解得=1u (-0.1111 0.1111 -0.3333)T

T u u y) 9045 .0 , 3015 .0 , 3015 .0 ( 2 1 1 1 - - = = (2)再解方程组 1 2 ) 5 (y u I A= - 解得= 2 u(0.3685 2.6465 -7.0350)T T u u y) 93484 .0 , 35168 .0 , 04896 .0( 2 2 2 2 - = = (3)再解方程组 2 3 ) 5 (y u I A= - 解得= 3 u(0.3452 2.8110 -7.4980)T T u u y) 93549 .0 , 35072 .0 , 04307 .0( 2 3 3 3 - = = (4)再解方程组 3 4 ) 5 (y u I A= - 解得= 4 u(0.3460 2.8112 -7.4980)T T u u y) 93548 .0 , 3507 .0 , 04317 .0( 2 4 4 4 - = = 所以 015150 .8 ) 4980 .7 , 8112 .2, 3460 .0( ) 93549 .0 , 35072 .0, 04307 .0( 4 3 4 = - ? - = = T T u y β 特征值12476 .5 5 1 4 = + ≈-β λ 特征向量 T u u y x) 93549 .0 , 35072 .0 , 04307 .0( 2 3 3 3 - = = ≈

数值方法课程设计幂法反幂法计算矩阵特征值和特征向量附Matlab程序

数值方法课程设计幂法反幂法计算矩阵特征值和特征向量附Matlab程序

矩阵的特征值与特征向量的计算 摘要 物理,力学,工程技术中的很多问题在数学上都归结于求矩阵特征值的问题,例如振动问题(桥梁的振动,机械的振动,电磁振动等)、物理学中某些临界值的确定问题以及理论物理中的一些问题。矩阵特征值的计算在矩阵计算中是一个很重要的部分,本文使用幂法和反幂法分别求矩阵的按模最大,按模最小特征向量及对应的特征值。 幂法是一种计算矩阵主特征值的一种迭代法,它最大的优点是方法简单,对于稀疏矩阵比较合适,但有时收敛速度很慢。其基本思想是任取一个非零的初始向量。由所求矩阵构造一向量序列。再经过所构造的向量序列求出特征值和特征向量。 反幂法用来计算矩阵按模最小特征向量及其特征值,及计算对应于一个给定近似特征值的特征向量。本文中主要使用反幂法计算一个矩阵的按模最小特征向量及其对应的特征值。计算矩阵按模最小特征向量的基本思想是将其转化为求逆矩阵的按模最大特征向量。然后经过这个按模最大的特征向量反推出原矩阵的按模最小特征向量。

关键词:矩阵;特征值;特征向量;冥法;反冥法 THE CALCULATIONS OF EIGENVALUE AND EIGENVECTOR OF MATRIX ABSTRACT Physics, mechanics, engineering technology in a lot of problems in mathematics are attributed to matrix eigenvalue problem, such as vibration (vibration of the bridge, mechanical vibration, electromagnetic vibration, etc.) in physics, some critical values determine problems and

数值方法课程设计报告幂法反幂法计算矩阵特征值和特征向量-附Matlab程序

矩阵的特征值与特征向量的计算 摘要 物理,力学,工程技术中的很多问题在数学上都归结于求矩阵特征值的问题,例如振动问题(桥梁的振动,机械的振动,电磁振动等)、物理学中某些临界值的确定问题以及理论物理中的一些问题。矩阵特征值的计算在矩阵计算中是一个很重要的部分,本文使用幂法和反幂法分别求矩阵的按模最大,按模最小特征向量及对应的特征值。 幂法是一种计算矩阵主特征值的一种迭代法,它最大的优点是方法简单,对于稀疏矩阵比较合适,但有时收敛速度很慢。其基本思想是任取一个非零的初始向量。由所求矩阵构造一向量序列。再通过所构造的向量序列求出特征值和特征向量。 反幂法用来计算矩阵按模最小特征向量及其特征值,及计算对应于一个给定近似特征值的特征向量。本文中主要使用反幂法计算一个矩阵的按模最小特征向量及其对应的特征值。计算矩阵按模最小特征向量的基本思想是将其转化为求逆矩阵的按模最大特征向量。然后通过这个按模最大的特征向量反推出原矩阵的按模最小特征向量。 关键词:矩阵;特征值;特征向量;冥法;反冥法

THE CALCULATIONS OF EIGENVALUE AND EIGENVECTOR OF MATRIX ABSTRACT Physics, mechanics, engineering technology in a lot of problems in mathematics are attributed to matrix eigenvalue problem, such as vibration (vibration of the bridge, mechanical vibration, electromagnetic vibration, etc.) in physics, some critical values determine problems and theoretical physics in some of the problems. Matrix eigenvalue calculation is a very important part in matrix putation. In this paper, we use the power method and inverse power method to calculate the maximum of the matrix, according to the minimum characteristic vector and the corresponding characteristic value. Power method is an iterative method to calculate the eigenvalues of a matrix. It has the advantage that the method is simple and suitable for sparse matrices, but sometimes the convergence rate is very slow. The basic idea is to take a non - zero initial vector. Construct a vector sequence from the matrix of the matrix. Then the eigenvalues and eigenvectors are obtained by using the constructed vector sequence. The inverse power method is used to calculate the minimum feature vectors and their eigenvalues of the matrix, and to calculate the eigenvalues of the matrix. In this paper, we use

幂法是求方阵最大特征值及对应特征向量

幂法是求方阵的最大特征值及对应特征向量 幂法 设A n 有n 个线性相关的特征向量v 1,v 2,…,v n ,对应的特征值λ1,λ2,…,λn ,满足 |λ1| > |λ2| ≥ …≥ |λn | (3.2.1) 1. 基本思想 因为{v 1,v 2,…,v n }为C n 的一组基,所以任给x (0) ≠ 0,∑==n i i i v a x 1)0( —— 线性表示 所以有 ])( [)(2111111 1)0(∑∑∑∑====+====n i i i k i k n i k k i i n i i k i n i i i k k v a v a v a v A a v a A x A λλλλ 若a 1 ≠ 0,则因11 <λλi 知,当k 充分大时 A (k )x (0) ≈ λ1k a 1v 1 = cv 1 属λ1的特征向量 另一方面,记max(x ) = x i ,其中|x i | = ||x ||∞,则当k 充分大时, 111111*********)0(1)0()max()max()max()max()max()max(λλλλλ==≈---v a v a v a v a x A x A k k k k k k 若a 1 = 0,则因舍入误差的影响,会有某次迭代向量在v 1方向上的分量不为0,迭代下去可求得λ1及对应特征向量的近似值。 2. 规范化 在实际计算中,若|λ1| > 1则|λ1k a 1| →∞,若|λ1| < 1则| λ1k a 1| → 0都将停机。 须采用“规范化”的方法 ???? ?==+)()1()() ()()max(k k k k k Ay x x x y , k = 0,1,2,… 定理3.2-1 任给初始向量0)0(≠x 有,?????==∞→∞ →特征值 特征向量1)(11)()max(lim )max(lim λk k k k x v v y 证明:

相关文档
最新文档