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
|
//------------------------------------------------------------------------------
// GrB_Matrix_serializeSize: return an upper bound on the blob size
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
// GrB_Matrix_serialize and GxB_Matrix_serialize both serialize a GrB_Matrix
// into a blob of bytes. This function provides an estimate of the # of bytes
// the blob would have, assuming the default method and default # of threads,
// using the dryrun option in GB_serialize.
#include "GB.h"
#include "GB_serialize.h"
GrB_Info GrB_Matrix_serializeSize // estimate the size of a blob
(
// output:
GrB_Index *blob_size_handle, // upper bound on the required size of the
// blob on output.
// input:
GrB_Matrix A // matrix to serialize
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
GB_WHERE1 ("GrB_Matrix_serializeSize (&blob_size, A)") ;
GB_BURBLE_START ("GrB_Matrix_serialize") ;
GB_RETURN_IF_NULL (blob_size_handle) ;
GB_RETURN_IF_NULL_OR_FAULTY (A) ;
// no descriptor, so assume the default method
int method = GxB_DEFAULT ;
// Context will hold the default # of threads, which can be controlled
// by GxB_Global_Option_set.
//--------------------------------------------------------------------------
// serialize the matrix
//--------------------------------------------------------------------------
size_t blob_size ;
GrB_Info info = GB_serialize (NULL, &blob_size, A, method, Context) ;
(*blob_size_handle) = (GrB_Index) blob_size ;
GB_BURBLE_END ;
#pragma omp flush
return (info) ;
}
|