File: test254.m

package info (click to toggle)
suitesparse 1%3A7.10.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, 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 (35 lines) | stat: -rw-r--r-- 957 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
function test254
%TEST254 test masks with all types

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

fprintf ('test254 ------------ C<M>=A+B with different masks\n') ;

fprintf ('jit control: %d, factory: %d\n', ...
    GB_mex_jit_control, GB_mex_factory_control) ;
rng ('default') ;

op = 'plus' ;
[~, ~, ~, types, ~, ~, ~,] = GB_spec_opsall ;
types = types.all ;

n = 20 ;
C0 = sparse (n, n) ;
A = GB_spec_random (n, n, 0.5, 100, 'double') ;
B = GB_spec_random (n, n, 0.5, 100, 'double') ;

for k = 1:length(types)
    type = types {k} ;
    M = GB_spec_random (n, n, 0.1, 100, type) ;
    M.matrix = full (M.matrix) ;
    M.matrix = GB_mex_cast (M.matrix, type) ;

    % C<M> A+B
    X2 = GB_mex_Matrix_eWiseAdd  (C0, M, [ ], op, A, B, [ ]) ;
    X1 = GB_spec_Matrix_eWiseAdd (C0, M, [ ], op, A, B, [ ]) ;
    GB_spec_compare (X1, X2) ;
end

fprintf ('test254 all tests passed\n') ;