Utilities for multi-modal architectures team
Project description
mmar-utils
Common pure/IO utilities for multi-modal architectures team.
Installation
pip install mmar-utils
parallel_map
Mix of joblib.Parallel and tqdm.
Similar libraries
joblib.Parallel: https://joblib.readthedocs.io/en/latest/parallel.html
- doesn't support showing progress out of the box
Syntax comparison ( assuming tqdm disabled )
from math import sqrt, pow
from joblib import Parallel as P, delayed as d
from agi_med_utils import parallel_map
# ONE-ARG: THREADING
print(P(n_jobs=2)(map(d(sqrt), range(5))))
print(P(n_jobs=2)(d(sqrt)(i) for i in range(5)))
print(parallel_map(sqrt, range(5)))
# > [0.0, 1.0, 2.0, 3.0, 4.0, 5.0]
# ONE-ARG: MULTIPROCESSING
print(P(n_jobs=2, backend='multiprocessing')(d(sqrt)(i) for i in range(3)))
print(parallel_map(sqrt, range(3), process=True))
# > [0.0, 1.0, 1.4142135623730951]
# MANY-ARGS: THREADING
pow_args = [(i, j) for i in range(1, 4) for j in range(1, 3)]
print(P(n_jobs=2)(d(pow)(i, j) for i, j in pow_args))
print(parallel_map(pow, pow_args, multiple_args=True))
# > [1.0, 1.0, 2.0, 4.0, 3.0, 9.0]
# KWARGS: THREADING
def ipow_kw(*, x, y):
return 1 / pow(x, y)
ipow_kwargs = [{'x': i, 'y': j} for i, j in pow_args]
print(P(n_jobs=2)(d(ipow_kw)(**kw) for kw in ipow_kwargs))
print(parallel_map(ipow_kw, ipow_kwargs, kwargs_args=True))
# > [1.0, 1.0, 0.5, 0.25, 0.3333333333333333, 0.1111111111111111]
# KWARGS: MULTIPROCESSING
def ipow_kw_inc(*, x, y):
return 1 / pow(x, y) + 1
print(P(n_jobs=2, backend='multiprocessing')(d(ipow_kw_inc)(**kw) for kw in ipow_kwargs))
print(parallel_map(ipow_kw_inc, ipow_kwargs, kwargs_args=True, process=True))
# > [2.0, 2.0, 1.5, 1.25, 1.3333333333333333, 1.1111111111111112]
pqdm: https://pqdm.readthedocs.io/en/latest/usage.html
trace_with
Decorator for function which executes some callback on each function call.
Similar libraries
functrace: https://github.com/idanhazan/functrace
- does not remember start datetime of call, which is critical
- supports selection of parameters to remember
functrace.TraceResultobject is not serializable out of the box
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
mmar_utils-1.1.16.tar.gz
(12.5 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mmar_utils-1.1.16.tar.gz.
File metadata
- Download URL: mmar_utils-1.1.16.tar.gz
- Upload date:
- Size: 12.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.31
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7d74c4e897c09f7603e5c6b749b4c0ad1dc7406d1457c5cc52c6d2a6ac8cd48
|
|
| MD5 |
5fcbec7d38d0fbfbe698b338c34f6de9
|
|
| BLAKE2b-256 |
ecc8ffe961e6e52e7230380f90742ac9188379ad3e21ff5da411f934f2ca77e8
|
File details
Details for the file mmar_utils-1.1.16-py3-none-any.whl.
File metadata
- Download URL: mmar_utils-1.1.16-py3-none-any.whl
- Upload date:
- Size: 16.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.31
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b055b73c5c1e3dc6ffd26f4200ea018ad72c2b94d402e907344e5f6b138217ba
|
|
| MD5 |
23cc41cb40c638224f2cab6a42ee648d
|
|
| BLAKE2b-256 |
bd32681a167de56a9dc7c2a0f3f85ce244d6a903b6737537d788c9327a89866c
|