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
|
//------------------------------------------------------------------------------
// GxB_Vector_sort: sort the values in a vector
//------------------------------------------------------------------------------
// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
//------------------------------------------------------------------------------
#include "GB.h"
#include "GB_sort.h"
GrB_Info GxB_Vector_sort
(
// output:
GrB_Vector w, // vector of sorted values
GrB_Vector p, // vector containing the permutation
// input
GrB_BinaryOp op, // comparator op
GrB_Vector u, // vector to sort
const GrB_Descriptor desc
)
{
//--------------------------------------------------------------------------
// check inputs
//--------------------------------------------------------------------------
GB_WHERE1 ("GxB_Vector_sort (w, p, op, u, desc)") ;
GB_BURBLE_START ("GxB_Vector_sort") ;
GB_RETURN_IF_NULL_OR_FAULTY (op) ;
GB_RETURN_IF_NULL_OR_FAULTY (u) ;
ASSERT (GB_VECTOR_OK (u)) ;
//--------------------------------------------------------------------------
// sort the vector
//--------------------------------------------------------------------------
GrB_Info info = GB_sort ((GrB_Matrix) w, (GrB_Matrix) p, op,
(GrB_Matrix) u, true, Context) ;
GB_BURBLE_END ;
return (info) ;
}
|