Skip to main content

parabar

Project description

parabar

Progress bars from tqdm for multiprocessing with pathos in Python.

This is similar in spirit to tqdm_pathos but more simplified.

Installation

pip install parabar

Usage

There is a single function parabar.map.

The two required arguments are the function you want to map and the iterable(s) you want to map over: parabar.map(func, iterable).

If you want to iterate over multiple arguments, you should zip them: parabar.map(func, zip(iterable1, iterable2)).

It has two optional arguments:

  • ncpus = 1: the number of processes for the pool
  • tqdm_kwargs = {}: dictionary of extra arguments to pass to tqdm.

If the length of your iterable is total, you can tell tqdm by using tqdm_kargs = {'total': total}. Otherwise, parabar.map will convert your iterables to a list and use len.

You can provide other fixed positional and keywords arguments to your function that you do not want to iterate over as the reminaing position and keyword arguments: parabar.map(func, iterable, arg1, arg2, kwarg1=None, ncpus=1).

Examples

Function of a single iterable:

f = lambda x: x**2
iterable = [1, 2, 3]

# Serial
y = [f(x) for x in iterable]
print(y)

# Parallel
y = parabar.map(f, iterable)
print(y)

Function of a single iterable, with non-iterable args and kwargs:

f = lambda x, a, b = 0: x**2 * a + b
iterable = [1, 2, 3]
a = 1
b = 0

# Serial
y = [f(x, a, b = b) for x in iterable]
print(y)

# Parallel
y = parabar.map(f, iterable, a, b = b)
print(y)

Function of multiple iterables:

f = lambda x, y: x * y
iterable1 = [1, 2, 3]
iterable2 = [4, 5, 6]

# Serial
z = [f(x, y) for x, y in zip(iterable1, iterable2)]
print(z)

# Parallel
z = parabar.map(f, zip(iterable1, iterable2))
print(z)

Function of multiple iterables, with non-iterable args and kwargs

f = lambda x, y, a, b = 0: x * y * a + b
iterable1 = [1, 2, 3]
iterable2 = [4, 5, 6]
a = 1
b = 0

# Serial
z = [f(x, y, a, b = b) for x, y in zip(iterable1, iterable2)]
print(z)

# Parallel
z = parabar.map(f, zip(iterable1, iterable2), a, b = b)
print(z)

Specify number of processes and keyword arguments for progress bar

from tqdm.auto import tqdm

f = lambda x: x
iterable = [1, 2, 3]
tqdm_kwargs = dict(total = 3, desc = 'iterating')

# Serial
y = [f(x) for x in tqdm(iterable, **tqdm_kwargs)]
print(y)

# Parallel
y = parabar.map(f, iterable, ncpus=2, tqdm_kwargs=tqdm_kwargs)
print(y)

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

parabar-0.2.tar.gz (3.1 kB view details)

Uploaded Source

Built Distribution

parabar-0.2-py3-none-any.whl (3.3 kB view details)

Uploaded Python 3

File details

Details for the file parabar-0.2.tar.gz.

File metadata

  • Download URL: parabar-0.2.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for parabar-0.2.tar.gz
Algorithm Hash digest
SHA256 bf9f148e00cea587caad51eb0ce607550f07a9710d41eea957c12f78c1ada572
MD5 bd32fec2defbc337b65c7b797f981d61
BLAKE2b-256 9932334f1dcc53a2ee911671a90b306421f5084d2b82194e436999ffbabe8607

See more details on using hashes here.

File details

Details for the file parabar-0.2-py3-none-any.whl.

File metadata

  • Download URL: parabar-0.2-py3-none-any.whl
  • Upload date:
  • Size: 3.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for parabar-0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0b8cc55a98c6a5c2aa37513558b63d2abbb5957677c6d8f3f3c94636c41b4759
MD5 87c80ee63afd2b6216e9da70d76189b3
BLAKE2b-256 6702f434c3f684e93348f6098c06e5d4e70180867ce67ad640237f83f52157fe

See more details on using hashes here.

Supported by

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