列主元Gauss消去法对于某电路的分析,归结为求解线性方程组
RI?V。其中
00?10000??31?130???1335?90?110000???0?931?1000000???00?1079?30000?9??R??000?3057?70?50?
??000?747?3000??0?00000?304100???000?50027?2??0?000?9000?229???VT???15,27,?23,0,?20,12,?7,7,10?
(1) 编制解n阶线性方程组Ax?b的列主元高斯消去法的通用程序; (2) 用所编程序线性方程组RIT?V,并打印出解向量,保留5位有效数;
二、通用程序
%% 列主元Gauss消去法求解线性方程组%% %%参数输入
n=input('Please input the order of matrix A: n='); %输入线性方程组阶数n b=zeros(1,n);
A=input('Input matrix A (such as a 2 order matrix:[1 2;3,4]) :'); b(1,:)=input('Input the column vector b:'); %输入行向量b b=b';
C=[A,b]; %得到增广矩阵 %%列主元消去得上三角矩阵
for i=1:n-1 [maximum,index]=max(abs(C(i:n,i))); index=index+i-1; T=C(index,:); C(index,:)=C(i,:); C(i,:)=T;
for k=i+1:n %%列主元消去 if C(k,i)~=0
C(k,:)=C(k,:)-C(k,i)/C(i,i)*C(i,:); end end end
%% 回代求解 %% x=zeros(n,1); x(n)=C(n,n+1)/C(n,n); for i=n-1:-1:1
x(i)=(C(i,n+1)-C(i,i+1:n)*x(i+1:n,1))/C(i,i); end
A=C(1:n,1:n); %消元后得到的上三角矩阵 disp('The upper teianguular matrix is:') for k=1:n
fprintf('%f ',A(k,:)); fprintf('\\n'); end
disp('Solution of the equations:');
fprintf('%.5g\\n',x); %以5位有效数字输出结果
以教材第123页习题16验证通用程序的正确性。执行程序,输入系数矩阵A和列向量b,结果如下:
Please input the order of matrix A: n=4 Input matrix A (such as a 2 order matrix:[1 2;3,4])[1 2 1 -2 2 5 3 -2 -2 -2 3 5 1 3 2 3] Input the column vector b:[4 7 -1 0] Solution of the equations: 2 -1 2 -1 结果与精确解完全一致。 三、求解结果
执行程序,输入矩阵A(即题中的矩阵R)和列向量b(即题中的V),得如下结果:
Please input the order of matrix A: n=9 Input matrix A (such as a 2 order matrix:[1 2;3,4]):[31 -13 0 0 0 -10 0 0 0 -13 35 -9 0 -11 0 0 0 0 0 -9 31 -10 0 0 0 0 0 0 0 -10 79 -30 0 0 0 -9 0 0 0 -30 57 -7 0 -5 0 0 0 0 0 -7 47 -30 0 0 0 0 0 0 0 -30 41 0 0 0 0 0 0 -5 0 0 27 -2 0 0 0 -9 0 0 0 -2 29]
由上述结果得:一、题目
第四章
二、通用程序