Learn R Programming

pbdMPI (version 0.2-2)

global stop and warning functions: Global Stop and Warning Functions

Description

These functions are global stop and warning applying on distributed data for all ranks, and are called by experts only. These functions may lead to potential performance degradation and system termination.

Usage

comm.stop(..., call. = TRUE, domain = NULL,
    all.rank = .SPMD.CT$print.all.rank, rank.print = .SPMD.CT$rank.source,
    comm = .SPMD.CT$comm, mpi.finalize = .SPMD.CT$mpi.finalize,
    quit = .SPMD.CT$quit)

comm.warning(..., call. = TRUE, immediate. = FALSE, domain = NULL, all.rank = .SPMD.CT$print.all.rank, rank.print = .SPMD.CT$rank.source, comm = .SPMD.CT$comm)

comm.warnings(..., all.rank = .SPMD.CT$print.all.rank, rank.print = .SPMD.CT$rank.source, comm = .SPMD.CT$comm)

Arguments

...
variables to be cat.
call.
see stop() and warnings().
immediate.
see stop() and warnings().
domain
see stop() and warnings().
all.rank
if all ranks print (default = FALSE).
rank.print
rank for printing if not all ranks print (default = 0).
comm
communicator for printing (default = 1).
mpi.finalize
if MPI should be shutdown.
quit
if quit R when errors happen.

Value

  • comm.stop() terminates all ranks, comm.warning() returns messages, and comm.warnings() print the message.

Details

These functions will respectively apply stop(), warning(), and warnings() locally.

References

Programming with Big Data in R Website: http://r-pbd.org/

Examples

Run this code
# Save code in a file "demo.r" and run with 2 processors by
# > mpiexec -np 2 Rscript demo.r

### Initial
library(pbdMPI, quietly = TRUE)
init()
if(comm.size() != 2){
  comm.cat("2 processors are requried.\n", quiet = TRUE)
  finalize()
}

### Examples
comm.warning("test warning.\n")
comm.warnings()
comm.stop("test stop.\n")

### Finish
finalize()

Run the code above in your browser using DataLab