Automatic highly parallelized hyperparameter optimizer based on Ax/Botorch
Project description
OmniOpt2 - Hyperparameter Optimizer for SLURM-based Systems
OmniOpt2 is a tool designed to assist researchers, engineers, and data scientists with hyperparameter optimization on SLURM-based clusters, even though it works without it as well. It simplifies large-scale optimization tasks with built-in fault tolerance and flexibility. A graphical user interface (GUI) is available for command creation, accessible at OmniOpt2 GUI. For tutorials on configuration, exit codes, and debugging, visit OmniOpt2 Tutorials.
Main program
omniopt --partition=alpha --experiment_name=example --mem_gb=1 --time=60 \
--worker_timeout=60 --max_eval=500 --num_parallel_jobs=500 --gpus=1 \
--follow --run_program=$(echo 'echo "RESULT: %(param)"' | base64 -w0) \
--parameter param range 0 1000 float
This command initiates OmniOpt2 and installs dependencies if not already
installed. The parameter --run_program uses a
Base64-encoded string to
specify commands. It is recommended to use the
GUI, though.
Plot Results
Generates visualizations, such as scatter and hex scatter plots.
--min and --max adjust the plotted result value range.
Or, with --min and --max:
omniopt_plot --run_dir runs/example/0
omniopt_plot --run_dir runs/example/0 --min 0 --max 100
Using live-share
Use --live_share (also enablable via GUI) to automatically share the job. You will get a URL
where your job data is hosted publically for 30 days, meaning everyone can access your results,
and you can see all kinds of visualizations and export them.
Run Tests (Developer Use Only)
The test suite simulates various scenarios, including handling faulty jobs and ensuring program resilience.
./tests/main
See the automated tests tutorial page for more details.
Install from pypi
This may not use the bleeding-edge version, but if you get the version from here it means, the test suite has completety tested it properly.
pip3 install omniopt2
Install from repo (bleeding edge, may contain untested changes)
pip3 install -e git+https://github.com/NormanTUD/OmniOpt2.git#egg=OmniOpt2
Alternatively, it can be executed directly, as OmniOpt2 will install its dependencies automatically if required.
Error Codes
For common issues and exit codes, see the exit codes tutorial-page.
Autocompletions
Autocomplete files for zsh and bash are in .shells. Run
bash .shells/install
to install them.
Contributions
I'd be glad to see your contributions!
Issues
If you experience any problems, please write issues at my Github Issues page.
Old OmniOpt
The old OmniOpt version, based on HyperOpt, is not supported anymore. It is still available, though, at https://github.com/NormanTUD/LegacyOmniOpt.
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
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 omniopt2-7084.tar.gz.
File metadata
- Download URL: omniopt2-7084.tar.gz
- Upload date:
- Size: 159.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.22
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2b6b98a6862ac65e26f56793df7ab8b8414fb718833f48e981318c2a0f41f92
|
|
| MD5 |
f9f77e95f53875f66550262d39103435
|
|
| BLAKE2b-256 |
58026a71277fdf6e5dd01aae182f7687f69493100778a3ef1702e772b1bbd7a7
|
File details
Details for the file omniopt2-7084-py3-none-any.whl.
File metadata
- Download URL: omniopt2-7084-py3-none-any.whl
- Upload date:
- Size: 361.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.22
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b2e440db048f525c633268bbfb59e62c6afce7d4b65444ecb15adf498b12d2b
|
|
| MD5 |
636fbe29804fa9b626282fef727f2815
|
|
| BLAKE2b-256 |
22e6752024dcbb24c46058bb96720f653f5e5dcc234d7f3f8dbfafd822729986
|