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 test15
%TEST15 test cs_amd
%
% Example:
% test15
% See also: testall
% CXSparse, Copyright (c) 2006-2022, Timothy A. Davis. All Rights Reserved.
% SPDX-License-Identifier: LGPL-2.1+
rand ('state', 0) ;
randn ('state', 0) ;
clf
for trials = 1:100
n = fix (200 * rand (1)) ;
d = 0.05 * rand (1) ;
A = sprandn (n, n, d) ;
% add a randomly placed dense column
k = fix (n * rand (1)) ;
k = max (1, k) ;
k = min (n, k) ;
if (n > 0)
A (:,k) = 1 ;
end
if (~ispc)
if (rand ( ) > .5)
A = A + 1i * sprand (A) ;
end
end
try
p0 = amd (A) ;
catch
p0 = symamd (A) ;
end
p1 = cs_amd (A) ;
if (any (sort (p1) ~= 1:n))
error ('not perm!') ;
end
C = A+A' + speye (n) ;
lnz0 = sum (symbfact (C (p0,p0))) ;
lnz1 = sum (symbfact (C (p1,p1))) ;
subplot (1,3,1) ; spy (C)
subplot (1,3,2) ; spy (C (p0,p0))
subplot (1,3,3) ; spy (C (p1,p1))
fprintf ('n %4d nz %6d lnz %6d %6d\n', n, nnz(A), lnz0, lnz1) ;
drawnow
end
|