2015-06-02 18:40:26 +03:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
2014-05-23 12:19:17 +04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2006 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2006 The Technical University of Chemnitz. All
|
|
|
|
* rights reserved.
|
|
|
|
* Copyright (c) 2014 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
2015-06-02 18:40:26 +03:00
|
|
|
* Copyright (c) 2015 Los Alamos National Security, LLC. All rights
|
|
|
|
* reserved.
|
2014-05-23 12:19:17 +04:00
|
|
|
*
|
|
|
|
* Author(s): Torsten Hoefler <htor@cs.indiana.edu>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "comm_helpers.h"
|
|
|
|
|
|
|
|
int ompi_comm_neighbors_count(MPI_Comm comm, int *indegree, int *outdegree, int *weighted) {
|
|
|
|
int res;
|
|
|
|
|
2015-06-24 06:59:57 +03:00
|
|
|
if (OMPI_COMM_IS_CART(comm)) {
|
2014-05-23 12:19:17 +04:00
|
|
|
int ndims;
|
|
|
|
res = MPI_Cartdim_get(comm, &ndims) ;
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
/* outdegree is always 2*ndims because we need to iterate over empty buffers for MPI_PROC_NULL */
|
|
|
|
*outdegree = *indegree = 2*ndims;
|
|
|
|
*weighted = 0;
|
|
|
|
} else if (OMPI_COMM_IS_GRAPH(comm)) {
|
|
|
|
int rank, nneighbors;
|
2015-06-02 18:40:26 +03:00
|
|
|
rank = ompi_comm_rank ((ompi_communicator_t *) comm);
|
2014-05-23 12:19:17 +04:00
|
|
|
res = MPI_Graph_neighbors_count(comm, rank, &nneighbors);
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
*outdegree = *indegree = nneighbors;
|
|
|
|
*weighted = 0;
|
|
|
|
} else if (OMPI_COMM_IS_DIST_GRAPH(comm)) {
|
|
|
|
res = MPI_Dist_graph_neighbors_count(comm, indegree, outdegree, weighted);
|
|
|
|
} else {
|
|
|
|
return MPI_ERR_ARG;
|
|
|
|
}
|
|
|
|
|
|
|
|
return MPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
int ompi_comm_neighbors(MPI_Comm comm, int maxindegree, int sources[], int sourceweights[], int maxoutdegree, int destinations[], int destweights[]) {
|
|
|
|
int res;
|
|
|
|
int index = 0;
|
|
|
|
|
|
|
|
int indeg, outdeg, wgtd;
|
|
|
|
res = ompi_comm_neighbors_count(comm, &indeg, &outdeg, &wgtd);
|
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
if(indeg > maxindegree && outdeg > maxoutdegree) return MPI_ERR_TRUNCATE; /* we want to return *all* neighbors */
|
|
|
|
|
2015-06-24 06:59:57 +03:00
|
|
|
if (OMPI_COMM_IS_CART(comm)) {
|
2014-05-23 12:19:17 +04:00
|
|
|
int ndims, i, rpeer, speer;
|
|
|
|
res = MPI_Cartdim_get(comm, &ndims);
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
|
|
|
|
for(i = 0; i<ndims; i++) {
|
|
|
|
res = MPI_Cart_shift(comm, i, 1, &rpeer, &speer);
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
sources[index] = destinations[index] = rpeer; index++;
|
|
|
|
sources[index] = destinations[index] = speer; index++;
|
|
|
|
}
|
|
|
|
} else if (OMPI_COMM_IS_GRAPH(comm)) {
|
2015-06-02 18:40:26 +03:00
|
|
|
int rank = ompi_comm_rank ((ompi_communicator_t *) comm);
|
2014-05-23 12:19:17 +04:00
|
|
|
res = MPI_Graph_neighbors(comm, rank, maxindegree, sources);
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
for(int i=0; i<maxindegree; i++) destinations[i] = sources[i];
|
|
|
|
} else if (OMPI_COMM_IS_DIST_GRAPH(comm)) {
|
|
|
|
res = MPI_Dist_graph_neighbors(comm, maxindegree, sources, sourceweights, maxoutdegree, destinations, destweights);
|
2014-05-26 05:54:24 +04:00
|
|
|
if (MPI_SUCCESS != res) {
|
|
|
|
return res;
|
|
|
|
}
|
2014-05-23 12:19:17 +04:00
|
|
|
} else {
|
|
|
|
return MPI_ERR_ARG;
|
|
|
|
}
|
|
|
|
|
|
|
|
return MPI_SUCCESS;
|
|
|
|
}
|