File: gbtest35.m

package info (click to toggle)
suitesparse-graphblas 7.4.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 67,112 kB
  • sloc: ansic: 1,072,243; cpp: 8,081; sh: 512; makefile: 506; asm: 369; python: 125; awk: 10
file content (43 lines) | stat: -rw-r--r-- 1,284 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
function gbtest35
%GBTEST35 test reshape (built-in variant)

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

rng ('default')

for m = 0:6
    for n = 0:10
        for kind = [0 1]
            if (kind == 0)
                A = rand (m, n) ;
            else
                A = sprand (m, n, 0.3) ;
            end
            G = GrB (A) ;
            mn = m*n ;
            if (mn == 0)
                C1 = reshape (A, n, m) ;
                C2 = reshape (G, n, m) ;
                assert (gbtest_eq (C1, C2)) ;
            else
                f = factor (mn) ;
                for k = 1:length (f)
                    S = nchoosek (f, k) ;
                    for i = 1:size(S,1)
                        m2 = prod (S (i,:)) ;
                        n2 = mn / m2 ;
                        C1 = reshape (A, m2, n2) ;
                        C2 = reshape (G, m2, n2) ;
                        assert (gbtest_eq (C1, C2)) ;
                        C1 = reshape (A, [m2 n2]) ;
                        C2 = reshape (G, [m2 n2]) ;
                        assert (gbtest_eq (C1, C2)) ;
                    end
                end
            end
        end
    end
end

fprintf ('gbtest35: all tests passed\n') ;