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
|
//------------------------------------------------------------------------------
// GB_block: apply all pending computations if blocking mode enabled
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
#include "GB_Pending.h"
#define GB_FREE_ALL ;
GB_PUBLIC
GrB_Info GB_block // apply all pending computations if blocking mode enabled
(
GrB_Matrix A,
GB_Context Context
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
GrB_Info info ;
ASSERT (A != NULL) ;
//--------------------------------------------------------------------------
// wait if mode is blocking, or if too many pending tuples
//--------------------------------------------------------------------------
if (!(GB_ANY_PENDING_WORK (A) || GB_NEED_HYPER_HASH (A)))
{
// no pending work, so no need to block
return (GrB_SUCCESS) ;
}
double npending = (double) GB_Pending_n (A) ;
double anzmax = ((double) A->vlen) * ((double) A->vdim) ;
bool many_pending = (npending >= anzmax) ;
GrB_Mode mode = GB_Global_mode_get ( ) ;
bool blocking = (mode == GrB_BLOCKING || mode == GxB_BLOCKING_GPU) ;
if (many_pending || blocking)
{
// delete any lingering zombies, assemble any pending tuples,
// sort the vectors, and construct the A->Y hyper_hash
GB_OK (GB_wait (A, "matrix", Context)) ;
GB_OK (GB_hyper_hash_build (A, Context)) ;
}
return (GrB_SUCCESS) ;
}
|