1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
function test_qr1
%TEST_QR1 test QR factorizations
%
% Example:
% test_qr1
% See also: testall
% CXSparse, Copyright (c) 2006-2022, Timothy A. Davis. All Rights Reserved.
% SPDX-License-Identifier: LGPL-2.1+
index = ssget ;
[ignore f] = sort (max (index.nrows, index.ncols)) ;
for i = f
Prob = ssget (i,index) ;
A = Prob.A ;
if (~isreal (A))
continue ;
end
[m n] = size (A) ;
if (m < n)
A = A' ;
end
t0 = 0 ;
k0 = 0 ;
while (t0 < 0.1)
tic
q = colamd (A, [-1 10]) ;
% [Q,R] = qr (A (:,q)) ;
R = qr (A (:,q)) ; %#ok
t = toc ;
t0 = t0 + t ;
k0 = k0 + 1 ;
end
t0 = t0 / k0 ;
t1 = 0 ;
k1 = 0 ;
while (t1 < 0.1)
tic
[V,beta, p, R,q] = cs_qr (A) ; %#ok
t = toc ;
t1 = t1 + t ;
k1 = k1 + 1 ;
end
t1 = t1 / k1 ;
fprintf (...
'%25s MATLAB: %10.4f (%8d) CS: %10.4f (%8d) speedup: %8.2f\n', ...
Prob.name, t0, k0, t1, k1, t0/t1) ;
end
|