mirror of
https://github.com/clearml/clearml-docs
synced 2025-03-03 10:42:51 +00:00
Edit PyTorch HPO example (#227)
This commit is contained in:
parent
37c43e0826
commit
4835f807cf
@ -3,89 +3,95 @@ title: Image Hyperparameter Optimization - Jupyter Notebook
|
||||
---
|
||||
|
||||
[hyperparameter_search.ipynb](https://github.com/allegroai/clearml/blob/master/examples/frameworks/pytorch/notebooks/image/hyperparameter_search.ipynb)
|
||||
demonstrates integrating ClearML into a Jupyter Notebook which performs automated hyperparameter optimization. This
|
||||
is an example of ClearML automation. It creates a ClearML
|
||||
[HyperParameterOptimizer](../../../../../references/sdk/hpo_optimization_hyperparameteroptimizer.md)
|
||||
object, which is a search controller. The search controller's search strategy optimizer is [OptimizerBOHB](../../../../../references/sdk/hpo_hpbandster_bandster_optimizerbohb.md)
|
||||
The example maximizes total accuracy by finding an optimal batch size, base learning rate, and dropout. ClearML
|
||||
demonstrates using ClearML's [HyperParameterOptimizer](../../../../../references/sdk/hpo_optimization_hyperparameteroptimizer.md)
|
||||
class to perform automated hyperparameter optimization.
|
||||
|
||||
The code creates a HyperParameterOptimizer object, which is a search controller. The search controller uses the
|
||||
[Optuna](../../../../../references/sdk/hpo_optuna_optuna_optimizeroptuna.md) search strategy optimizer.
|
||||
The example maximizes total accuracy by finding an optimal number of epochs, batch size, base learning rate, and dropout. ClearML
|
||||
automatically logs the optimization's top performing experiments.
|
||||
|
||||
The experiment whose hyperparameters are optimized is named `image_classification_CIFAR10`. It is created by running another
|
||||
ClearML example, [image_classification_CIFAR10.ipynb](https://github.com/allegroai/clearml/blob/master/examples/frameworks/pytorch/notebooks/image/image_classification_CIFAR10.ipynb), which must run before `hyperparameter_search.ipynb`.
|
||||
ClearML example, [image_classification_CIFAR10.ipynb](https://github.com/allegroai/clearml/blob/master/examples/frameworks/pytorch/notebooks/image/image_classification_CIFAR10.ipynb),
|
||||
which must run before `hyperparameter_search.ipynb`.
|
||||
|
||||
When `hyperparameter_search.py` runs, it creates an experiment named `Hyper-Parameter Optimization` which is associated
|
||||
with the `Hyper-Parameter Search` project.
|
||||
|
||||
The optimizer Task, `Hyper-Parameter Optimization`, and the experiments appear individually in the **ClearML Web UI**.
|
||||
The optimizer Task, `Hyperparameter Optimization`, and the experiments appear individually in the [ClearML Web UI](../../../../../webapp/webapp_overview.md).
|
||||
|
||||
## Optimizer Task
|
||||
|
||||
### Scalars
|
||||
|
||||
Scalars for total accuracy and remaining budget by iteration, and a plot of total accuracy by iteration appear in **RESULTS** **>** **SCALARS**. Remaining budget indicates the percentage of total iterations for all jobs left before that total is reached.
|
||||
|
||||
These scalars are reported automatically by ClearML from `HyperParameterOptimizer` when it runs.
|
||||
|
||||
data:image/s3,"s3://crabby-images/0cf8a/0cf8ad731fba7c16e691678a853b83a3c32f519e" alt="image"
|
||||
|
||||
### Plots
|
||||
|
||||
A plot for the optimization of total accuracy by job appears in **RESULTS** **>** **SCALARS**.
|
||||
|
||||
This is also reported automatically by ClearML when `HyperParameterOptimizer` runs.
|
||||
|
||||
data:image/s3,"s3://crabby-images/a5a65/a5a65138fa6c9883fe1a4d02de4617bd8467417a" alt="image"
|
||||
|
||||
### Hyperparameters
|
||||
|
||||
`HyperParameterOptimizer` hyperparameters, including the optimizer parameters appear in **CONFIGURATIONS** **>** **HYPER PARAMETERS**.
|
||||
The `HyperParameterOptimizer`'s configuration, which is provided when the object instantiated, are stored under the
|
||||
optimizer task's **CONFIGURATIONS** **>** **HYPER PARAMETERS**.
|
||||
|
||||
These hyperparameters are those in the optimizer Task, where the `HyperParameterOptimizer` object is created.
|
||||
```python
|
||||
optimizer = HyperParameterOptimizer(
|
||||
base_task_id=TEMPLATE_TASK_ID, # This is the experiment we want to optimize
|
||||
# here we define the hyper-parameters to optimize
|
||||
hyper_parameters=[
|
||||
UniformIntegerParameterRange('number_of_epochs', min_value=2, max_value=12, step_size=2),
|
||||
UniformIntegerParameterRange('batch_size', min_value=2, max_value=16, step_size=2),
|
||||
UniformParameterRange('dropout', min_value=0, max_value=0.5, step_size=0.05),
|
||||
UniformParameterRange('base_lr', min_value=0.00025, max_value=0.01, step_size=0.00025),
|
||||
],
|
||||
# setting the objective metric we want to maximize/minimize
|
||||
objective_metric_title='accuracy',
|
||||
objective_metric_series='total',
|
||||
objective_metric_sign='max', # maximize or minimize the objective metric
|
||||
|
||||
optimizer = HyperParameterOptimizer(
|
||||
base_task_id=TEMPLATE_TASK_ID, # This is the experiment we want to optimize
|
||||
# here we define the hyper-parameters to optimize
|
||||
hyper_parameters=[
|
||||
UniformIntegerParameterRange('number_of_epochs', min_value=5, max_value=15, step_size=1),
|
||||
UniformIntegerParameterRange('batch_size', min_value=2, max_value=12, step_size=2),
|
||||
UniformParameterRange('dropout', min_value=0, max_value=0.5, step_size=0.05),
|
||||
UniformParameterRange('base_lr', min_value=0.0005, max_value=0.01, step_size=0.0005),
|
||||
],
|
||||
# this is the objective metric we want to maximize/minimize
|
||||
objective_metric_title='accuracy',
|
||||
objective_metric_series='total',
|
||||
objective_metric_sign='max', # maximize or minimize the objective metric
|
||||
max_number_of_concurrent_tasks=3, # number of concurrent experiments
|
||||
# setting optimizer - clearml supports GridSearch, RandomSearch or OptimizerBOHB
|
||||
optimizer_class=OptimizerBOHB, # can be replaced with OptimizerBOHB
|
||||
execution_queue='default', # queue to schedule the experiments for execution
|
||||
optimization_time_limit=30., # time limit for each experiment (optional, ignored by OptimizerBOHB)
|
||||
pool_period_min=1, # Check the experiments every x minutes
|
||||
# set the maximum number of experiments for the optimization.
|
||||
# OptimizerBOHB sets the total number of iteration as total_max_jobs * max_iteration_per_job
|
||||
total_max_jobs=12,
|
||||
# setting OptimizerBOHB configuration (ignored by other optimizers)
|
||||
min_iteration_per_job=15000, # minimum number of iterations per experiment, till early stopping
|
||||
max_iteration_per_job=150000, # maximum number of iterations per experiment
|
||||
)
|
||||
# setting optimizer - clearml supports GridSearch, RandomSearch, OptimizerBOHB and OptimizerOptuna
|
||||
optimizer_class=OptimizerOptuna,
|
||||
|
||||
data:image/s3,"s3://crabby-images/54147/541472af57c774380295684364478e77245a8a9c" alt="image"
|
||||
# Configuring optimization parameters
|
||||
execution_queue='dan_queue', # queue to schedule the experiments for execution
|
||||
max_number_of_concurrent_tasks=2, # number of concurrent experiments
|
||||
optimization_time_limit=60., # set the time limit for the optimization process
|
||||
compute_time_limit=120, # set the compute time limit (sum of execution time on all machines)
|
||||
total_max_jobs=20, # set the maximum number of experiments for the optimization.
|
||||
# Converted to total number of iteration for OptimizerBOHB
|
||||
min_iteration_per_job=15000, # minimum number of iterations per experiment, till early stopping
|
||||
max_iteration_per_job=150000, # maximum number of iterations per experiment
|
||||
)
|
||||
```
|
||||
|
||||
data:image/s3,"s3://crabby-images/54147/541472af57c774380295684364478e77245a8a9c" alt="Experiment hyperparameters"
|
||||
|
||||
### Console
|
||||
|
||||
All console output from `Hyper-Parameter Optimization` appears in **RESULTS** tab, **CONSOLE** sub-tab.
|
||||
All console output appears in the optimizer task's **RESULTS > CONSOLE**.
|
||||
|
||||
data:image/s3,"s3://crabby-images/37260/37260f84370a9b6b8ce764a6e862e846d36775db" alt="Experiment console"
|
||||
|
||||
### Scalars
|
||||
|
||||
Scalar metrics for total accuracy and remaining budget by iteration, and a plot of total accuracy by iteration appear in the
|
||||
experiment's **RESULTS** **>** **SCALARS**. Remaining budget indicates the percentage of total iterations for all jobs left before that total is reached.
|
||||
|
||||
ClearML automatically reports the scalars generated by `HyperParameterOptimizer`.
|
||||
|
||||
data:image/s3,"s3://crabby-images/0cf8a/0cf8ad731fba7c16e691678a853b83a3c32f519e" alt="Experiment Scalars"
|
||||
|
||||
### Plots
|
||||
|
||||
The optimization task automatically records and monitors the different trial tasks' configuration and execution details, and
|
||||
provides a summary of the optimization results in tabular and parallel coordinate formats. View these plots in the task's **RESULTS** **>**
|
||||
**PLOTS**.
|
||||
|
||||
data:image/s3,"s3://crabby-images/a5a65/a5a65138fa6c9883fe1a4d02de4617bd8467417a" alt="Experiment scatter plot"
|
||||
|
||||
data:image/s3,"s3://crabby-images/e7d1e/e7d1e281d49b78ae8f8cc3e28e90b5138d5d5034" alt="Experiment parallel coordinates"
|
||||
|
||||
data:image/s3,"s3://crabby-images/fe62e/fe62e959fb221fc44d7082850330f757c273c349" alt="Experiment summary plot"
|
||||
|
||||
data:image/s3,"s3://crabby-images/37260/37260f84370a9b6b8ce764a6e862e846d36775db" alt="image"
|
||||
|
||||
## Experiments Comparison
|
||||
|
||||
ClearML automatically logs each job, meaning each experiment that executes with a set of hyperparameters, separately. Each appears as an individual experiment in the **ClearML Web UI**, where the Task name is `image_classification_CIFAR10` and the hyperparameters appended.
|
||||
## Experiments Comparison
|
||||
|
||||
For example:
|
||||
ClearML automatically logs each job, meaning each experiment that executes with a set of hyperparameters, separately. Each appears as an individual experiment in the ClearML Web UI, where the Task name is `image_classification_CIFAR10` and the hyperparameters appended.
|
||||
For example: `image_classification_CIFAR10: base_lr=0.0075 batch_size=12 dropout=0.05 number_of_epochs=6`
|
||||
|
||||
`image_classification_CIFAR10: base_lr=0.0075 batch_size=12 dropout=0.05 number_of_epochs=6`
|
||||
|
||||
Use the **ClearML Web UI** [experiment comparison](../../../../../webapp/webapp_exp_comparing.md) to visualize the following:
|
||||
Use the ClearML Web UI [experiment comparison](../../../../../webapp/webapp_exp_comparing.md) to visualize the following:
|
||||
|
||||
* Side by side hyperparameter value comparison
|
||||
* Metric comparison by hyperparameter
|
||||
@ -97,28 +103,28 @@ Use the **ClearML Web UI** [experiment comparison](../../../../../webapp/webapp_
|
||||
|
||||
In the experiment comparison window, **HYPER PARAMETERS** tab, select **Values** in the list (the right of **+ Add Experiment**), and hyperparameter differences appear with a different background color.
|
||||
|
||||
data:image/s3,"s3://crabby-images/fc881/fc881f30ac6c3942a9071690a39ecc0f68b2b7ac" alt="image"
|
||||
data:image/s3,"s3://crabby-images/fc881/fc881f30ac6c3942a9071690a39ecc0f68b2b7ac" alt="Hyperparameter comparison"
|
||||
|
||||
### Metric Comparison by Hyperparameter
|
||||
|
||||
Select **Parallel Coordinates** in the list, click a **Performance Metric**, and then select the checkboxes of the hyperparameters.
|
||||
|
||||
data:image/s3,"s3://crabby-images/48ae3/48ae3a740b392c54dcdaadf0ebbeee77cd9da370" alt="image"
|
||||
data:image/s3,"s3://crabby-images/48ae3/48ae3a740b392c54dcdaadf0ebbeee77cd9da370" alt="Metric comparison"
|
||||
|
||||
### Scalar Values Comparison
|
||||
|
||||
In the **SCALARS** tab, select **Last Values**, **Min Values**, or **Max Values**. Value differences appear with a different background color.
|
||||
|
||||
data:image/s3,"s3://crabby-images/6d43f/6d43f1ba5267d8e6f22b62aff0a44db8bb5b9522" alt="image"
|
||||
data:image/s3,"s3://crabby-images/6d43f/6d43f1ba5267d8e6f22b62aff0a44db8bb5b9522" alt="Scalar value comparison"
|
||||
|
||||
### Scalar Series Comparison
|
||||
|
||||
Select **Graph** and the scalar series for the jobs appears, where each scalar plot shows the series for all jobs.
|
||||
|
||||
data:image/s3,"s3://crabby-images/15d85/15d85d5cef6b0cb4cf03f2d143129ed18862681d" alt="image"
|
||||
data:image/s3,"s3://crabby-images/15d85/15d85d5cef6b0cb4cf03f2d143129ed18862681d" alt="Scalar series comparison"
|
||||
|
||||
### Debug Samples Comparison
|
||||
|
||||
In the **DEBUG SAMPLES** tab, debug images appear.
|
||||
|
||||
data:image/s3,"s3://crabby-images/c7d4d/c7d4dd9a6def9984fc1df2f0cb3b62bc15dd7ca6" alt="image"
|
||||
data:image/s3,"s3://crabby-images/c7d4d/c7d4dd9a6def9984fc1df2f0cb3b62bc15dd7ca6" alt="Debug sample comparison"
|
BIN
docs/img/examples_hyperparameter_search_02a.png
Normal file
BIN
docs/img/examples_hyperparameter_search_02a.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 177 KiB |
BIN
docs/img/examples_hyperparameter_search_02b.png
Normal file
BIN
docs/img/examples_hyperparameter_search_02b.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 151 KiB |
Loading…
Reference in New Issue
Block a user