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
|
//------------------------------------------------------------------------------
// gbisequal: isequal (A,B)
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
// gbisequal returns isequal(A,B) for two matrices A and B.
// Usage:
// result = gbisequal (A,B)
#include "gb_interface.h"
#define USAGE "usage: s = GrB.isequal (A, B)"
void mexFunction
(
int nargout,
mxArray *pargout [ ],
int nargin,
const mxArray *pargin [ ]
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
gb_usage (nargin == 2 && nargout <= 1, USAGE) ;
//--------------------------------------------------------------------------
// get the arguments
//--------------------------------------------------------------------------
GrB_Matrix A = gb_get_shallow (pargin [0]) ;
GrB_Matrix B = gb_get_shallow (pargin [1]) ;
//--------------------------------------------------------------------------
// check if they are equal
//--------------------------------------------------------------------------
pargout [0] = mxCreateLogicalScalar (gb_is_equal (A, B)) ;
//--------------------------------------------------------------------------
// free shallow copies
//--------------------------------------------------------------------------
OK (GrB_Matrix_free (&A)) ;
OK (GrB_Matrix_free (&B)) ;
GB_WRAPUP ;
}
|