/*! * Copyright (c) 2018 by Contributors * \file c_api_common.h * \brief DGL C API common util functions */ #ifndef DGL_C_API_COMMON_H_ #define DGL_C_API_COMMON_H_ #include #include #include #include #include #include #include using dgl::runtime::operator<<; /*! \brief Output the string representation of device context.*/ inline std::ostream& operator << (std::ostream& os, const DLContext& ctx) { return os << ctx.device_type << ":" << ctx.device_id; } namespace dgl { // Communicator handler type typedef void* CommunicatorHandle; // KVstore message handler type typedef void* KVMsgHandle; /*! \brief Enum type for bool value with unknown */ enum BoolFlag { kBoolUnknown = -1, kBoolFalse = 0, kBoolTrue = 1 }; /*! * \brief Convert a vector of NDArray to PackedFunc. */ dgl::runtime::PackedFunc ConvertNDArrayVectorToPackedFunc( const std::vector& vec); /*! * \brief Copy a vector to an int64_t NDArray. * * The element type of the vector must be convertible to int64_t. */ template dgl::runtime::NDArray CopyVectorToNDArray( const std::vector& vec) { using dgl::runtime::NDArray; const int64_t len = vec.size(); NDArray a = NDArray::Empty({len}, DLDataType{kDLInt, 64, 1}, DLContext{kDLCPU, 0}); std::copy(vec.begin(), vec.end(), static_cast(a->data)); return a; } runtime::PackedFunc ConvertEdgeArrayToPackedFunc(const EdgeArray& ea); } // namespace dgl #endif // DGL_C_API_COMMON_H_