Skip to content

Parallel

This module provides a common interface to parallelization backends. The list of supported backends is here. Backends can be selected with the backend argument of an instance of ParallelConfig, as seen in the examples below.

We use executors to submit tasks in parallel. The basic high-level pattern is

from pydvl.parallel import init_executor, ParallelConfig

config = ParallelConfig(backend="ray")
with init_executor(max_workers=1, config=config) as executor:
    future = executor.submit(lambda x: x + 1, 1)
    result = future.result()
assert result == 2

Running a map-reduce job is also easy:

from pydvl.parallel import init_executor, ParallelConfig

config = ParallelConfig(backend="joblib")
with init_executor(config=config) as executor:
    results = list(executor.map(lambda x: x + 1, range(5)))
assert results == [1, 2, 3, 4, 5]

There is an alternative map-reduce implementation MapReduceJob which internally uses joblib's higher level API with Parallel()