1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
|
function R = qr_givens (A)
%QR_GIVENS Givens-rotation QR factorization.
% Example:
% R = qr_givens (A)
% See also: cs_demo
% CXSparse, Copyright (c) 2006-2022, Timothy A. Davis. All Rights Reserved.
% SPDX-License-Identifier: LGPL-2.1+
[m n] = size (A) ;
parent = cs_etree (sparse (A), 'col') ;
A = full (A) ;
for i = 2:m
k = min (find (A (i,:))) ; %#ok
if (isempty (k))
continue ;
end
while (k > 0 & k <= min (i-1,n)) %#ok
A ([k i],k:n) = givens2 (A(k,k), A(i,k)) * A ([k i],k:n) ;
A (i,k) = 0 ;
k = parent (k) ;
end
end
R = sparse (A) ;
|