1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
.. _mpi_group_translate_ranks:
MPI_Group_translate_ranks
=========================
.. include_body
:ref:`MPI_Group_translate_ranks` |mdash| Translates the ranks of processes in one
group to those in another group.
SYNTAX
------
C Syntax
^^^^^^^^
.. code-block:: c
#include <mpi.h>
int MPI_Group_translate_ranks(MPI_Group group1, int n,
const int ranks1[], MPI_Group group2, int ranks2[])
Fortran Syntax
^^^^^^^^^^^^^^
.. code-block:: fortran
USE MPI
! or the older form: INCLUDE 'mpif.h'
MPI_GROUP_TRANSLATE_RANKS(GROUP1, N, RANKS1, GROUP2, RANKS2,
IERROR)
INTEGER GROUP1, N, RANKS1(*), GROUP2, RANKS2(*), IERROR
Fortran 2008 Syntax
^^^^^^^^^^^^^^^^^^^
.. code-block:: fortran
USE mpi_f08
MPI_Group_translate_ranks(group1, n, ranks1, group2, ranks2, ierror)
TYPE(MPI_Group), INTENT(IN) :: group1, group2
INTEGER, INTENT(IN) :: n, ranks1(n)
INTEGER, INTENT(OUT) :: ranks2(n)
INTEGER, OPTIONAL, INTENT(OUT) :: ierror
INPUT PARAMETERS
----------------
* ``group1``: First group (handle).
* ``n``: Number of ranks in ranks1 and ranks2 arrays (integer).
* ``ranks1``: Array of zero or more valid ranks in group1.
* ``group2``: Second group (handle).
OUTPUT PARAMETERS
-----------------
* ``ranks2``: Array of corresponding ranks in group2, MPI_UNDEFINED when no correspondence exists.
* ``ierror``: Fortran only: Error status (integer).
DESCRIPTION
-----------
This function is important for determining the relative numbering of the
same processes in two different groups. For instance, if one knows the
ranks of certain processes in the group of MPI_COMM_WORLD, one might
want to know their ranks in a subset of that group.
ERRORS
------
.. include:: ./ERRORS.rst
|