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
|
function A = GB_spec_random (m, n, d, scale, type, is_csc,is_hyper,hyper_switch)
%GB_SPEC_RANDOM generate random matrix
%
% A = GB_spec_random (m, n, d, scale, type, is_csc, is_hyper, hyper_switch)
%
% m,n,d: parameters to sprandn (m,n,d)
% m,n: defaults to 4
% d: defaults to 0.5. If d = inf, A is fully populated.
% scale: a double scalar, defaults to 1.0
% type: a string; defaults to 'double'
% is_csc: true for CSC, false for CSR; defaults to true
% is_hyper: false for non-hypersparse, true for hypersparse, default false
% SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
% SPDX-License-Identifier: Apache-2.0
if (nargin < 1)
m = 4 ;
end
if (nargin < 2)
n = 4 ;
end
if (nargin < 3)
d = 0.5 ;
end
if (nargin < 4)
scale = 1 ;
end
if (nargin < 5)
type = 'double' ;
end
if (nargin >= 6)
A.is_csc = is_csc ;
end
if (nargin >= 7 && ~isempty (is_hyper))
A.is_hyper = is_hyper ;
end
if (nargin >= 8)
A.hyper_switch = hyper_switch ;
end
if (isinf (d))
A.matrix = scale * sparse (rand (m, n)) ;
else
A.matrix = scale * sprandn (m, n, d) ;
end
if (test_contains (type, 'complex'))
if (isinf (d))
A.matrix = A.matrix + 1i * scale * sparse (rand (m, n)) ;
else
A.matrix = A.matrix + 1i * scale * sprandn (m, n, d) ;
end
end
A.class = type ;
A.pattern = logical (spones (A.matrix)) ;
A.iso = false ;
|