topo_base_cart_rank.c

来自「MPI stands for the Message Passing Inter」· C语言 代码 · 共 79 行

C
79
字号
/* * Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana *                         University Research and Technology *                         Corporation.  All rights reserved. * Copyright (c) 2004-2005 The University of Tennessee and The University *                         of Tennessee Research Foundation.  All rights *                         reserved. * Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,  *                         University of Stuttgart.  All rights reserved. * Copyright (c) 2004-2005 The Regents of the University of California. *                         All rights reserved. * $COPYRIGHT$ *  * Additional copyrights may follow *  * $HEADER$ */#include "ompi_config.h"#include "ompi/mca/topo/base/base.h"#include "ompi/communicator/communicator.h"#include "ompi/mca/topo/topo.h"/* * function - Determines process rank in communicator given Cartesian *                 location * * @param comm communicator with cartesian structure (handle) * @param coords integer array (of size  'ndims') specifying the cartesian *               coordinates of a process * @param rank rank of specified process (integer) * * @retval MPI_SUCCESS * @retval MPI_ERR_COMM * @retval MPI_ERR_TOPOLOGY * @retval MPI_ERR_ARG */                   int mca_topo_base_cart_rank (MPI_Comm comm,                          int *coords,                          int *rank){   int prank;   int dim;   int ord;   int factor;   int i;   int *d;   int *c;   /*    * Loop over coordinates computing the rank.    */    factor = 1;    prank = 0;    i = comm->c_topo_comm->mtc_ndims_or_nnodes - 1;    d = comm->c_topo_comm->mtc_dims_or_index + i;    c = coords + i;   for (; i >= 0; --i, --c, --d) {       dim = (*d > 0) ? *d : -(*d);       ord = *c;        if ((ord < 0) || (ord >= dim)) {          if (*d > 0) {             return MPI_ERR_ARG;          }          ord %= dim;          if (ord < 0) {             ord += dim;          }       }       prank += factor * ord;       factor *= dim;    }    *rank = prank;    return(MPI_SUCCESS);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?