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
|
function test_qrsol
%TEST_QRSOL test cs_qrsol
%
% Example:
% test_qrsol
% 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)) ;
k = 0 ;
rs1 = zeros (1,0) ;
rs2 = zeros (1,0) ;
for i = f
Prob = ssget (i,index) ;
A = Prob.A ;
if (~isreal (A))
continue ;
end
[m n] = size (A) ; %#ok
b = rand (m,1) ;
x1 = A\b ;
x2 = cs_qrsol (A,b) ;
x1 (~isfinite (x1)) = 0 ;
x2 (~isfinite (x2)) = 0 ;
r1 = norm (A*x1-b) ;
r2 = norm (A*x2-b) ;
k = k + 1 ;
rs1 (k) = r1 ;
rs2 (k) = r2 ;
fprintf ('%30s MATLAB: %6.2e CS: %6.2e\n', Prob.name, r1, r2) ;
loglog (rs1, rs2, 'o') ;
drawnow
clear A b x1 x2
% pack
end
|