MPI is a standard library for performing parallel processing using a distributed-memory model. The Glenn and Oakley clusters at OSC use the MVAPICH implementation of the Message Passing Interface (MPI), which is based on MPICH and optimized for the high-speed Infiniband interconnects.
MVAPICH2, based on the MPI-2 standard, is installed on both Oakley and Glenn. The older MVAPICH, based on the MPI-1 standard, is installed on Glenn only.
Availability & Restrictions
MPI is available without restriction to all OSC users.
Installations are available for the Intel, PGI, and gnu compilers.
The following versions of MVAPICH2 are available on OSC systems:
The following versions of MVAPICH (MPI-1) are available on OSC systems:
Some older versions are also available.
*Default version. The default on Oakley is the build corresponding to the currently loaded compiler. The default on Glenn is the MPI-1 build for the PGI compiler.
To set up your environment for using the MPI libraries, you must load the appropriate module. On Oakley this is pretty straightforward:
module load mvapich2
You will get the default version for the compiler you have loaded. (Be sure to swap the intel compiler module for the gnu module if you're using gnu.)
On Glenn you should load the module shown in the table below for the compiler you're using. Be sure to unload the default module before loading a new one.
To see all available mvapich modules on Glenn, use this command:
module avail mvapich
For example, to use the MPI-2 library with the gnu compilers:
module unload mpi module load mvapich2-1.5-gnu
Building With MPI
To build a program that uses MPI, you should use the compiler wrappers provided on the system. They accept the same options as the underlying compiler. The commands are shown in the following table.
For example, to build the code my_prog.c using the -O2 option, you would use:
mpicc -o my_prog -O2 my_prog.c
In rare cases you may be unable to use the wrappers. In that case you should use the environment variables set by the module.
||Use during your compilation step for C programs.|
||Use during your compilation step for C++ programs.|
||Use during your compilation step for Fortran 77 programs.|
||Use during your compilation step for Fortran 90 programs.|
||Use when linking your program to the MPI libraries.|
For example, to build the code my_prog.c without using the wrappers you would use:
mpicc -c $MPI_CFLAGS my_prog.c
mpicc -o my_prog my_prog.o $MPI_LIBS
Programs built with MPI can only be run in the batch environment at OSC. For information on starting MPI programs using the
mpiexec command, see Batch Processing at OSC.
Be sure to load the same compiler and mvapich modules at execution time as at build time.
- The Message Passing Interface (MPI) standard, http://www.mcs.anl.gov/research/projects/mpi/
- MPI Training Course