File: MPI_Cart_create.3.rst

package info (click to toggle)
openmpi 5.0.8-10
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 201,692 kB
  • sloc: ansic: 613,078; makefile: 42,351; sh: 11,194; javascript: 9,244; f90: 7,052; java: 6,404; perl: 5,179; python: 1,859; lex: 740; fortran: 61; cpp: 20; tcl: 12
file content (86 lines) | stat: -rw-r--r-- 2,408 bytes parent folder | download | duplicates (4)
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
78
79
80
81
82
83
84
85
86
.. _mpi_cart_create:

MPI_Cart_create
===============

.. include_body

:ref:`MPI_Cart_create` |mdash| Makes a new communicator to which Cartesian
topology information has been attached.

SYNTAX
------

C Syntax
^^^^^^^^

.. code-block:: c

   #include <mpi.h>

   int MPI_Cart_create(MPI_Comm comm_old, int ndims, const int dims[],

       const int periods[], int reorder, MPI_Comm *comm_cart)

Fortran Syntax
^^^^^^^^^^^^^^

.. code-block:: fortran

   USE MPI
   ! or the older form: INCLUDE 'mpif.h'

   MPI_CART_CREATE(COMM_OLD, NDIMS, DIMS, PERIODS, REORDER,
           COMM_CART, IERROR)
       INTEGER COMM_OLD, NDIMS, DIMS(*), COMM_CART, IERROR
       LOGICAL PERIODS(*), REORDER

Fortran 2008 Syntax
^^^^^^^^^^^^^^^^^^^

.. code-block:: fortran

   USE mpi_f08

   MPI_Cart_create(comm_old, ndims, dims, periods, reorder, comm_cart, ierror)
       TYPE(MPI_Comm), INTENT(IN) :: comm_old
       INTEGER, INTENT(IN) :: ndims, dims(ndims)
       LOGICAL, INTENT(IN) :: periods(ndims), reorder
       TYPE(MPI_Comm), INTENT(OUT) :: comm_cart
       INTEGER, OPTIONAL, INTENT(OUT) :: ierror

INPUT PARAMETERS
----------------

* ``comm_old`` : Input communicator (handle).
* ``ndims`` : Number of dimensions of Cartesian grid (integer).
* ``dims`` : Integer array of size ndims specifying the number of
   processes in each dimension.
* ``periods`` : Logical array of size ndims specifying whether the grid
   is periodic (true) or not (false) in each dimension.
* ``reorder`` : Ranking may be reordered (true) or not (false)
   (logical).

OUTPUT PARAMETERS
-----------------

* ``comm_cart`` : Communicator with new Cartesian topology (handle).
* ``ierror`` : Fortran only: Error status (integer).

DESCRIPTION
-----------

:ref:`MPI_Cart_create` returns a handle to a new communicator to which the
Cartesian topology information is attached. If ``reorder`` = false then
the rank of each process in the new group is identical to its rank in
the old group. Otherwise, the function may ``reorder`` the processes
(possibly so as to choose a good embedding of the virtual topology onto
the physical machine). If the total size of the Cartesian grid is
smaller than the size of the group of comm, then some processes are
returned MPI_COMM_NULL, in analogy to :ref:`MPI_Comm_split`. The call
is erroneous if it specifies a grid that is larger than the group size.

ERRORS
------

.. include:: ./ERRORS.rst