
Applies Group Normalization over a mini-batch of inputs as described in the paper Group Normalization.
nn_group_norm(num_groups, num_channels, eps = 1e-05, affine = TRUE)
(int): number of groups to separate the channels into
(int): number of channels expected in input
a value added to the denominator for numerical stability. Default: 1e-5
a boolean value that when set to TRUE
, this module
has learnable per-channel affine parameters initialized to ones (for weights)
and zeros (for biases). Default: TRUE
.
Input:
Output:
The input channels are separated into num_groups
groups, each containing
num_channels / num_groups
channels. The mean and standard-deviation are calculated
separately over the each group. num_channels
if
affine
is TRUE
.
The standard-deviation is calculated via the biased estimator, equivalent to
torch_var(input, unbiased=FALSE)
.
if (torch_is_installed()) {
input <- torch_randn(20, 6, 10, 10)
# Separate 6 channels into 3 groups
m <- nn_group_norm(3, 6)
# Separate 6 channels into 6 groups (equivalent with [nn_instance_morm])
m <- nn_group_norm(6, 6)
# Put all 6 channels into a single group (equivalent with [nn_layer_norm])
m <- nn_group_norm(1, 6)
# Activating the module
output <- m(input)
}
Run the code above in your browser using DataLab