supervised_training_step_amp#
- 
ignite.engine.supervised_training_step_amp(model, optimizer, loss_fn, device=None, non_blocking=False, prepare_batch=<function _prepare_batch>, output_transform=<function <lambda>>, scaler=None)[source]#
- Factory function for supervised training using - torch.cuda.amp.- Parameters
- model (torch.nn.modules.module.Module) – the model to train. 
- optimizer (torch.optim.optimizer.Optimizer) – the optimizer to use. 
- loss_fn (Union[Callable, torch.nn.modules.module.Module]) – the loss function to use. 
- device (Optional[Union[str, torch.device]]) – device type specification (default: None). Applies to batches after starting the engine. Model will not be moved. Device can be CPU, GPU. 
- non_blocking (bool) – 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) – function that receives batch, device, non_blocking and outputs tuple of tensors (batch_x, batch_y). 
- output_transform (Callable) – function that receives ‘x’, ‘y’, ‘y_pred’, ‘loss’ and returns value to be assigned to engine’s state.output after each iteration. Default is returning loss.item(). 
- scaler (Optional[torch.cuda.amp.grad_scaler.GradScaler]) – GradScaler instance for gradient scaling. (default: None) 
 
- Returns
- update function 
- Return type
- Callable 
 - Example: - from ignite.engine import Engine, supervised_training_step_amp model = ... optimizer = ... loss_fn = ... scaler = torch.cuda.amp.GradScaler(2**10) update_fn = supervised_training_step_amp(model, optimizer, loss_fn, 'cuda', scaler=scaler) trainer = Engine(update_fn) - New in version 0.5.0.