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
|
function test11
%TEST11 test cs_rowcnt
%
% Example:
% test11
% 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)) ;
f = f (1:200) ;
for i = f
Prob = ssget (i, index) ;
disp (Prob) ;
A = Prob.A ;
[m n] = size (A) ;
if (m ~= n)
continue
end
A = spones (A) ;
A = A+A' + speye(n) ;
if (~ispc)
if (rand ( ) > .5)
A = A + 1i * sprand (A) ;
end
end
[cc h pa po R] = symbfact (A) ;
rc1 = full (sum (R)) ;
rc2 = cs_rowcnt (A, pa, po) ;
if (any (rc1 ~= rc2))
error ('!') ;
end
try
p = amd (A) ;
catch
p = symamd (A) ;
end
A = A (p,p) ;
[cc h pa po R] = symbfact (A) ;
rc1 = full (sum (R)) ;
rc2 = cs_rowcnt (A, pa, po) ;
if (any (rc1 ~= rc2))
error ('!') ;
end
end
|