mindformers.wrapper.MFPipelineWithLossScaleCell
- class mindformers.wrapper.MFPipelineWithLossScaleCell(network, optimizer, use_clip_grad=True, max_grad_norm=1.0, scale_sense=1.0, micro_batch_num=1, local_norm=False, calculate_per_token_loss=False, **kwargs)[source]
Append a train-one-step cell with loss scale of pipeline parallel for MindFormers.
- Parameters
network (Cell) – The training network. Note that loss function should have been added.
optimizer (Optimizer) – Optimizer for updating the weights.
use_clip_grad (bool, optional) – Whether to use gradient clipping. Default:
True
.max_grad_norm (float, optional) – Maximum gradient constraint value. Default:
1.0
.scale_sense (Union[Tensor, Cell], optional) – Cell to do the loss scale. Default:
1.0
.micro_batch_num (int, optional) – Micro batch number of pipeline parallel. Default:
1
.local_norm (bool, optional) – Whether to calculate the local norm. Default:
False
.calculate_per_token_loss (bool, optional) – Whether to calculate the loss of each token. Default:
False
.kwargs (Any) – Additional parameters.
- Inputs:
(*inputs) (Tuple(Tensor)) - Tuple of input tensors with shape \((N, \ldots)\).
- Outputs:
Tuple of 5 or 7 Tensor, the loss, overflow flag, current loss scale value, learning rate, global grads norm, local grads norm and size of local norm grads.
loss (Tensor) - A scalar, the loss value.
overflow (Tensor) - A scalar, whether overflow occur or not, the type is bool.
loss scale (Tensor) - The loss scale value, the shape is \(()\) or \((1,)\).
learning rate (Tensor) - A scalar, the learning rate of the optimizer.
global norm (Tensor) - A scalar, the global norm of all grads, only be calculated when use_clip_grad=True, otherwise None.
local_norm (Tensor) - The local norm of the grads by group, only be returned when local_norm=True.
size (Tensor) - The sizes of each grads group, only be returned when local_norm=True.
- Raises
TypeError – If scale_sense is neither Cell nor Tensor.
ValueError – If shape of scale_sense is neither (1,) nor ().
ValueError – If the parallel mode is not one of [ParallelMode.SEMI_AUTO_PARALLEL, ParallelMode.AUTO_PARALLEL].