Source code for composer.core.callback

# Copyright 2022 MosaicML Composer authors
# SPDX-License-Identifier: Apache-2.0

"""Base module for callbacks."""
from __future__ import annotations

import abc
from typing import TYPE_CHECKING, Any

from composer.core.serializable import Serializable

if TYPE_CHECKING:
    from composer import Event, State
    from composer.loggers import Logger

__all__ = ['Callback']


[docs]class Callback(Serializable, abc.ABC): """Base class for callbacks. Callbacks provide hooks that can run at each training loop :class:`.Event`. A callback is similar to an :class:`.Algorithm` in that they are run on specific events, but it differs from an :class:`.Algorithm` in that it should not modify the training of the model. By convention, callbacks should not modify the :class:`.State`. They are typically used to for non-essential recording functions such as logging or timing. Callbacks can be implemented in two ways: #. Override the individual methods named for each :class:`.Event`. For example, .. doctest:: >>> class MyCallback(Callback): ... def epoch_start(self, state: State, logger: Logger): ... print(f'Epoch: {int(state.timestamp.epoch)}') >>> # construct trainer object with your callback >>> trainer = Trainer( ... model=model, ... train_dataloader=train_dataloader, ... eval_dataloader=eval_dataloader, ... optimizers=optimizer, ... max_duration="1ep", ... callbacks=[MyCallback()], ... ) >>> # trainer will run MyCallback whenever the EPOCH_START >>> # is triggered, like this: >>> _ = trainer.engine.run_event(Event.EPOCH_START) Epoch: 0 #. Override :meth:`run_event` if you want a single method to handle all events. If this method is overridden, then the individual methods corresponding to each event name (such as :meth:`epoch_start`) will no longer be automatically invoked. For example, if you override :meth:`run_event`, then :meth:`epoch_start` will not be called on the :attr:`.Event.EPOCH_START` event, :meth:`batch_start` will not be called on the :attr:`.Event.BATCH_START`, etc. However, you can invoke :meth:`epoch_start`, :meth:`batch_start`, etc. in your overriding implementation of :meth:`run_event`. For example, .. doctest:: >>> class MyCallback(Callback): ... def run_event(self, event: Event, state: State, logger: Logger): ... if event == Event.EPOCH_START: ... print(f'Epoch: {int(state.timestamp.epoch)}') >>> # construct trainer object with your callback >>> trainer = Trainer( ... model=model, ... train_dataloader=train_dataloader, ... eval_dataloader=eval_dataloader, ... optimizers=optimizer, ... max_duration="1ep", ... callbacks=[MyCallback()], ... ) >>> # trainer will run MyCallback whenever the EPOCH_START >>> # is triggered, like this: >>> _ = trainer.engine.run_event(Event.EPOCH_START) Epoch: 0 """ def __init__(self, *args: Any, **kwargs: Any) -> None: # Stub signature for pyright del args, kwargs # unused pass
[docs] def run_event(self, event: Event, state: State, logger: Logger) -> None: """Called by the engine on each event. Args: event (Event): The event. state (State): The state. logger (Logger): The logger. """ event_cb = getattr(self, event.value) return event_cb(state, logger)
[docs] def init(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.INIT` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_load(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_LOAD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_load(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_LOAD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def fit_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.FIT_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def iteration_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.ITERATION_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def epoch_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EPOCH_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_dataloader(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_DATALOADER` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_dataloader(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_DATALOADER` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def batch_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BATCH_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_train_batch(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_TRAIN_BATCH` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_loss(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_LOSS` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_loss(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_LOSS` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def before_backward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BEFORE_BACKWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_backward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_BACKWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def after_train_batch(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.AFTER_TRAIN_BATCH` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def batch_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BATCH_END` event. .. note:: The following :attr:`.State.timestamp` member variables are incremented immediately before the :attr:`.Event.BATCH_END` event. +------------------------------------+ | :attr:`.Timestamp.batch` | +------------------------------------+ | :attr:`.Timestamp.batch_in_epoch` | +------------------------------------+ | :attr:`.Timestamp.sample` | +------------------------------------+ | :attr:`.Timestamp.sample_in_epoch` | +------------------------------------+ | :attr:`.Timestamp.token` | +------------------------------------+ | :attr:`.Timestamp.token_in_epoch` | +------------------------------------+ Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def batch_checkpoint(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.BATCH_CHECKPOINT` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def epoch_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EPOCH_END` event. .. note:: The following :attr:`.State.timestamp` member variables are incremented immediately before the :attr:`.Event.EPOCH_END` event. +--------------------------------------+ | :attr:`.Timestamp.epoch` | +--------------------------------------+ | :attr:`.Timestamp.epoch_in_iteration`| +--------------------------------------+ Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def epoch_checkpoint(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EPOCH_CHECKPOINT` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def iteration_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.ITERATION_END` event. .. note:: :attr:`.State.timestamp` member variable :attr:`.Timestamp.iteration` is incremented immediately before :attr:`.Event.ITERATION_END`. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def iteration_checkpoint(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.ITERATION_CHECKPOINT` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_batch_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_BATCH_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_before_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_BATCH_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_after_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_AFTER_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_batch_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_BATCH_END` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def predict_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.PREDICT_END` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_before_all(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_BEFORE_ALL` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_batch_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_BATCH_START` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_before_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_BATCH_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_after_forward(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_AFTER_FORWARD` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_batch_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_BATCH_END` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_END` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_after_all(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_AFTER_ALL` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def eval_standalone_start(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_STANDALONE_START` event. Args: state (State): The training state. logger (Logger): The logger. """ pass
[docs] def eval_standalone_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.EVAL_STANDALONE_END` event. Args: state (State): The training state. logger (Logger): The logger. """ pass
[docs] def fit_end(self, state: State, logger: Logger) -> None: """Called on the :attr:`.Event.FIT_END` event. Args: state (State): The training state. logger (Logger): The logger. """ del state, logger # unused pass
[docs] def close(self, state: State, logger: Logger) -> None: """Called whenever the trainer finishes training, even when there is an exception. It should be used for clean up tasks such as flushing I/O streams and/or closing any files that may have been opened during the :attr:`.Event.INIT` event. Args: state (State): The training state. logger (Logger): The logger. """ pass
[docs] def post_close(self) -> None: """Called after :meth:`close` has been invoked for each callback. Very few callbacks should need to implement :meth:`post_close`. This callback can be used to back up any data that may have been written by other callbacks during :meth:`close`. """ pass