From 6ad05d3338f9167bf68189cd6c7ce6132d5f7278 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlos=20Mochol=C3=AD?= Date: Thu, 6 May 2021 10:39:01 +0200 Subject: [PATCH] Update `configure_optimizers` docs (#7390) * Update `configure_optimizers` docs * Update pytorch_lightning/core/lightning.py --- pytorch_lightning/core/lightning.py | 57 +++++++++-------------------- 1 file changed, 18 insertions(+), 39 deletions(-) diff --git a/pytorch_lightning/core/lightning.py b/pytorch_lightning/core/lightning.py index 79cf6978fa..109b8fd810 100644 --- a/pytorch_lightning/core/lightning.py +++ b/pytorch_lightning/core/lightning.py @@ -1123,6 +1123,24 @@ class LightningModule( - **Tuple of dictionaries** as described above, with an optional ``"frequency"`` key. - **None** - Fit will run without any optimizer. + Note: + The lr_dict is a dictionary which contains the scheduler and its associated configuration. + The default configuration is shown below. + + .. code-block:: python + + lr_dict = { + 'scheduler': lr_scheduler, # The LR scheduler instance (required) + # The unit of the scheduler's step size, could also be 'step' + 'interval': 'epoch', + 'frequency': 1, # The frequency of the scheduler + 'monitor': 'val_loss', # Metric for `ReduceLROnPlateau` to monitor + 'strict': True, # Whether to crash the training if `monitor` is not found + 'name': None, # Custom name for `LearningRateMonitor` to use + } + + Only the ``"scheduler"`` key is required, the rest will be set to the defaults above. + Note: The ``frequency`` value specified in a dict along with the ``optimizer`` key is an int corresponding to the number of sequential batches optimized with the specific optimizer. @@ -1148,33 +1166,6 @@ class LightningModule( If an LR scheduler is specified for an optimizer using the ``lr_scheduler`` key in the above dict, the scheduler will only be updated when its optimizer is being used. - Note: - The lr_dict is a dictionary which contains the scheduler and its associated configuration. - The default configuration is shown below. - - .. code-block:: python - - lr_dict = { - 'scheduler': lr_scheduler, # The LR scheduler instance (required) - 'interval': 'epoch', # The unit of the scheduler's step size - 'frequency': 1, # The frequency of the scheduler - 'reduce_on_plateau': False, # For ReduceLROnPlateau scheduler - 'monitor': 'val_loss', # Metric for ReduceLROnPlateau to monitor - 'strict': True, # Whether to crash the training if `monitor` is not found - 'name': None, # Custom name for LearningRateMonitor to use - } - - Only the ``"scheduler"`` key is required, the rest will be set to the defaults above. - - Note: - The ``"frequency"`` value is an ``int`` corresponding to the number of sequential batches optimized with the - specific optimizer. It should be given to none or to all of the optimizers. - - There is a difference between passing multiple optimizers in a list and passing multiple optimizers in - dictionaries with a frequency of 1: - In the former case, all optimizers will operate on the given batch in each optimization step. - In the latter, only one optimizer will operate on the given batch at every step. - Examples:: # most cases @@ -1226,18 +1217,6 @@ class LightningModule( at each training step. - If you need to control how often those optimizers step or override the default ``.step()`` schedule, override the :meth:`optimizer_step` hook. - - If you only want to call a learning rate scheduler every ``x`` step or epoch, or want to monitor a custom - metric, you can specify these in a lr_dict: - - .. code-block:: python - - lr_dict = { - 'scheduler': lr_scheduler, - 'interval': 'step', # or 'epoch' - 'monitor': 'val_f1', - 'frequency': x, - } - """ rank_zero_warn("`configure_optimizers` must be implemented to be used with the Lightning Trainer")