ignite.contrib.engines¶
Contribution module of engines and helper tools:
ignite.contrib.engines.tbptt
Aditional tbptt events. |
|
Create a trainer for truncated backprop through time supervised models. |
ignite.contrib.engines.common
Method setups early stopping handler based on the score (named by metric_name) provided by evaluator. |
|
Method adds a handler to |
|
Method adds a handler to |
|
Method to setup ClearML logging on trainer and a list of evaluators. |
|
Helper method to setup trainer with common handlers (it also supports distributed configuration): |
|
Helper method to setup trainer with common handlers (it also supports distributed configuration): |
|
Method to setup MLflow logging on trainer and a list of evaluators. |
|
Method to setup Neptune logging on trainer and a list of evaluators. |
|
Method to setup Polyaxon logging on trainer and a list of evaluators. |
|
Method to setup TensorBoard logging on trainer and a list of evaluators. |
|
|
|
Method to setup Visdom logging on trainer and a list of evaluators. |
|
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
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 saven_saved
of best models based on the metric (named bymetric_name
) provided byevaluator
(i.e.evaluator.state.metrics[metric_name]
). Models with highest metric value will be retained. The logic of how to store objects is delegated tosave_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. Ifsave_handler
is callable class, it can inherit ofBaseSaveHandler
and optionally implementremove
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 withDiskSaver
.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
andload_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 diskn_saved
of best models based on the metric (named bymetric_name
) provided byevaluator
(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
-
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):
handler to setup learning rate scheduling
RunningAverage
on update_function outputTwo progress bars on epochs and optionally on iterations
- 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 storeto_save
. SeeCheckpoint
for more details. Argument is mutually exclusive withoutput_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):
handler to setup learning rate scheduling
RunningAverage
on update_function outputTwo progress bars on epochs and optionally on iterations
- 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 storeto_save
. SeeCheckpoint
for more details. Argument is mutually exclusive withoutput_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
-
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
-
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
-
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
-
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 tosetup_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
-
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