• Docs >
  • ignite.contrib.engines
Shortcuts

ignite.contrib.engines

Contribution module of engines and helper tools:

ignite.contrib.engines.tbptt

Tbptt_Events

Aditional tbptt events.

create_supervised_tbptt_trainer

Create a trainer for truncated backprop through time supervised models.

ignite.contrib.engines.common

add_early_stopping_by_val_score

Method setups early stopping handler based on the score (named by metric_name) provided by evaluator.

gen_save_best_models_by_val_score

Method adds a handler to evaluator to save n_saved of best models based on the metric (named by metric_name) provided by evaluator (i.e.

save_best_model_by_val_score

Method adds a handler to evaluator to save on a disk n_saved of best models based on the metric (named by metric_name) provided by evaluator (i.e.

setup_clearml_logging

Method to setup ClearML logging on trainer and a list of evaluators.

setup_common_distrib_training_handlers

Helper method to setup trainer with common handlers (it also supports distributed configuration):

setup_common_training_handlers

Helper method to setup trainer with common handlers (it also supports distributed configuration):

setup_mlflow_logging

Method to setup MLflow logging on trainer and a list of evaluators.

setup_neptune_logging

Method to setup Neptune logging on trainer and a list of evaluators.

setup_plx_logging

Method to setup Polyaxon logging on trainer and a list of evaluators.

setup_tb_logging

Method to setup TensorBoard logging on trainer and a list of evaluators.

setup_trains_logging

setup_trains_logging was renamed to setup_clearml_logging().

setup_visdom_logging

Method to setup Visdom logging on trainer and a list of evaluators.

setup_wandb_logging

Method to setup WandB logging on trainer and a list of evaluators.

Truncated Backpropagation Throught Time

class ignite.contrib.engines.tbptt.Tbptt_Events(value)[source]

Aditional tbptt events.

Additional events for truncated backpropagation throught time dedicated trainer.

ignite.contrib.engines.tbptt.create_supervised_tbptt_trainer(model: torch.nn.modules.module.Module, optimizer: torch.optim.optimizer.Optimizer, loss_fn: torch.nn.modules.module.Module, tbtt_step: int, dim: int = 0, device: Optional[str] = None, non_blocking: bool = False, prepare_batch: Callable = <function _prepare_batch>) → ignite.engine.engine.Engine[source]

Create a trainer for truncated backprop through time supervised models.

Training recurrent model on long sequences is computationally intensive as it requires to process the whole sequence before getting a gradient. However, when the training loss is computed over many outputs (X to many), there is an opportunity to compute a gradient over a subsequence. This is known as truncated backpropagation through time. This supervised trainer apply gradient optimization step every tbtt_step time steps of the sequence, while backpropagating through the same tbtt_step time steps.

Parameters
  • model (torch.nn.Module) – the model to train.

  • optimizer (torch.optim.Optimizer) – the optimizer to use.

  • loss_fn (torch.nn loss function) – the loss function to use.

  • tbtt_step (int) – the length of time chunks (last one may be smaller).

  • dim (int) – axis representing the time dimension.

  • device (str, optional) – device type specification (default: None). Applies to batches.

  • non_blocking (bool, optional) – if True and this copy is between CPU and GPU, the copy may occur asynchronously with respect to the host. For other cases, this argument has no effect.

  • prepare_batch (callable, optional) – function that receives batch, device, non_blocking and outputs tuple of tensors (batch_x, batch_y).

Warning

The internal use of device has changed. device will now only be used to move the input data to the correct device. The model should be moved by the user before creating an optimizer.

For more information see:

Returns

a trainer engine with supervised update function.

Return type

Engine

Helper methods to setup trainer/evaluator

ignite.contrib.engines.common.add_early_stopping_by_val_score(patience: int, evaluator: ignite.engine.engine.Engine, trainer: ignite.engine.engine.Engine, metric_name: str) → ignite.handlers.early_stopping.EarlyStopping[source]

Method setups early stopping handler based on the score (named by metric_name) provided by evaluator. Metric value should increase in order to keep training and not early stop.

Parameters
  • patience (int) – number of events to wait if no improvement and then stop the training.

  • evaluator (Engine) – evaluation engine used to provide the score

  • trainer (Engine) – trainer engine to stop the run if no improvement.

  • metric_name (str) – metric name to use for score evaluation. This metric should be present in evaluator.state.metrics.

Returns

A EarlyStopping handler.

ignite.contrib.engines.common.gen_save_best_models_by_val_score(save_handler: Union[Callable, ignite.handlers.checkpoint.BaseSaveHandler], evaluator: ignite.engine.engine.Engine, models: Union[torch.nn.modules.module.Module, Dict[str, torch.nn.modules.module.Module]], metric_name: str, n_saved: int = 3, trainer: Optional[ignite.engine.engine.Engine] = None, tag: str = 'val', **kwargs: Any) → ignite.handlers.checkpoint.Checkpoint[source]

Method adds a handler to evaluator to save n_saved of best models based on the metric (named by metric_name) provided by evaluator (i.e. evaluator.state.metrics[metric_name]). Models with highest metric value will be retained. The logic of how to store objects is delegated to save_handler.

Parameters
  • save_handler (callable or BaseSaveHandler) – Method or callable class to use to save engine and other provided objects. Function receives two objects: checkpoint as a dictionary and filename. If save_handler is callable class, it can inherit of BaseSaveHandler and optionally implement remove method to keep a fixed number of saved checkpoints. In case if user needs to save engine’s checkpoint on a disk, save_handler can be defined with DiskSaver.

  • evaluator (Engine) – evaluation engine used to provide the score

  • models (nn.Module or Mapping) – model or dictionary with the object to save. Objects should have implemented state_dict and load_state_dict methods.

  • metric_name (str) – metric name to use for score evaluation. This metric should be present in evaluator.state.metrics.

  • n_saved (int, optional) – number of best models to store

  • trainer (Engine, optional) – trainer engine to fetch the epoch when saving the best model.

  • tag (str, optional) – score name prefix: {tag}_{metric_name}. By default, tag is “val”.

  • **kwargs – optional keyword args to be passed to construct Checkpoint.

Returns

A Checkpoint handler.

ignite.contrib.engines.common.save_best_model_by_val_score(output_path: str, evaluator: ignite.engine.engine.Engine, model: torch.nn.modules.module.Module, metric_name: str, n_saved: int = 3, trainer: Optional[ignite.engine.engine.Engine] = None, tag: str = 'val', **kwargs: Any) → ignite.handlers.checkpoint.Checkpoint[source]

Method adds a handler to evaluator to save on a disk n_saved of best models based on the metric (named by metric_name) provided by evaluator (i.e. evaluator.state.metrics[metric_name]). Models with highest metric value will be retained.

Parameters
  • output_path (str) – output path to indicate where to save best models

  • evaluator (Engine) – evaluation engine used to provide the score

  • model (nn.Module) – model to store

  • metric_name (str) – metric name to use for score evaluation. This metric should be present in evaluator.state.metrics.

  • n_saved (int, optional) – number of best models to store

  • trainer (Engine, optional) – trainer engine to fetch the epoch when saving the best model.

  • tag (str, optional) – score name prefix: {tag}_{metric_name}. By default, tag is “val”.

  • **kwargs – optional keyword args to be passed to construct Checkpoint.

Returns

A Checkpoint handler.

ignite.contrib.engines.common.setup_clearml_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.clearml_logger.ClearMLLogger[source]

Method to setup ClearML logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

ClearMLLogger

ignite.contrib.engines.common.setup_common_distrib_training_handlers(trainer: ignite.engine.engine.Engine, train_sampler: Optional[torch.utils.data.distributed.DistributedSampler] = None, to_save: Optional[Mapping] = None, save_every_iters: int = 1000, output_path: Optional[str] = None, lr_scheduler: Optional[Union[ignite.contrib.handlers.param_scheduler.ParamScheduler, torch.optim.lr_scheduler._LRScheduler]] = None, with_gpu_stats: bool = False, output_names: Optional[Iterable[str]] = None, with_pbars: bool = True, with_pbar_on_iters: bool = True, log_every_iters: int = 100, stop_on_nan: bool = True, clear_cuda_cache: bool = True, save_handler: Optional[Union[Callable, ignite.handlers.checkpoint.BaseSaveHandler]] = None, **kwargs: Any) → None

Helper method to setup trainer with common handlers (it also supports distributed configuration):

Parameters
  • trainer (Engine) – trainer engine. Output of trainer’s update_function should be a dictionary or sequence or a single tensor.

  • train_sampler (torch.utils.data.DistributedSampler, optional) – Optional distributed sampler used to call set_epoch method on epoch started event.

  • to_save (dict, optional) – dictionary with objects to save in the checkpoint. This argument is passed to Checkpoint instance.

  • save_every_iters (int, optional) – saving interval. By default, to_save objects are stored each 1000 iterations.

  • output_path (str, optional) – output path to indicate where to_save objects are stored. Argument is mutually exclusive with save_handler.

  • lr_scheduler (ParamScheduler or subclass of torch.optim.lr_scheduler._LRScheduler) – learning rate scheduler as native torch LRScheduler or ignite’s parameter scheduler.

  • with_gpu_stats (bool, optional) – if True, GpuInfo is attached to the trainer. This requires pynvml package to be installed.

  • output_names (list/tuple, optional) – list of names associated with update_function output dictionary.

  • with_pbars (bool, optional) – if True, two progress bars on epochs and optionally on iterations are attached. Default, True.

  • with_pbar_on_iters (bool, optional) – if True, a progress bar on iterations is attached to the trainer. Default, True.

  • log_every_iters (int, optional) – logging interval for GpuInfo and for epoch-wise progress bar. Default, 100.

  • stop_on_nan (bool, optional) – if True, TerminateOnNan handler is added to the trainer. Default, True.

  • clear_cuda_cache (bool, optional) – if True, torch.cuda.empty_cache() is called every end of epoch. Default, True.

  • save_handler (callable or BaseSaveHandler, optional) – Method or callable class to use to store to_save. See Checkpoint for more details. Argument is mutually exclusive with output_path.

  • **kwargs – optional keyword args to be passed to construct Checkpoint.

ignite.contrib.engines.common.setup_common_training_handlers(trainer: ignite.engine.engine.Engine, train_sampler: Optional[torch.utils.data.distributed.DistributedSampler] = None, to_save: Optional[Mapping] = None, save_every_iters: int = 1000, output_path: Optional[str] = None, lr_scheduler: Optional[Union[ignite.contrib.handlers.param_scheduler.ParamScheduler, torch.optim.lr_scheduler._LRScheduler]] = None, with_gpu_stats: bool = False, output_names: Optional[Iterable[str]] = None, with_pbars: bool = True, with_pbar_on_iters: bool = True, log_every_iters: int = 100, stop_on_nan: bool = True, clear_cuda_cache: bool = True, save_handler: Optional[Union[Callable, ignite.handlers.checkpoint.BaseSaveHandler]] = None, **kwargs: Any) → None[source]

Helper method to setup trainer with common handlers (it also supports distributed configuration):

Parameters
  • trainer (Engine) – trainer engine. Output of trainer’s update_function should be a dictionary or sequence or a single tensor.

  • train_sampler (torch.utils.data.DistributedSampler, optional) – Optional distributed sampler used to call set_epoch method on epoch started event.

  • to_save (dict, optional) – dictionary with objects to save in the checkpoint. This argument is passed to Checkpoint instance.

  • save_every_iters (int, optional) – saving interval. By default, to_save objects are stored each 1000 iterations.

  • output_path (str, optional) – output path to indicate where to_save objects are stored. Argument is mutually exclusive with save_handler.

  • lr_scheduler (ParamScheduler or subclass of torch.optim.lr_scheduler._LRScheduler) – learning rate scheduler as native torch LRScheduler or ignite’s parameter scheduler.

  • with_gpu_stats (bool, optional) – if True, GpuInfo is attached to the trainer. This requires pynvml package to be installed.

  • output_names (list/tuple, optional) – list of names associated with update_function output dictionary.

  • with_pbars (bool, optional) – if True, two progress bars on epochs and optionally on iterations are attached. Default, True.

  • with_pbar_on_iters (bool, optional) – if True, a progress bar on iterations is attached to the trainer. Default, True.

  • log_every_iters (int, optional) – logging interval for GpuInfo and for epoch-wise progress bar. Default, 100.

  • stop_on_nan (bool, optional) – if True, TerminateOnNan handler is added to the trainer. Default, True.

  • clear_cuda_cache (bool, optional) – if True, torch.cuda.empty_cache() is called every end of epoch. Default, True.

  • save_handler (callable or BaseSaveHandler, optional) – Method or callable class to use to store to_save. See Checkpoint for more details. Argument is mutually exclusive with output_path.

  • **kwargs – optional keyword args to be passed to construct Checkpoint.

ignite.contrib.engines.common.setup_mlflow_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.mlflow_logger.MLflowLogger[source]

Method to setup MLflow logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

MLflowLogger

ignite.contrib.engines.common.setup_neptune_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.neptune_logger.NeptuneLogger[source]

Method to setup Neptune logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

NeptuneLogger

ignite.contrib.engines.common.setup_plx_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.polyaxon_logger.PolyaxonLogger[source]

Method to setup Polyaxon logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

PolyaxonLogger

ignite.contrib.engines.common.setup_tb_logging(output_path: str, trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.tensorboard_logger.TensorboardLogger[source]

Method to setup TensorBoard logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • output_path (str) – logging directory path

  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

TensorboardLogger

ignite.contrib.engines.common.setup_trains_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.clearml_logger.ClearMLLogger[source]

setup_trains_logging was renamed to setup_clearml_logging().

ignite.contrib.engines.common.setup_visdom_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.visdom_logger.VisdomLogger[source]

Method to setup Visdom logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

VisdomLogger

ignite.contrib.engines.common.setup_wandb_logging(trainer: ignite.engine.engine.Engine, optimizers: Optional[Union[torch.optim.optimizer.Optimizer, Dict[str, torch.optim.optimizer.Optimizer]]] = None, evaluators: Optional[Union[ignite.engine.engine.Engine, Dict[str, ignite.engine.engine.Engine]]] = None, log_every_iters: int = 100, **kwargs: Any) → ignite.contrib.handlers.wandb_logger.WandBLogger[source]

Method to setup WandB logging on trainer and a list of evaluators. Logged metrics are:

  • Training metrics, e.g. running average loss values

  • Learning rate(s)

  • Evaluation metrics

Parameters
  • trainer (Engine) – trainer engine

  • optimizers (torch.optim.Optimizer or dict of torch.optim.Optimizer, optional) – single or dictionary of torch optimizers. If a dictionary, keys are used as tags arguments for logging.

  • evaluators (Engine or dict of Engine, optional) – single or dictionary of evaluators. If a dictionary, keys are used as tags arguments for logging.

  • log_every_iters (int, optional) – interval for loggers attached to iteration events. To log every iteration, value can be set to 1 or None.

  • **kwargs – optional keyword args to be passed to construct the logger.

Returns

WandBLogger