LU factorization with decreasing elements on the main diagonal of U
Show older comments
Does
select P so that
is decreasing?
If not, how can I request it?
Answers (1)
Bruno Luong
on 25 Sep 2023
Edited: Bruno Luong
on 25 Sep 2023
Obviously not
A=[1 10 9;
5 1 9;
2 8 1]
[L,U,P]=lu(A)
But you can fix the progression of abs(diag(U)) in any arbitray decrasing sequance you want, just scale appropiately L.
Here I select the sequene of U(1,1).*2.^(-(1:n-1))
% Fix it, assuming A is not singular
Ukk = abs(U(1,1));
for k=2:size(U,1)
s = Ukk/(2*abs(U(k,k)));
U(k,:) = s*U(k,:);
L(:,k) = L(:,k)/s;
Ukk = abs(U(k,k));
end
L
U
P'*L*U % close to A
In some sense the question of scaling U alone is trivial and sort of useless if you don't specify what L should be.
Note that MATLAB returns L such that diag(L) are 1.
5 Comments
Sara
on 25 Sep 2023
Bruno Luong
on 25 Sep 2023
Then it is not possible in general.
If you need similar property, use qr with permutation.
I'll give you a simple counter example where no permutation can achieve what you ask for. The example is 2 x 2, there is 2 pemutations of 1:2, both them don't provide U with absolute values of the diagonal decreasing.
In both case the diagonal od U is [1,2]; which is non decreasing
Note that once you impose P, and diag(L)=1, the LU factorization is unique.
A = [1 0; 0 2]
p = perms(1:2);
for k=1:size(p,1)
P = eye(2);
P = P(:,p(k,:));
[L,U] = lu(P*A)
end
% and of course
[L,U,P] = lu(A)
Sara
on 25 Sep 2023
Bruno Luong
on 25 Sep 2023
No
Categories
Find more on Operating on Diagonal Matrices in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!