Skip to content

mpi4py_map provides a simple map() interface to mpi4py that allows easy parallelization of function evaluations over sequential input.

Notifications You must be signed in to change notification settings

twiecki/mpi4py_map

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Provides a map() interface to mpi4py.

License: MIT

Copyright (c) 2012 Thomas Wiecki (thomas.wiecki[at]gmail.com)

Depracation warning

You probably do not want to use this as there are much better alternatives like IPython parallel. See here for a blog post in which I describe my current setup: http://twiecki.github.io/blog/2014/02/24/ipython-nb-cluster/

The code might be instructive on how to use MPI4Py however.

About

MPI (Message Passing Interface) is a library that allows processes running on different hosts to communicate and exchange information. It is ideally suited for parallel computations on a cluster. mpi4py provides a convenient python wrapper for this library. However, it still a pretty bare exposition of MPI functions which requires you to code most of the interprocess-communication by hand. Other parallel python libraries such as the multiprocessing package (which only allows process management on a single host) have more simple interfaces. For example, you can create a worker pool and use the map() function to easily parallelize evaluations of your function over a given sequence (e.g. pool.map(lambda x: x**2, range(500)) will square the list in parallel).

mpi4py_map brings this simple but powerful map() functionality to mpi4py. It takes care of assigning the jobs to the workers, queueing if all workers are busy and cleanly shutting down all workers after the job is complete.

Features

  • Easy, transparent parallelization of your Python code on a PC or cluster.
  • Sequential items do not have to be serializable.

Dependencies

Usage

Create a python file (e.g. mpi_square.py):

from mpi4py_map import map
print map(lambda x, y: x**y, [1,2,3,4], 2) # square the sequence

Then call your program with mpirun, e.g.:

mpi4run -n 4 mpi_square.py

About

mpi4py_map provides a simple map() interface to mpi4py that allows easy parallelization of function evaluations over sequential input.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages