SyncBatchNorm — PyTorch 2.7 documentation (original) (raw)

class torch.nn.SyncBatchNorm(num_features, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True, process_group=None, device=None, dtype=None)[source][source]

Applies Batch Normalization over a N-Dimensional input.

The N-D input is a mini-batch of [N-2]D inputs with additional channel dimension) as described in the paperBatch Normalization: Accelerating Deep Network Training by Reducing Internal Covariate Shift .

y=x−E[x]Var[x]+ϵ∗γ+βy = \frac{x - \mathrm{E}[x]}{ \sqrt{\mathrm{Var}[x] + \epsilon}} * \gamma + \beta

The mean and standard-deviation are calculated per-dimension over all mini-batches of the same process groups. γ\gamma and β\betaare learnable parameter vectors of size C (where C is the input size). By default, the elements of γ\gamma are sampled fromU(0,1)\mathcal{U}(0, 1) and the elements of β\beta are set to 0. The standard-deviation is calculated via the biased estimator, equivalent totorch.var(input, unbiased=False).

Also by default, during training this layer keeps running estimates of its computed mean and variance, which are then used for normalization during evaluation. The running estimates are kept with a default momentumof 0.1.

If track_running_stats is set to False, this layer then does not keep running estimates, and batch statistics are instead used during evaluation time as well.

Note

This momentum argument is different from one used in optimizer classes and the conventional notion of momentum. Mathematically, the update rule for running statistics here isx^new=(1−momentum)×x^+momentum×xt\hat{x}_\text{new} = (1 - \text{momentum}) \times \hat{x} + \text{momentum} \times x_t, where x^\hat{x} is the estimated statistic and xtx_t is the new observed value.

Because the Batch Normalization is done for each channel in the C dimension, computing statistics on (N, +) slices, it’s common terminology to call this Volumetric Batch Normalization or Spatio-temporal Batch Normalization.

Currently SyncBatchNorm only supportsDistributedDataParallel (DDP) with single GPU per process. Usetorch.nn.SyncBatchNorm.convert_sync_batchnorm() to convertBatchNorm*D layer to SyncBatchNorm before wrapping Network with DDP.

Parameters

Shape:

Note

Synchronization of batchnorm statistics occurs only while training, i.e. synchronization is disabled when model.eval() is set or ifself.training is otherwise False.

Examples:

With Learnable Parameters

m = nn.SyncBatchNorm(100)

creating process group (optional)

ranks is a list of int identifying rank ids.

ranks = list(range(8)) r1, r2 = ranks[:4], ranks[4:]

Note: every rank calls into new_group for every

process group created, even if that rank is not

part of the group.

process_groups = [torch.distributed.new_group(pids) for pids in [r1, r2]] process_group = process_groups[0 if dist.get_rank() <= 3 else 1]

Without Learnable Parameters

m = nn.BatchNorm3d(100, affine=False, process_group=process_group) input = torch.randn(20, 100, 35, 45, 10) output = m(input)

network is nn.BatchNorm layer

sync_bn_network = nn.SyncBatchNorm.convert_sync_batchnorm(network, process_group)

only single gpu per process is currently supported

ddp_sync_bn_network = torch.nn.parallel.DistributedDataParallel( sync_bn_network, device_ids=[args.local_rank], output_device=args.local_rank)

classmethod convert_sync_batchnorm(module, process_group=None)[source][source]

Converts all BatchNorm*D layers in the model to torch.nn.SyncBatchNorm layers.

Parameters

Returns

The original module with the converted torch.nn.SyncBatchNormlayers. If the original module is a BatchNorm*D layer, a new torch.nn.SyncBatchNorm layer object will be returned instead.

Example:

Network with nn.BatchNorm layer

module = torch.nn.Sequential( torch.nn.Linear(20, 100), torch.nn.BatchNorm1d(100), ).cuda()

creating process group (optional)

ranks is a list of int identifying rank ids.

ranks = list(range(8)) r1, r2 = ranks[:4], ranks[4:]

Note: every rank calls into new_group for every

process group created, even if that rank is not

part of the group.

process_groups = [torch.distributed.new_group(pids) for pids in [r1, r2]] process_group = process_groups[0 if dist.get_rank() <= 3 else 1] sync_bn_module = torch.nn.SyncBatchNorm.convert_sync_batchnorm(module, process_group)