Skip to main content

better multiprocessing and multithreading in python

Project description

About Multiprocess

multiprocess is a fork of multiprocessing, and is developed as part of pathos: https://github.com/uqfoundation/pathos

multiprocessing is a package for the Python language which supports the spawning of processes using the API of the standard library’s threading module. multiprocessing has been distributed in the standard library since python 2.6.

Features:

  • Objects can be transferred between processes using pipes or multi-producer/multi-consumer queues.

  • Objects can be shared between processes using a server process or (for simple data) shared memory.

  • Equivalents of all the synchronization primitives in threading are available.

  • A Pool class makes it easy to submit tasks to a pool of worker processes.

multiprocess is part of pathos, a python framework for heterogeneous computing. multiprocess is in active development, so any user feedback, bug reports, comments, or suggestions are highly appreciated. A list of issues is located at https://github.com/uqfoundation/multiprocess/issues, with a legacy list maintained at https://uqfoundation.github.io/pathos-issues.html.

NOTE: A C compiler is required to build the included extension module. For python 3.3 and above, a C compiler is suggested, but not required.

Major Changes

  • enhanced serialization, using dill

Current Release

This documentation is for version multiprocess-0.70.10 (a fork of multiprocessing-0.70a1).

The latest released version of multiprocess is available from:

https://pypi.org/project/multiprocess

Multiprocessing is distributed under a BSD license.

Development Version

You can get the latest development version with all the shiny new features at:

https://github.com/uqfoundation

If you have a new contribution, please submit a pull request.

Installation

multiprocess is packaged to install from source, so you must download the tarball, unzip, and run the installer:

[download]
$ tar -xvzf multiprocess-0.70.10.tgz
$ cd multiprocess-0.70.10
$ python setup.py build
$ python setup.py install

You will be warned of any missing dependencies and/or settings after you run the “build” step above.

Alternately, multiprocess can be installed with pip or easy_install:

$ pip install multiprocess

NOTE: A C compiler is required to build the included extension module from source. For python 3.3 and above, a C compiler is suggested, but not required. Binary installs do not require a C compiler.

Requirements

multiprocess requires:

- ``python``, **version == 2.7** or **version >= 3.5**
- ``dill``, **version >= 0.3.2**

Optional requirements:

- ``setuptools``, **version >= 0.6**

More Information

Probably the best way to get started is to look at the documentation at http://multiprocess.rtfd.io. See multiprocess.examples for a set of example scripts. You can also run the test suite with python -m multiprocess.tests. Please feel free to submit a ticket on github, or ask a question on stackoverflow (@Mike McKerns). If you would like to share how you use multiprocess in your work, please post send an email (to mmckerns at uqfoundation dot org).

Citation

If you use multiprocess to do research that leads to publication, we ask that you acknowledge use of multiprocess by citing the following in your publication:

M.M. McKerns, L. Strand, T. Sullivan, A. Fang, M.A.G. Aivazis,
"Building a framework for predictive science", Proceedings of
the 10th Python in Science Conference, 2011;
http://arxiv.org/pdf/1202.1056

Michael McKerns and Michael Aivazis,
"pathos: a framework for heterogeneous computing", 2010- ;
https://uqfoundation.github.io/pathos.html

Please see https://uqfoundation.github.io/pathos.html or http://arxiv.org/pdf/1202.1056 for further information.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

multiprocess-0.70.10.zip (2.4 MB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

multiprocess-0.70.10-cp27-cp27m-win_amd64.whl (92.7 kB view details)

Uploaded CPython 2.7mWindows x86-64

multiprocess-0.70.10-cp27-cp27m-win32.whl (91.6 kB view details)

Uploaded CPython 2.7mWindows x86

File details

Details for the file multiprocess-0.70.10.zip.

File metadata

  • Download URL: multiprocess-0.70.10.zip
  • Upload date:
  • Size: 2.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.18.1 setuptools/47.1.1 requests-toolbelt/0.8.0 tqdm/4.14.0 CPython/3.6.10

File hashes

Hashes for multiprocess-0.70.10.zip
Algorithm Hash digest
SHA256 81f388527a0c8766e94fe084fd8a408da5045a9fe7b28e199f684a796f3c6bf8
MD5 a420b7091a45b4e8132db1792797b143
BLAKE2b-256 1a4e4591c45b85fbcbcc3de9554e20e079e0006c4332e0a780ed0883f2b07965

See more details on using hashes here.

File details

Details for the file multiprocess-0.70.10-cp27-cp27m-win_amd64.whl.

File metadata

  • Download URL: multiprocess-0.70.10-cp27-cp27m-win_amd64.whl
  • Upload date:
  • Size: 92.7 kB
  • Tags: CPython 2.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.18.1 setuptools/47.1.1 requests-toolbelt/0.8.0 tqdm/4.14.0 CPython/3.6.10

File hashes

Hashes for multiprocess-0.70.10-cp27-cp27m-win_amd64.whl
Algorithm Hash digest
SHA256 9e604ac3ff7d6aa7da8306e7dd3a76a8b6ba83f5a8a2d8590b2edd1468df6479
MD5 88fc1ac3d5dee011250d6e8740f3f743
BLAKE2b-256 0be00137586a80a8aa752555ffc5e0b23e65e14348b369b582ed48b1d5022297

See more details on using hashes here.

File details

Details for the file multiprocess-0.70.10-cp27-cp27m-win32.whl.

File metadata

  • Download URL: multiprocess-0.70.10-cp27-cp27m-win32.whl
  • Upload date:
  • Size: 91.6 kB
  • Tags: CPython 2.7m, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.18.1 setuptools/47.1.1 requests-toolbelt/0.8.0 tqdm/4.14.0 CPython/3.6.10

File hashes

Hashes for multiprocess-0.70.10-cp27-cp27m-win32.whl
Algorithm Hash digest
SHA256 879ee48882bf7959102010058f30419d72abc90035de70b7259a386dc8b1946a
MD5 d063656d7d948bf41460e1982982cbd6
BLAKE2b-256 ecb6ada68fffcfa032e104e2b4d792f9dab9dbef99c0cc4b3f8e271cd9daa83f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page