Distributed computing made easier, using remote objects
Project description
Overview
Distob will take your existing python objects, or a sequence of objects, and scatter them onto many IPython parallel engines, which may be running on a single computer or on a cluster.
In place of the original objects, proxy objects are kept on the client computer that provide the same interface as the original objects. You can continue to use these as if the objects were still local. All methods are passed through to the remote objects, where computation is done.
In particular, sending numpy arrays to the cluster is supported.
A numpy array can also be scattered across the cluster, along a particular axis. Operations on the array can then be automatically done in parallel (either using ufuncs, or by using vectorize() below)
Note: numpy with __numpy_ufunc__ feature enabled (not yet released) is required to support distributed array arithmetic and distributed ufuncs. You can get numpy with this experimental feature enabled here: https://github.com/mattja/numpy/archive/master.zip
Distob is an object layer built on top of ipyparallel, so it will make use of your default IPython parallel profile. This allows different cluster architectures, local CPUs, SSH nodes, PBS, Amazon EC2, etc.
functions
distributed numpy arrays
classes
attributes
engine: the ObjectEngine instance on each host (ObjectHub on the client)
TODO
Allow assignment to slices of remote arrays.
Properly implement caching of remote method results.
Auto-creation of proxy classes at runtime (depends uqfoundation/dill#58)
For ufunc execution, still need to implement reduce, accumulate, reduceat, outer, at methods.
Make proxy classes more robust, adapting wrapt (pypi.python.org/pypi/wrapt)
Thanks
Incorporates pylru.py by Jay Hutchinson, http://github.com/jlhutch/pylru
ipyparallel interactive parallel computing: https://ipyparallel.readthedocs.org/
dill by Mike McKerns for object serialization, see: http://trac.mystic.cacr.caltech.edu/project/pathos
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file distob-0.3.3.tar.gz
.
File metadata
- Download URL: distob-0.3.3.tar.gz
- Upload date:
- Size: 55.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/2.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 93ddc0a8d0f1d1a41d66153b518dffad685a91b9bec9e99f40a3aca0f8065bee |
|
MD5 | ee6c4dd05738fa08a430e64ccbf86b1a |
|
BLAKE2b-256 | bb489a0ba5ec94063ba5eea13f9f0f5f9c63f9979e93046930e83544a6c2dbe5 |