2020-05-05 02:16:54 +00:00
.. testsetup :: *
from pytorch_lightning.trainer.trainer import Trainer
from pytorch_lightning.callbacks.early_stopping import EarlyStopping
2020-09-14 01:04:21 +00:00
.. _early_stopping:
2020-05-05 02:16:54 +00:00
2020-10-07 17:01:50 +00:00
***** ***** *** *
2020-02-11 04:55:22 +00:00
Early stopping
2020-10-07 17:01:50 +00:00
***** ***** *** *
2020-02-11 04:55:22 +00:00
2020-10-08 09:49:56 +00:00
.. raw :: html
2020-10-08 19:54:52 +00:00
<video width="50%" max-width="400px" controls
2020-10-08 09:49:56 +00:00
poster="https://pl-bolts-doc-images.s3.us-east-2.amazonaws.com/pl_docs/trainer_flags/yt_thumbs/thumb_earlystop.png"
src="https://pl-bolts-doc-images.s3.us-east-2.amazonaws.com/pl_docs/yt/Trainer+flags+19-+early+stopping_1.mp4"></video>
|
2020-04-08 12:38:53 +00:00
Stopping an epoch early
2020-10-07 17:01:50 +00:00
=======================
2020-10-02 19:46:46 +00:00
You can stop an epoch early by overriding :meth: `~pytorch_lightning.core.hooks.ModelHooks.on_train_batch_start` to return `` -1 `` when some condition is met.
2020-04-08 12:38:53 +00:00
If you do this repeatedly, for every epoch you had originally requested, then this will stop your entire run.
2020-06-19 06:38:10 +00:00
----------
2020-10-07 17:01:50 +00:00
Early stopping based on metric using the EarlyStopping Callback
===============================================================
2020-05-25 17:33:00 +00:00
The
:class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping`
callback can be used to monitor a validation metric and stop the training when no improvement is observed.
2020-09-30 12:31:16 +00:00
To enable it:
2020-05-05 02:16:54 +00:00
2020-10-07 17:01:50 +00:00
- Import :class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping` callback.
2021-04-20 23:23:36 +00:00
- Log the metric you want to monitor using :func: `~pytorch_lightning.core.lightning.LightningModule.log` method.
2020-10-07 17:01:50 +00:00
- Init the callback, and set `monitor` to the logged metric of your choice.
- Pass the :class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping` callback to the :class: `~pytorch_lightning.trainer.trainer.Trainer` callbacks flag.
2020-09-30 12:31:16 +00:00
2020-10-07 17:01:50 +00:00
.. code-block :: python
2020-09-30 12:31:16 +00:00
2020-10-07 17:01:50 +00:00
from pytorch_lightning.callbacks.early_stopping import EarlyStopping
2020-05-05 02:16:54 +00:00
2021-07-30 12:10:15 +00:00
def validation_step(self):
self.log("val_loss", loss)
trainer = Trainer(callbacks=[EarlyStopping(monitor="val_loss")])
2020-05-05 02:16:54 +00:00
2021-04-20 23:23:36 +00:00
You can customize the callbacks behaviour by changing its parameters.
2020-02-11 04:55:22 +00:00
2021-01-26 09:44:54 +00:00
.. testcode ::
2020-02-11 04:55:22 +00:00
2021-07-30 12:10:15 +00:00
early_stop_callback = EarlyStopping(monitor="val_accuracy", min_delta=0.00, patience=3, verbose=False, mode="max")
2020-10-07 17:01:50 +00:00
trainer = Trainer(callbacks=[early_stop_callback])
2020-02-11 04:55:22 +00:00
2021-04-20 23:23:36 +00:00
Additional parameters that stop training at extreme points:
- `` stopping_threshold `` : Stops training immediately once the monitored quantity reaches this threshold.
It is useful when we know that going beyond a certain optimal value does not further benefit us.
- `` divergence_threshold `` : Stops training as soon as the monitored quantity becomes worse than this threshold.
When reaching a value this bad, we believe the model cannot recover anymore and it is better to stop early and run with different initial conditions.
- `` check_finite `` : When turned on, we stop training if the monitored metric becomes NaN or infinite.
2020-10-07 20:10:41 +00:00
In case you need early stopping in a different part of training, subclass :class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping`
2020-05-25 17:33:00 +00:00
and change where it is called:
.. testcode ::
class MyEarlyStopping(EarlyStopping):
def on_validation_end(self, trainer, pl_module):
# override this to disable early stopping at the end of val loop
pass
def on_train_end(self, trainer, pl_module):
# instead, do it at the end of training loop
self._run_early_stopping_check(trainer, pl_module)
.. note ::
2020-10-07 20:10:41 +00:00
The :class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping` callback runs
at the end of every validation epoch,
2020-05-25 17:33:00 +00:00
which, under the default configuration, happen after every training epoch.
However, the frequency of validation can be modified by setting various parameters
2020-10-07 20:10:41 +00:00
in the :class: `~pytorch_lightning.trainer.trainer.Trainer` ,
2020-05-25 17:33:00 +00:00
for example :paramref: `~pytorch_lightning.trainer.trainer.Trainer.check_val_every_n_epoch`
and :paramref: `~pytorch_lightning.trainer.trainer.Trainer.val_check_interval` .
It must be noted that the `patience` parameter counts the number of
validation epochs with no improvement, and not the number of training epochs.
Therefore, with parameters `check_val_every_n_epoch=10` and `patience=3` , the trainer
will perform at least 40 training epochs before being stopped.
2020-03-31 06:24:26 +00:00
2020-04-05 09:38:52 +00:00
.. seealso ::
2020-05-05 02:16:54 +00:00
- :class: `~pytorch_lightning.trainer.trainer.Trainer`
- :class: `~pytorch_lightning.callbacks.early_stopping.EarlyStopping`