mirror of
https://github.com/clearml/clearml-docs
synced 2025-02-19 10:39:29 +00:00
79 lines
2.7 KiB
Markdown
79 lines
2.7 KiB
Markdown
|
---
|
||
|
title: Keras Tuner Integration
|
||
|
---
|
||
|
|
||
|
Integrate **ClearML** into code that uses [Keras Tuner](https://www.tensorflow.org/tutorials/keras/keras_tuner). By
|
||
|
specifying `ClearMLTunerLogger` (see [kerastuner.py](https://github.com/allegroai/clearml/blob/master/clearml/external/kerastuner.py))
|
||
|
as the Keras Tuner logger, **ClearML** automatically logs scalars and hyperparameter optimization.
|
||
|
|
||
|
## ClearMLTunerLogger
|
||
|
|
||
|
Take a look at [keras_tuner_cifar.py](https://github.com/allegroai/clearml/blob/master/examples/frameworks/kerastuner/keras_tuner_cifar.py)
|
||
|
example script, which demonstrates the integration of **ClearML** in a code that uses Keras Tuner.
|
||
|
|
||
|
The script does the following:
|
||
|
1. Creates a `Hyperband` object, which uses Keras Tuner's `Hyperband` tuner. It finds the best hyperparameters to train a
|
||
|
network on a CIFAR10 dataset.
|
||
|
1. When the `Hyperband` object is created, instantiates a `ClearMLTunerLogger` object and assigns it to the `Hyperband` logger.
|
||
|
The `ClearMLTunerLogger` class provides the required binding for **ClearML** automatic logging.
|
||
|
|
||
|
```python
|
||
|
tuner = kt.Hyperband(
|
||
|
build_model,
|
||
|
project_name='kt examples',
|
||
|
logger=ClearMLTunerLogger(),
|
||
|
objective='val_accuracy',
|
||
|
max_epochs=10,
|
||
|
hyperband_iterations=6)
|
||
|
```
|
||
|
|
||
|
When the script runs, it logs:
|
||
|
* Tabular summary of hyperparameters tested and their metrics by trial ID
|
||
|
* Scalar plot showing metrics for all runs
|
||
|
* Summary plot
|
||
|
* Output model with configuration and snapshot location.
|
||
|
|
||
|
## Scalars
|
||
|
|
||
|
**ClearML** logs the scalars from training each network. They appear in the project's page in the **ClearML web UI**, under
|
||
|
**RESULTS** **>** **SCALARS**.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/79d44/79d445151a6e24638d0a883637b93236795ad14c" alt="image"
|
||
|
|
||
|
## Summary of hyperparameter optimization
|
||
|
|
||
|
**ClearML** automatically logs the parameters of each experiment run in the hyperparameter search. They appear in tabular
|
||
|
form in **RESULTS** **>** **PLOTS**.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/0d7de/0d7de0bab0d7adc7d4068f037bdc2e1081a5a1cd" alt="image"
|
||
|
|
||
|
## Artifacts
|
||
|
|
||
|
**ClearML** automatically stores the output model. It appears in **ARTIFACTS** **>** **Output Model**.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/7a0e3/7a0e3cedcb2910740a978420baca27c8deffa694" alt="image"
|
||
|
|
||
|
Model details, such as snap locations, appear in the **MODELS** tab.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/55b0f/55b0f00b496134de0f3d74eef42729d89413947a" alt="image"
|
||
|
|
||
|
The model configuration is stored with the model.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/d3727/d37274bf8a575582a15eb1f55e19fe92c3e50f17" alt="image"
|
||
|
|
||
|
## Configuration objects
|
||
|
|
||
|
### Hyperparameters
|
||
|
|
||
|
**ClearML** automatically logs the TensorFlow Definitions, which appear in **RESULTS** **>** **CONFIGURATION** **>** **HYPER PARAMETERS**.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/c87bb/c87bbdf0b02ecb3ffa23248bacd8d40e60bde8ab" alt="image"
|
||
|
|
||
|
### Configuration
|
||
|
|
||
|
The Task configuration appears in **RESULTS** **>** **CONFIGURATION** **>** **General**.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/acec8/acec851951e307233520168f805d8f8fbfcd72a0" alt="image"
|
||
|
|
||
|
|