Blame www/www3/MPI_Intercomm_create.html

Packit 0848f5
Packit 0848f5
<HTML>
Packit 0848f5
<HEAD>
Packit 0848f5
<META NAME="GENERATOR" CONTENT="DOCTEXT">
Packit 0848f5
<TITLE>MPI_Intercomm_create</TITLE>
Packit 0848f5
</HEAD>
Packit 0848f5
<BODY BGCOLOR="FFFFFF">
Packit 0848f5

MPI_Intercomm_create

Packit 0848f5
Creates an intercommuncator from two intracommunicators 
Packit 0848f5

Synopsis

Packit 0848f5
Packit 0848f5
int MPI_Intercomm_create(MPI_Comm local_comm, int local_leader, 
Packit 0848f5
                       MPI_Comm peer_comm, int remote_leader, int tag, 
Packit 0848f5
                       MPI_Comm *newintercomm)
Packit 0848f5
Packit 0848f5

Input Parameters

Packit 0848f5
Packit 0848f5
local_comm
Local (intra)communicator
Packit 0848f5
Packit 0848f5
local_leader
Rank in local_comm of leader (often 0)
Packit 0848f5
Packit 0848f5
peer_comm
Communicator used to communicate between a
Packit 0848f5
designated process in the other communicator.  
Packit 0848f5
Significant only at the process in <tt>local_comm</tt> with
Packit 0848f5
rank <tt>local_leader</tt>.
Packit 0848f5
Packit 0848f5
remote_leader
Rank in peer_comm of remote leader (often 0)
Packit 0848f5
Packit 0848f5
tag
Message tag to use in constructing intercommunicator; if multiple
Packit 0848f5
<tt>MPI_Intercomm_creates</tt> are being made, they should use different tags (more
Packit 0848f5
precisely, ensure that the local and remote leaders are using different
Packit 0848f5
tags for each <tt>MPI_intercomm_create</tt>).
Packit 0848f5
Packit 0848f5

Packit 0848f5

Output Parameters

Packit 0848f5
newintercomm
Created intercommunicator
Packit 0848f5
Packit 0848f5

Packit 0848f5

Notes

Packit 0848f5
<tt>peer_comm</tt> is significant only for the process designated the
Packit 0848f5
<tt>local_leader</tt> in the <tt>local_comm</tt>.
Packit 0848f5

Packit 0848f5
The MPI 1.1 Standard contains two mutually exclusive comments on the
Packit 0848f5
input intercommunicators.  One says that their repective groups must be
Packit 0848f5
disjoint; the other that the leaders can be the same process.  After
Packit 0848f5
some discussion by the MPI Forum, it has been decided that the groups must
Packit 0848f5
be disjoint.  Note that the reason given for this in the standard is
Packit 0848f5
not the reason for this choice; rather, the other operations on
Packit 0848f5
intercommunicators (like <tt>MPI_Intercomm_merge</tt>) do not make sense if the
Packit 0848f5
groups are not disjoint.
Packit 0848f5

Packit 0848f5

Thread and Interrupt Safety

Packit 0848f5

Packit 0848f5
This routine is thread-safe.  This means that this routine may be
Packit 0848f5
safely used by multiple threads without the need for any user-provided
Packit 0848f5
thread locks.  However, the routine is not interrupt safe.  Typically,
Packit 0848f5
this is due to the use of memory allocation routines such as <tt>malloc
Packit 0848f5
</tt>or other non-MPICH runtime routines that are themselves not interrupt-safe.
Packit 0848f5

Packit 0848f5

Notes for Fortran

Packit 0848f5
All MPI routines in Fortran (except for <tt>MPI_WTIME</tt> and <tt>MPI_WTICK</tt>) have
Packit 0848f5
an additional argument <tt>ierr</tt> at the end of the argument list.  <tt>ierr
Packit 0848f5
</tt>is an integer and has the same meaning as the return value of the routine
Packit 0848f5
in C.  In Fortran, MPI routines are subroutines, and are invoked with the
Packit 0848f5
<tt>call</tt> statement.
Packit 0848f5

Packit 0848f5
All MPI objects (e.g., <tt>MPI_Datatype</tt>, <tt>MPI_Comm</tt>) are of type <tt>INTEGER
Packit 0848f5
</tt>in Fortran.
Packit 0848f5

Packit 0848f5

Errors

Packit 0848f5

Packit 0848f5
All MPI routines (except <tt>MPI_Wtime</tt> and <tt>MPI_Wtick</tt>) return an error value;
Packit 0848f5
C routines as the value of the function and Fortran routines in the last
Packit 0848f5
argument.  Before the value is returned, the current MPI error handler is
Packit 0848f5
called.  By default, this error handler aborts the MPI job.  The error handler
Packit 0848f5
may be changed with <tt>MPI_Comm_set_errhandler</tt> (for communicators),
Packit 0848f5
<tt>MPI_File_set_errhandler</tt> (for files), and <tt>MPI_Win_set_errhandler</tt> (for
Packit 0848f5
RMA windows).  The MPI-1 routine <tt>MPI_Errhandler_set</tt> may be used but
Packit 0848f5
its use is deprecated.  The predefined error handler
Packit 0848f5
<tt>MPI_ERRORS_RETURN</tt> may be used to cause error values to be returned.
Packit 0848f5
Note that MPI does not guarentee that an MPI program can continue past
Packit 0848f5
an error; however, MPI implementations will attempt to continue whenever
Packit 0848f5
possible.
Packit 0848f5

Packit 0848f5
MPI_SUCCESS
No error; MPI routine completed successfully.
Packit 0848f5
Packit 0848f5
MPI_ERR_COMM
Invalid communicator. A common error is to use a null
Packit 0848f5
communicator in a call (not even allowed in <tt>MPI_Comm_rank</tt>).
Packit 0848f5
Packit 0848f5
MPI_ERR_TAG
Invalid tag argument. Tags must be non-negative; tags
Packit 0848f5
in a receive (<tt>MPI_Recv</tt>, <tt>MPI_Irecv</tt>, <tt>MPI_Sendrecv</tt>, etc.) may
Packit 0848f5
also be <tt>MPI_ANY_TAG</tt>.  The largest tag value is available through the 
Packit 0848f5
the attribute <tt>MPI_TAG_UB</tt>.
Packit 0848f5
Packit 0848f5
MPI_ERR_INTERN
This error is returned when some part of the MPICH
Packit 0848f5
implementation is unable to acquire memory.  
Packit 0848f5
Packit 0848f5
MPI_ERR_RANK
Invalid source or destination rank. Ranks must be between
Packit 0848f5
zero and the size of the communicator minus one; ranks in a receive
Packit 0848f5
(<tt>MPI_Recv</tt>, <tt>MPI_Irecv</tt>, <tt>MPI_Sendrecv</tt>, etc.) may also be <tt>MPI_ANY_SOURCE</tt>.
Packit 0848f5
Packit 0848f5

Packit 0848f5
<H0>See Also</H0>
Packit 0848f5
 MPI_Intercomm_merge, MPI_Comm_free, MPI_Comm_remote_group, 
Packit 0848f5

MPI_Comm_remote_size
Packit 0848f5

Packit 0848f5
</BODY></HTML>