This is the description for ask_and_tell=True
.
This class wraps not only a function but also an optimizer so that we can control the right timing of the addition of data to the optimizer and of job allocation.
While ask_and_tell=False
requires users to wrap objective function and users simply need to pass the wrapped function to the optimizer prepared by users, ask_and_tell=True
runs the simulation on the application side.
Unlike the other worker wrappers, each objective function will not be run in parallel.
Instead, we internally simulate the cumulative runtime for each worker.
For this sake, the provided optimizer must take the so-called ask-and-tell interface.
As long as the optimizer takes this interface, arbitrary optimizers can be used for this class.
Please check examples to know how to encapsulate an optimizer with an incompatible interface and AbstractAskTellOptimizer how the optimizer wrapper should look like.
The benefits of this option are:
- Very stable because all function calls are performed sequentially and unexpected behavior due to parallel computation will not happen while preserving the same results from the parallel version,
- No slow down even when using a large
n_workers
, and - No huge memory consumption caused by multiple in-memory tabular or surrogate datasets. On the other hand, the downsides of this option are to:
- force optimizers to take the ask-and-tell interface,
- not cosider the bottleneck caused by sampling in parallel, and
- be able to not reproduce the effect caused by random seeds.
You can run the example via:
# Random search
$ python -m examples.ask_and_tell.random --bench_name branin --seed 0 --n_workers 4
# Optuna
$ python -m examples.ask_and_tell.optuna --bench_name hpolib --dataset_id 0 --seed 0 --n_workers 4