This repository builds and publishes mpi4py Python wheels able to run in a variety of
- operating systems: Linux, macOS, Windows;
- processor architectures: AMD64, ARM64, PPC64;
- MPI implementations: MPICH, Open MPI, MVAPICH, Intel MPI, HPE Cray MPICH, Microsoft MPI;
- Python implementations: CPython, PyPy.
mpi4py wheels are uploaded to the Anaconda.org
package server. These wheels can be installed with pip
specifying the
alternative index URL:
python -m pip install mpi4py -i https://pypi.anaconda.org/mpi4py/simple
mpi4py wheels can be installed (with pip
) in conda
environments and they should work out of the box, for any MPI package provided
by conda-forge, and without any special tweak to
environment variables. Otherwise, these wheels can be installed in standard
Python virtual environments and use an externally-provided MPI runtime coming
from the system package manager, sysadmin-maintained builds accessible via
module files, or customized user builds.
Tip
Intel MPI distributes Linux
and Windows wheels for Intel-based
processor architectures (x86_64
/AMD64
). mpi4py and Intel MPI wheels can
be installed side by side to get a ready-to-use Python+MPI environment:
python -m pip install impi-rt mpi4py \
--extra-index-url https://pypi.anaconda.org/mpi4py/simple
The Linux wheels require
-
MPICH and any other ABI-compatible derivative like MVAPICH, Intel MPI, HPE Cray MPICH.
-
Open MPI and any other ABI-compatible derivative.
Users may need to set the LD_LIBRARY_PATH
environment variable such that the
dynamic linker is able to find at runtime the MPI shared library file
(libmpi.so.??
).
On Debian/Ubuntu systems, Open MPI is the default MPI implementation and most of the MPI-based applications and libraries provided by the distribution depend on Open MPI. Nonetheless, MPICH is also available to users for installation.
In Ubuntu 22.04 and older, due to legacy reasons, the MPICH ABI is slightly
broken: the MPI shared library file is named libmpich.so.12
instead of
libmpi.so.12
as required by the MPICH ABI Compatibility
Initiative.
Users without sudo
access can workaround this issue creating a symbolic link
anywhere in their home directory and appending to LD_LIBRARY_PATH
.
mkdir -p ~/.local/lib
multiarch=$(arch | sed s/^ppc/powerpc/)-linux-gnu
ln -s /usr/lib/$multiarch/libmpich.so.12 ~/.local/lib/libmpi.so.12
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/.local/lib
A system-wide fix for all users requires sudo
access:
multiarch=$(arch | sed s/^ppc/powerpc/)-linux-gnu
sudo ln -sr /usr/lib/$multiarch/libmpi{ch,}.so.12
On Fedora/RHEL systems, both MPICH and Open MPI are available for installation. There is no default or preferred MPI implementation. Instead, users must select their favorite MPI implementation by loading the proper MPI module.
module load mpi/mpich-$(arch) # for MPICH
module load mpi/openmpi-$(arch) # for Open MPI
After loading the requested MPI module, the LD_LIBRARY_PATH
environment
variable should be properly setup.
Users must load the cray-mpich-abi
module. For further details, refer to
man intro_mpi
.
The macOS wheels require
-
MPICH or Open MPI installed (either manually or via a package manager) in the standard prefix
/usr/local
. -
MPICH or Open MPI installed via Homebrew in the default prefix
/opt/homebrew
. -
MPICH or Open MPI installed via MacPorts in the default prefix
/opt/local
.
The Windows wheels require
User may need to set the I_MPI_ROOT
or MSMPI_BIN
environment variables such
that the MPI dynamic link library (DLL) file (impi.dll
or msmpi.dll
) can be
found at runtime.