For Ax=b, How do I make LU decomposition (A=L*U) without using lu function. For example, A is nxn matrix and bis nx1 matrix.

5 ビュー (過去 30 日間)
clc
clear
A=rand(5)
b=rand(5,1);
A(2:3,1)
n=length(A)
U=A;
for i=1:n
k=i+1
i
U(k:n,i)=U(k:n,i)-U(i,i)*(U(k:n,i)/U(i,i))
end
for k= 1:n
L(k+1:n,k)=A(k+1:n,k)/A(k,k)
end
This is what I have try so far, I am very new to MATLAB like 2 week and genuinely struggle here.

採用された回答

David Hill
David Hill 2020 年 9 月 5 日
function [L,U] = mylu(A)
n = size(A,1);
for k = 1:n
if A(k,k)==0
warning('LU factorization fails');
L = []; U = []; return;
end
i = k+1:n;
A(i,k) = A(i,k)/A(k,k);
A(i,i) = A(i,i)-A(i,k)*A(k,i);
end
L = tril(A,-1)+eye(n); U = triu(A);

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLinear Algebra についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by