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 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
function test5
%TEST5 test cs_add
%
% Example:
% test5
% See also: testall
% CXSparse, Copyright (c) 2006-2022, Timothy A. Davis. All Rights Reserved.
% SPDX-License-Identifier: LGPL-2.1+
rand ('state', 0) ;
for trial = 1:200
m = fix (100 * rand (1)) ;
n = fix (100 * rand (1)) ;
d = rand (1) ;
A = sprandn (m,n,d) ;
B = sprandn (m,n,d) ;
if (~ispc)
if (mod (trial, 4) == 0)
A = A + 1i*sprand(A) ;
end
if (mod (trial, 2) == 0)
B = B + 1i*sprand(B) ;
end
end
C = A+B ;
D = cs_add (A,B) ;
err = nnz (spones (C) - spones (D)) ;
if (err > 0)
error ('nz!') ;
end
err = norm (C-D,1) ;
fprintf ('m %3d n %3d nnz(A) %6d nnz(B) %6d nnz(C) %6d err %g\n', ...
m, n, nnz(A), nnz(B), nnz(C), err) ;
if (err > 1e-12)
error ('!') ;
end
alpha = pi ;
beta = 3 ;
if (~ispc)
if (rand () > .5)
alpha = alpha + rand ( ) * 1i ;
end
if (rand () > .5)
beta = beta + rand ( ) * 1i ;
end
end
C = alpha*A+B ;
D = cs_add (A,B,alpha) ;
err = nnz (spones (C) - spones (D)) ;
if (err > 0)
error ('nz!') ;
end
err = norm (C-D,1) ;
fprintf ('m %3d n %3d nnz(A) %6d nnz(B) %6d nnz(C) %6d err %g\n', ...
m, n, nnz(A), nnz(B), nnz(C), err) ;
if (err > 1e-12)
error ('!') ;
end
C = alpha*A + beta*B ;
D = cs_add (A,B,alpha,beta) ;
err = nnz (spones (C) - spones (D)) ;
if (err > 0)
error ('nz!') ;
end
err = norm (C-D,1) ;
fprintf ('m %3d n %3d nnz(A) %6d nnz(B) %6d nnz(C) %6d err %g\n', ...
m, n, nnz(A), nnz(B), nnz(C), err) ;
if (err > 1e-12)
error ('!') ;
end
end
|