/*! * 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 /*! \brief Check whether two data types are the same.*/ inline bool operator == (const DLDataType& ty1, const DLDataType& ty2) { return ty1.code == ty2.code && ty1.bits == ty2.bits && ty1.lanes == ty2.lanes; } /*! \brief Output the string representation of device context.*/ inline std::ostream& operator << (std::ostream& os, const DLDataType& ty) { return os << "code=" << ty.code << ",bits=" << ty.bits << "lanes=" << ty.lanes; } /*! \brief Check whether two device contexts are the same.*/ inline bool operator == (const DLContext& ctx1, const DLContext& ctx2) { return ctx1.device_type == ctx2.device_type && ctx1.device_id == ctx2.device_id; } /*! \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; /*! \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 Return whether the array is a valid 1D int array*/ inline bool IsValidIdArray(const dgl::runtime::NDArray& arr) { return arr->ndim == 1 && arr->dtype.code == kDLInt; } /*! * \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; } } // namespace dgl #endif // DGL_C_API_COMMON_H_