Skip to content

Files

This branch is 827 commits behind DrTimothyAldenDavis/GraphBLAS:stable.

Test

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Apr 19, 2023
Jun 29, 2021
Mar 21, 2024
Mar 21, 2024
May 1, 2023
May 1, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 20, 2023
May 11, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 12, 2023
Apr 19, 2023
Apr 19, 2023
May 4, 2023
May 4, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Dec 26, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 2, 2023
Apr 27, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 27, 2023
May 2, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 7, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 11, 2023
May 11, 2023
May 8, 2023
May 11, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Jan 10, 2024
May 8, 2023
Feb 16, 2024
May 8, 2023
Feb 16, 2024
May 8, 2023
May 8, 2023
Mar 21, 2024
May 11, 2023
May 8, 2023
May 8, 2023
May 8, 2023
May 8, 2023
Mar 21, 2024
May 11, 2023
May 11, 2023
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Feb 16, 2024
May 8, 2023
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
May 8, 2023
Jan 10, 2024
May 8, 2023
Jan 10, 2024
May 8, 2023
Mar 21, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 11, 2023
May 3, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
May 2, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Jan 10, 2024
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 8, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 8, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 2, 2023
Apr 19, 2023
Feb 6, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 7, 2023
Apr 19, 2023
Apr 19, 2023
Apr 27, 2023
May 7, 2023
Apr 19, 2023
May 12, 2023
Apr 29, 2023
Apr 19, 2023
Apr 19, 2023
May 8, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Mar 21, 2024
Apr 19, 2023
Apr 19, 2023
May 11, 2023
Apr 19, 2023
Apr 22, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
May 1, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
Apr 27, 2023
Apr 27, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
May 7, 2023
Apr 27, 2023
Apr 27, 2023
May 4, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 19, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 27, 2023
Apr 19, 2023
Apr 27, 2023
Apr 27, 2023
May 4, 2023
Apr 27, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Oct 8, 2023
Apr 19, 2023
Apr 27, 2023
Oct 8, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 27, 2023
Apr 27, 2023
May 1, 2023
Apr 29, 2023
May 12, 2023
May 3, 2023
May 8, 2023
May 8, 2023
May 2, 2023
May 8, 2023
May 8, 2023
May 8, 2023
May 8, 2023
Oct 8, 2023
May 8, 2023
May 8, 2023
May 8, 2023
May 11, 2023
May 11, 2023
May 11, 2023
May 11, 2023
May 12, 2023
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
May 28, 2023
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Jan 10, 2024
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 27, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Dec 24, 2022
Apr 19, 2023
Mar 21, 2024
May 11, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
Apr 19, 2023
SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2023, All Rights Reserved.
SPDX-License-Identifier: Apache-2.0

GraphBLAS/Test:

This folder includes an *.m interface that tests each GraphBLAS
function.  It is meant for testing and development only, not for general usage.
The interface is not designed to be simple, clean, elegant, and
well-documented.  Such an interface would interfere with the purpose of these
functions, which is to compute a result in GraphBLAS (via a GB_mex_*
mexFunction) and then to compare its results with the GB_spec_*.m mimic
function.  None of the GB_mex_*.c mexFunctions have corresponding GB_mex_*.m
files to provide 'help GB_mex...' documentation.

For a usable @GrB interface to GraphBLAS, see the GraphBLAS/GraphBLAS folder,
and the @GrB object it supports.

Requirements:  the mex command must use a C compiler supporting C11.
Microft Visual Studio does not support C11 so this test is not available
on Windows unless you use another compiler.

To run the tests, use the following command in this directory, in the 
Octave Command Window:

    make ; testall

If you get a linking problem on linux, add this directory to your
LD_LIBRARY_PATH, so that the libgraphblas.so can be found by the mexFunctions.

Longer tests can be done as well (this can take a whole day):

    testall (1)

To run with malloc debugging (this will be slower):

    debug_on
    make ; testall

To turn off malloc debugging:

    debug_off

Malloc debugging is very extensive.  When enabled, the GraphBLAS wrapper
functions for malloc/calloc/realloc/free, which are mxMalloc/etc in this
interface, decrement a counter when they are been successful.  When this
reaches zero, they pretend to fail, and thus allow the out-of-memory error
handling in GraphBLAS to be tested.  If the function fails, the counter is
reset, and the test is done again.  The initial state of this counter is
increased until the function succeeds.  During this entire process, a count is
kept of malloc'd blocks, and an error is reported if a leak is found.
GraphBLAS will be very slow with malloc debugging enabled.  It is only done
through the @GrB interface and has no effect when GraphBLAS is used through a
C program.

To enable further debugging tests, see the comments in Source/GB.h.

--------------------------------------------------------------------------------
Files and folders in GraphBLAS/Test:
--------------------------------------------------------------------------------

GB_spec_*.m     'spec' scripts.  These are very concise scripts, yet they
                perfectly match the GraphBLAS spec.  They are very slow since
                they rely on built-in dense matrices, since built-in sparse
                matrices only support sparse logical, double, and double
                complex.

GB_mex_*.c      mexFunction interfaces to GraphBLAS functions.  Some of these
                are interfaces to internal functions in SuiteSparse:GraphBLAS
                that are not in the GraphBLAS spec.  All of the functions rely
                on the specific details of the SuiteSparse:GraphBLAS
                implementation of the GraphBLAS specification, and thus they
                are not suitable as general interfaces to any GraphBLAS
                implementation.

GB_mx_*.c       helper functions for the mexFunctions
GB_mex.h        include file for the mexFunctions
Template/*.c    a template file for building two mexFunctions:
                GB_mex_Matrix_build and GB_mex_Vector_build.

make.m          compiles the Test interface to GraphBLAS (links with
                dynamic -lgraphblas)

debug_off.m     turns off malloc debugging
debug_on.m      turns on malloc debugging; the interface will be *very* slow,
                since the problem is solved many times, with slowing increasing
                allotment of malloc's, until it succeeds.

stat.m          report on whether malloc debugging is enabled, and the current
                test coverage (see ../Tcov).

testall.m       a complete set of tests for GraphBLAS
testperf.m      performance tests for GraphBLAS

spok            an acronym for "sparse OK"; checks if a built-in sparse matrix
                is valid

README.txt      this file

Contents.m      list of m-files in this folder

GB_define.m     create #defines for GraphBLAS.h

GB_user_*.m     test user-defined complex type and operators

Makefile        only 'make clean' and 'make distclean'

For all other *.m files, see Contents.m for a description.