lu_decom.m

来自「数值分析中几个基础的matlab程序」· M 代码 · 共 32 行

M
32
字号
function[L,U,flag]=LU_Decom(A)
%求矩阵A的LU分解,其中
%A为要分解的矩阵
%L为单位下三角阵
%U为下三角阵
%flag为指标向量,flag='OK'表示计算成功
[n,m]=size(A)
%要求说分解的矩阵是方阵;否则停止计算,并输出出错信息
if n~=m
    error('The rows and columns of matrix A must be equal!');
    return;
end
L=eye(n);U=zeros(n);flag='OK';
for k=1:n
    for j=k:n
        z=0;
        for q=1:k-1
            z=z+L(k,q)*U(q,j);
        end
        U(k,j)=A(k,j)-z;
    end
    if abs(U(k,k))<eps
        flag='failure';return;
    end
    for i=k+1:n
        z=0;
        for q=1:k-1
            z=z+L(i,q)*U(q,k);
        end
        L(i,k)=(A(i,k)-z)/U(k,k);
    end
end

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?