|
|
|
|
|
|
|
\section{Parallel environment routines}
|
|
|
|
\label{sec:parenv}
|
|
|
|
|
|
|
|
\subroutine{psb\_init}{Initializes PSBLAS parallel environment}
|
|
|
|
|
|
|
|
\syntax{call psb\_init}{icontxt, np}
|
|
|
|
|
|
|
|
This subroutine initializes the PSBLAS parallel environment, defining
|
|
|
|
a virtual parallel machine.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[np] Number of processes in the PSBLAS virtual parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value. \
|
|
|
|
Default: use all available processes provided by the underlying
|
|
|
|
parallel environment.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf out}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item A call to this routine must precede any other PSBLAS call.
|
|
|
|
\item It is an error to specify a value for $np$ greater than the
|
|
|
|
number of processes available in the underlying parallel execution
|
|
|
|
environment.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_info}{Return information about PSBLAS parallel environment}
|
|
|
|
|
|
|
|
\syntax{call psb\_info}{icontxt, iam, np}
|
|
|
|
|
|
|
|
This subroutine returns information about the PSBLAS parallel environment, defining
|
|
|
|
a virtual parallel machine.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Asynchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[iam] Identifier of current process in the PSBLAS virtual parallel machine.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf out}.\\
|
|
|
|
Specified as: an integer value. $-1 \le iam \le np-1$\
|
|
|
|
\item[np] Number of processes in the PSBLAS virtual parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf out}.\\
|
|
|
|
Specified as: an integer variable. \
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item For processes in the virtual parallel machine the identifier
|
|
|
|
will satisfy $0 \le iam \le np-1$;
|
|
|
|
\item If the user has requested on \verb|psb_init| a number of
|
|
|
|
processes less than the total available in the parallel execution
|
|
|
|
environment, the remaining processes will have on return $iam=-1$;
|
|
|
|
the only call involving \verb|icontxt| that any such process may
|
|
|
|
execute is to \verb|psb_exit|.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_exit}{Exit from PSBLAS parallel environment}
|
|
|
|
|
|
|
|
\syntax{call psb\_exit}{icontxt}
|
|
|
|
\syntax*{call psb\_exit}{icontxt,close}
|
|
|
|
|
|
|
|
This subroutine exits from the PSBLAS parallel virtual machine.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[close] Whether to close all data structures related to the
|
|
|
|
virtual parallel machine, besides those associated with icontxt.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: a logical variable, default value: true.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item This routine may be called even if a previous call to
|
|
|
|
\verb|psb_info| has returned with $iam=-1$; indeed, it it is the only
|
|
|
|
routine that may be called with argument \verb|icontxt| in this
|
|
|
|
situation.
|
|
|
|
\item A call to this routine with \verb|close=.true.| implies a call
|
|
|
|
to \verb|MPI_Finalize|, after which no parallel routine may be called.
|
|
|
|
\item If the user whishes to use multiple communication contexts in the
|
|
|
|
same program, or to enter and exit multiple times into the parallel
|
|
|
|
environment, this routine may be called to
|
|
|
|
selectively close the contexts with \verb|close=.false.|, while on
|
|
|
|
the last call it should be called with \verb|close=.true.| to
|
|
|
|
shutdown in a clean way the entire parallel environment.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_get\_mpicomm}{Get the MPI communicator}
|
|
|
|
|
|
|
|
\syntax{call psb\_get\_mpicomm}{icontxt, icomm}
|
|
|
|
|
|
|
|
This subroutine returns the MPI communicator associated with a PSBLAS context
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Asynchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[icomm] The MPI communicator associated with the PSBLAS virtual parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf out}.\\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_get\_rank}{Get the MPI rank}
|
|
|
|
|
|
|
|
\syntax{call psb\_get\_rank}{rank, icontxt, id}
|
|
|
|
|
|
|
|
This subroutine returns the MPI rank of the PSBLAS process $id$
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Asynchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[id] Identifier of a process in the PSBLAS virtual parallel machine.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value. $0 \le id \le np-1$\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[rank] The MPI rank associated with the PSBLAS process $id$.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf out}.\\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_wtime}{Wall clock timing}
|
|
|
|
|
|
|
|
\syntax{time = psb\_wtime}{}
|
|
|
|
|
|
|
|
This function returns a wall clock timer. The resolution of the timer
|
|
|
|
is dependent on the underlying parallel environment implementation.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Asynchronous.
|
|
|
|
\item[\bf On Exit ]
|
|
|
|
\item[Function value] the elapsed time in seconds.\\
|
|
|
|
Returned as: a \verb|real(kind(1.d0))| integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_barrier}{Sinchronization point parallel environment}
|
|
|
|
|
|
|
|
\syntax{call psb\_barrier}{icontxt}
|
|
|
|
|
|
|
|
This subroutine acts as an explicit synchronization point for the PSBLAS
|
|
|
|
parallel virtual machine.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_abort}{Abort a computation}
|
|
|
|
|
|
|
|
\syntax{call psb\_abort}{icontxt}
|
|
|
|
|
|
|
|
This subroutine aborts computation on the parallel virtual machine.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Asynchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_bcast}{Broadcast data}
|
|
|
|
|
|
|
|
\syntax{call psb\_bcast}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a broadcast operation based on the
|
|
|
|
underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] On the root process, the data to be broadcast.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array, or a character or logical scalar. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Root process holding data to be broadcast.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $0<= root <= np-1$, default 0 \
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On processes other than root, the data to be broadcast.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array, or a character or logical scalar. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_sum}{Global sum}
|
|
|
|
|
|
|
|
\syntax{call psb\_sum}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a sum reduction operation based on the
|
|
|
|
underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The local contribution to the global sum.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Process to hold the final sum, or $-1$ to make it available
|
|
|
|
on all processes.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $-1<= root <= np-1$, default -1. \
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On destination process(es), the result of the sum operation.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \\
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item The \verb|dat| argument is both input and output, and its
|
|
|
|
value may be changed even on processes different from the final
|
|
|
|
result destination.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_max}{Global maximum}
|
|
|
|
|
|
|
|
\syntax{call psb\_max}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a maximum valuereduction
|
|
|
|
operation based on the underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The local contribution to the global maximum.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer or real variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Process to hold the final maximum, or $-1$ to make it available
|
|
|
|
on all processes.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $-1<= root <= np-1$, default -1. \\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On destination process(es), the result of the maximum operation.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer or real variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item The \verb|dat| argument is both input and output, and its
|
|
|
|
value may be changed even on processes different from the final
|
|
|
|
result destination.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
\subroutine{psb\_min}{Global minimum}
|
|
|
|
|
|
|
|
\syntax{call psb\_min}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a minimum value reduction
|
|
|
|
operation based on the underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The local contribution to the global minimum.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer or real variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Process to hold the final value, or $-1$ to make it available
|
|
|
|
on all processes.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $-1<= root <= np-1$, default -1. \\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On destination process(es), the result of the minimum operation.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer or real variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \\
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item The \verb|dat| argument is both input and output, and its
|
|
|
|
value may be changed even on processes different from the final
|
|
|
|
result destination.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
\subroutine{psb\_amx}{Global maximum absolute value}
|
|
|
|
|
|
|
|
\syntax{call psb\_amx}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a maximum absolute value reduction
|
|
|
|
operation based on the underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The local contribution to the global maximum.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Process to hold the final value, or $-1$ to make it available
|
|
|
|
on all processes.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $-1<= root <= np-1$, default -1. \\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On destination process(es), the result of the maximum operation.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item The \verb|dat| argument is both input and output, and its
|
|
|
|
value may be changed even on processes different from the final
|
|
|
|
result destination.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
\subroutine{psb\_amn}{Global minimum absolute value}
|
|
|
|
|
|
|
|
\syntax{call psb\_amn}{icontxt, dat, root}
|
|
|
|
|
|
|
|
This subroutine implements a minimum absolute value reduction
|
|
|
|
operation based on the underlying communication library.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The local contribution to the global minimum.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\item[root] Process to hold the final value, or $-1$ to make it available
|
|
|
|
on all processes.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $-1<= root <= np-1$, default -1. \\
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] On destination process(es), the result of the minimum operation.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array. \\
|
|
|
|
Type, rank and size must agree on all processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item The \verb|dat| argument is both input and output, and its
|
|
|
|
value may be changed even on processes different from the final
|
|
|
|
result destination.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_snd}{Send data}
|
|
|
|
|
|
|
|
\syntax{call psb\_snd}{icontxt, dat, dst, m}
|
|
|
|
|
|
|
|
This subroutine sends a packet of data to a destination.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous: see usage notes.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[dat] The data to be sent.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array, or a character or logical scalar. \
|
|
|
|
Type and rank must agree on sender and receiver process; if $m$ is
|
|
|
|
not specified, size must agree as well.
|
|
|
|
\item[dst] Destination process.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $0<= dst <= np-1$. \\
|
|
|
|
\item[m] Number of rows.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf Optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $0<= m <= size(dat,1)$. \\
|
|
|
|
When $dat$ is a rank 2 array, specifies the number of rows to be sent
|
|
|
|
independently of the leading dimension $size(dat,1)$; must have the
|
|
|
|
same value on sending and receiving processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item This subroutine implies a synchronization, but only between the
|
|
|
|
calling process and the destination process $dst$.
|
|
|
|
\end{enumerate}
|
|
|
|
|
|
|
|
|
|
|
|
\subroutine{psb\_rcv}{Receive data}
|
|
|
|
|
|
|
|
\syntax{call psb\_rcv}{icontxt, dat, src, m}
|
|
|
|
|
|
|
|
This subroutine receives a packet of data to a destination.
|
|
|
|
\begin{description}
|
|
|
|
\item[Type:] Synchronous: see usage notes.
|
|
|
|
\item[\bf On Entry ]
|
|
|
|
\item[icontxt] the communication context identifying the virtual
|
|
|
|
parallel machine.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer variable.
|
|
|
|
\item[src] Source process.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $0<= src <= np-1$. \\
|
|
|
|
\item[m] Number of rows.\\
|
|
|
|
Scope: {\bf global}.\\
|
|
|
|
Type: {\bf Optional}.\\
|
|
|
|
Intent: {\bf in}.\\
|
|
|
|
Specified as: an integer value $0<= m <= size(dat,1)$. \\
|
|
|
|
When $dat$ is a rank 2 array, specifies the number of rows to be sent
|
|
|
|
independently of the leading dimension $size(dat,1)$; must have the
|
|
|
|
same value on sending and receiving processes.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
|
|
|
|
\begin{description}
|
|
|
|
\item[\bf On Return]
|
|
|
|
\item[dat] The data to be received.\\
|
|
|
|
Scope: {\bf local}.\\
|
|
|
|
Type: {\bf required}.\\
|
|
|
|
Intent: {\bf inout}.\\
|
|
|
|
Specified as: an integer, real or complex variable, which may be a
|
|
|
|
scalar, or a rank 1 or 2 array, or a character or logical scalar. \
|
|
|
|
Type and rank must agree on sender and receiver process; if $m$ is
|
|
|
|
not specified, size must agree as well.
|
|
|
|
\end{description}
|
|
|
|
|
|
|
|
\section*{Notes}
|
|
|
|
\begin{enumerate}
|
|
|
|
\item This subroutine implies a synchronization, but only between the
|
|
|
|
calling process and the source process $src$.
|
|
|
|
\end{enumerate}
|