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 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
//------------------------------------------------------------------------------
// GrB_Matrix_serialize: copy a matrix into a serialized array of bytes
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
// serialize a GrB_Matrix into a blob of bytes
// This method is similar to GxB_Matrix_serialize. In contrast with the GrB*
// method, this method requires the user application to allocate the blob
// first, which must be non-NULL on input. The required size of the blob is
// computed by GrB_Matrix_serializeSize. Example usage:
/*
void *blob = NULL ;
GrB_Index blob_size = 0 ;
GrB_Matrix A, B = NULL ;
// construct a matrix A, then serialized it:
GrB_Matrix_serializeSize (&blob_size, A) ; // loose upper bound
blob = malloc (blob_size) ; // user mallocs the blob
GrB_Matrix_serialize (blob, &blob_size, A) ; // returns actual size
blob = realloc (blob, blob_size) ; // user can shrink the blob
GrB_Matrix_deserialize (&B, atype, blob, blob_size) ;
free (blob) ; // user frees the blob
*/
#include "GB.h"
#include "GB_serialize.h"
GrB_Info GrB_Matrix_serialize // serialize a GrB_Matrix to a blob
(
// output:
void *blob, // the blob, already allocated in input
// input/output:
GrB_Index *blob_size_handle, // size of the blob on input. On output,
// the # of bytes used in the blob.
// input:
GrB_Matrix A // matrix to serialize
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
GB_WHERE1 ("GrB_Matrix_serialize (blob, &blob_size, A)") ;
GB_BURBLE_START ("GrB_Matrix_serialize") ;
GB_RETURN_IF_NULL (blob) ;
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 into the preallocated blob
//--------------------------------------------------------------------------
size_t blob_size = (size_t) (*blob_size_handle) ;
GrB_Info info = GB_serialize ((GB_void **) &blob, &blob_size, A, method,
Context) ;
if (info == GrB_SUCCESS)
{
(*blob_size_handle) = (GrB_Index) blob_size ;
}
GB_BURBLE_END ;
#pragma omp flush
return (info) ;
}
|