📄 gather.c
字号:
/* (C) 2004 by Argonne National Laboratory. See COPYRIGHT in top-level directory.*/#include "collchk.h" int MPI_Gather(void* sbuff, int scnt, MPI_Datatype stype, void* rbuff, int rcnt, MPI_Datatype rtype, int root, MPI_Comm comm){ int g2g = 1, rank; char call[COLLCHK_SM_STRLEN]; int are2buffs; sprintf(call, "GATHER"); /* Check if init has been called */ g2g = CollChk_is_init(); if(g2g) { MPI_Comm_rank(comm, &rank); /* check for call consistency */ CollChk_same_call(comm, call); /* check for root consistency */ CollChk_same_root(comm, root, call); /* check for datatype signature consistency */#if defined( HAVE_MPI_IN_PLACE ) are2buffs = ( rank == root ? sbuff != MPI_IN_PLACE : 1 );#else are2buffs = 1;#endif CollChk_dtype_scatter(comm, rtype, rcnt, stype, scnt, root, are2buffs, call); /* make the call */ return PMPI_Gather(sbuff, scnt, stype, rbuff, rcnt, rtype, root, comm); } else { /* init not called */ return CollChk_err_han("MPI_Init() has not been called!", COLLCHK_ERR_NOT_INIT, call, comm); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -