nn.LayerNorm的参数

nn.LayerNorm的参数:

参考:
1、pytorch LayerNorm参数详解,计算过程
2、nn.LayerNorm的具体实现方法(通过公式复现)

normalized_shape

如果传入整数,比如4,则被看做只有一个整数的list,此时LayerNorm会对输入的最后一维进行归一化,这个int值需要和输入的最后一维一样大。

假设此时输入的数据维度是[3, 4],则对3个长度为4的向量求均值方差,得到3个均值和3个方差,分别对这3行进行归一化(每一行的4个数字都是均值为0,方差为1);LayerNorm中的weight和bias也分别包含4个数字,重复使用3次,对每一行进行仿射变换(仿射变换即乘以weight中对应的数字后,然后加bias中对应的数字),并会在反向传播时得到学习。
如果输入的是个list或者torch.Size,比如[3, 4]或torch.Size([3, 4]),则会对网络最后的两维进行归一化,且要求输入数据的最后两维尺寸也是[3, 4]。

假设此时输入的数据维度也是[3, 4],首先对这12个数字求均值和方差,然后归一化这个12个数字;weight和bias也分别包含12个数字,分别对12个归一化后的数字进行仿射变换(仿射变换即乘以weight中对应的数字后,然后加bias中对应的数字),并会在反向传播时得到学习。
假设此时输入的数据维度是[N, 3, 4],则对着N个[3,4]做和上述一样的操作,只是此时做仿射变换时,weight和bias被重复用了N次。
假设此时输入的数据维度是[N, T, 3, 4],也是一样的,维度可以更多。
注意:显然LayerNorm中weight和bias的shape就是传入的normalized_shape。

eps

归一化时加在分母上防止除零。

elementwise_affine

如果设为False,则LayerNorm层不含有任何可学习参数。

如果设为True(默认是True)则会包含可学习参数weight和bias,用于仿射变换,即对输入数据归一化到均值0方差1后,乘以weight,即bias。

torch.nn.LayerNorm(
        normalized_shape: Union[int, List[int], torch.Size],
        eps: float = 1e-05,
        elementwise_affine: bool = True)
import torch
a = torch.tensor([[1,2,4,1],[6,3,2,4],[2,4,6,1]]).float()
print(a)

输出

tensor([[1., 2., 4., 1.],
        [6., 3., 2., 4.],
        [2., 4., 6., 1.]])

1.只考虑最低维:每个维各自按公式计算即可,不和其他维度掺和

print(nn.LayerNorm([4])(a))
tensor([[-0.8165,  0.0000,  1.6330, -0.8165],
        [ 1.5213, -0.5071, -1.1832,  0.1690],
        [-0.6509,  0.3906,  1.4321, -1.1717]],
       grad_fn=<NativeLayerNormBackward>)

2.考虑最低的2个维度:计算最低两维的12个元素的方差均值

a = torch.tensor([[1,2,4,1],[6,3,2,4],[2,4,6,1]]).float()
print(a)
print(nn.LayerNorm([3,4])(a))
tensor([[1., 2., 4., 1.],
        [6., 3., 2., 4.],
        [2., 4., 6., 1.]])
tensor([[-1.1547, -0.5773,  0.5773, -1.1547],
        [ 1.7320,  0.0000, -0.5773,  0.5773],
        [-0.5773,  0.5773,  1.7320, -1.1547]],
       grad_fn=<NativeLayerNormBackward>)
### PyTorch `nn.LayerNorm` 层归一化 #### 使用方法和参数说明 `torch.nn.LayerNorm` 是一种用于对神经网络层的输出进行归一化的技术,在自然语言处理和其他序列建模任务中特别有用[^2]。该层可以加速训练过程并提升模型性能。 此函数接受多个参数来配置其行为: - **normalized_shape (int or list or torch.Size)**: 输入数据的最后一维或几维的大小,这些维度上的元素会被一起归一化。 - **eps (float, optional)**: 稳定计算的小常数,默认值为 $1e^{-5}$。为了数值稳定性加入到分母里防止除零错误。 - **elementwise_affine (bool, optional)**: 如果设置为 True,则 LayerNorm 将拥有可学习的仿射参数 $\gamma$ 和 $\beta$;如果 False 则不具有任何可学习参数[^1]。 下面是一个简单的例子展示如何创建一个 `LayerNorm` 实例并将它应用于张量: ```python import torch from torch import nn # 创建一个LayerNorm实例 layer_norm = nn.LayerNorm(normalized_shape=32) # 假设我们有一个形状为(batch_size, sequence_length, hidden_dim) 的输入张量 input_tensor = torch.randn(64, 10, 32) output_tensor = layer_norm(input_tensor) print(output_tensor.shape) # 输出应保持原尺寸不变 ``` 对于更复杂的场景,比如多头自注意力机制中的应用,通常会在最后一个轴上执行归一化操作,即针对每个位置单独做归一化而不是跨时间步长或其他批次成员之间共享统计信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

饿了就干饭

你的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值