34 #ifndef NEKTAR_LIB_UTILITIES_COMMSERIAL_H
35 #define NEKTAR_LIB_UTILITIES_COMMSERIAL_H
45 namespace LibUtilities
83 void *sendbuf,
int sendcount,
CommDataType sendtype,
int dest,
84 void *recvbuf,
int recvcount,
CommDataType recvtype,
int source) final;
93 void *recvbuf,
int recvcount,
96 void *sendbuf,
int sendcounts[],
int sensdispls[],
97 CommDataType sendtype,
void *recvbuf,
int recvcounts[],
int rdispls[],
101 void *recvbuf,
int recvcount,
104 void *sendbuf,
int sendcount,
CommDataType sendtype,
void *recvbuf,
105 int recvcounts[],
int rdispls[],
CommDataType recvtype) final;
114 Array<
OneD,
unsigned long long> &ans) final;
117 void *recvbuf,
int recvcount,
122 void *recvbuf,
int recvcount,
127 int indegree, const
int sources[], const
int sourceweights[],
131 void *sendbuf,
int sendcounts[],
int sdispls[],
CommDataType sendtype,
132 void *recvbuf,
int recvcounts[],
int rdispls[],
163 int pColumns) override;
#define LIB_UTILITIES_EXPORT
Base communications class.
virtual std::tuple< int, int, int > v_GetVersion() final
virtual void v_SendRecvReplace(void *buf, int count, CommDataType dt, int pSendProc, int pRecvProc) final
virtual void v_Gather(void *sendbuf, int sendcount, CommDataType sendtype, void *recvbuf, int recvcount, CommDataType recvtype, int root) final
virtual CommSharedPtr v_CommCreateIf(int flag) final
virtual void v_SendRecv(void *sendbuf, int sendcount, CommDataType sendtype, int dest, void *recvbuf, int recvcount, CommDataType recvtype, int source) final
virtual void v_Bcast(void *buffer, int count, CommDataType dt, int root) final
virtual CommRequestSharedPtr v_CreateRequest(int num) final
virtual void v_Irecv(void *buf, int count, CommDataType dt, int source, CommRequestSharedPtr request, int loc) final
virtual void v_AllReduce(void *buf, int count, CommDataType dt, enum ReduceOperator pOp) final
static CommSharedPtr create(int narg, char *arg[])
Creates an instance of this class.
virtual void v_Exscan(Array< OneD, unsigned long long > &pData, const enum ReduceOperator pOp, Array< OneD, unsigned long long > &ans) final
virtual void v_SplitComm(int pRows, int pColumns) override
virtual void v_RecvInit(void *buf, int count, CommDataType dt, int source, CommRequestSharedPtr request, int loc) final
virtual void v_AlltoAllv(void *sendbuf, int sendcounts[], int sensdispls[], CommDataType sendtype, void *recvbuf, int recvcounts[], int rdispls[], CommDataType recvtype) final
virtual void v_Finalise() final
virtual void v_StartAll(CommRequestSharedPtr request) final
virtual bool v_TreatAsRankZero() override
CommSerial(int argc, char *argv[])
virtual NekDouble v_Wtime() final
static std::string className
Name of class.
virtual void v_NeighborAlltoAllv(void *sendbuf, int sendcounts[], int sdispls[], CommDataType sendtype, void *recvbuf, int recvcounts[], int rdispls[], CommDataType recvtype) final
virtual void v_Irsend(void *buf, int count, CommDataType dt, int dest, CommRequestSharedPtr request, int loc) final
virtual void v_Block() final
virtual void v_Send(void *buf, int count, CommDataType dt, int dest) final
virtual ~CommSerial() override
virtual bool v_IsSerial() override
virtual void v_WaitAll(CommRequestSharedPtr request) final
virtual void v_AllGatherv(void *sendbuf, int sendcount, CommDataType sendtype, void *recvbuf, int recvcounts[], int rdispls[], CommDataType recvtype) final
virtual void v_AlltoAll(void *sendbuf, int sendcount, CommDataType sendtype, void *recvbuf, int recvcount, CommDataType recvtype) final
virtual void v_Scatter(void *sendbuf, int sendcount, CommDataType sendtype, void *recvbuf, int recvcount, CommDataType recvtype, int root) final
virtual void v_AllGather(void *sendbuf, int sendcount, CommDataType sendtype, void *recvbuf, int recvcount, CommDataType recvtype) final
virtual void v_DistGraphCreateAdjacent(int indegree, const int sources[], const int sourceweights[], int reorder) final
virtual void v_Recv(void *buf, int count, CommDataType dt, int source) final
virtual int v_GetRank() override
virtual void v_SendInit(void *buf, int count, CommDataType dt, int dest, CommRequestSharedPtr request, int loc) final
static std::shared_ptr< DataType > AllocateSharedPtr(const Args &...args)
Allocate a shared pointer from the memory pool.
unsigned int CommDataType
std::shared_ptr< CommRequest > CommRequestSharedPtr
ReduceOperator
Type of operation to perform in AllReduce.
std::shared_ptr< Comm > CommSharedPtr
Pointer to a Communicator object.
std::shared_ptr< CommSerial > CommSerialSharedPtr
Pointer to a Communicator object.
The above copyright notice and this permission notice shall be included.