File: test179.m

package info (click to toggle)
suitesparse 1%3A7.10.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 254,920 kB
  • sloc: ansic: 1,134,743; cpp: 46,133; makefile: 4,875; fortran: 2,087; java: 1,826; sh: 996; ruby: 725; python: 495; asm: 371; sed: 166; awk: 44
file content (49 lines) | stat: -rw-r--r-- 1,451 bytes parent folder | download | duplicates (2)
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
function test179
%TEST179 bitmap select

% SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2025, All Rights Reserved.
% SPDX-License-Identifier: Apache-2.0

fprintf ('test179: --------------------------------- bitmap select\n') ;

ops = { 'nonzero',  'eq_zero', 'ne_thunk', 'eq_thunk' } ;

n = 20 ;
rng ('default') ;

Cin = GB_spec_random (n, n, 0.5, 1, 'double complex') ;
A = GB_spec_random (n, n, 0.5, 1, 'double complex') ;
scalar = 3+1i ;
A.matrix  (2:3,2:4) = scalar ;
A.pattern (2:3,2:4) = true ;

for builtin = 1 % 0:1
    GB_builtin_complex_set (builtin) ;
    for sparsity_control = [1 2 4]
        Cin.sparsity = sparsity_control ;
        A.sparsity = sparsity_control ;
        for k = 1:length (ops)
            op = ops {k} ;
            C1 = GB_spec_select (Cin, [], [], op, A, scalar, []) ;
            C2 = GB_mex_select  (Cin, [], [], op, A, scalar, []) ;
            GB_spec_compare (C1, C2) ;
        end
    end
end

% try a user-defined selectop
Cin = GB_spec_random (n, n, 0.5, 1, 'double') ;
A = GB_spec_random (n, n, 0.5, 1, 'double') ;
A.matrix  (2:3,2:4) = nan ;
A.pattern (2:3,2:4) = true ;
for sparsity_control = [1 2 4]
    Cin.sparsity = sparsity_control ;
    A.sparsity = sparsity_control ;
    C1 = GB_spec_select (Cin, [], [], 'isnan', A, 0, []) ;
    C2 = GB_mex_select  (Cin, [], [], 'isnan', A) ;
    GB_spec_compare (C1, C2) ;
end

GB_builtin_complex_set (true) ;
fprintf ('\ntest179: all tests passed\n') ;