欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > pytorch中torch.nn.functional.normalize、nn.norm和LayerNorm计算中的区别

pytorch中torch.nn.functional.normalize、nn.norm和LayerNorm计算中的区别

2025/2/25 14:16:09 来源:https://blog.csdn.net/taoqick/article/details/144662255  浏览:    关键词:pytorch中torch.nn.functional.normalize、nn.norm和LayerNorm计算中的区别

torch.nn.functional.normalize

计算方式

v = v max ⁡ ( ∥ v ∥ p , ϵ ) \mathbf{v} = \frac{\mathbf{v}}{\max\left(\|\mathbf{v}\|_p, \epsilon\right)} v=max(vp,ϵ)v

pytorch例子

a = torch.arange(12).reshape(3,4).float()
torch.nn.functional.normalize(a, dim=-1)
'''
tensor([[0.0000, 0.2673, 0.5345, 0.8018],[0.3563, 0.4454, 0.5345, 0.6236],[0.4182, 0.4704, 0.5227, 0.5750]])
'''

这样除一下就相等了

a = torch.arange(12).reshape(3,4).float()
torch.nn.functional.normalize(a, dim=-1)
'''
tensor([[0.0000, 0.2673, 0.5345, 0.8018],[0.3563, 0.4454, 0.5345, 0.6236],[0.4182, 0.4704, 0.5227, 0.5750]])
'''
a / a.norm(dim=-1,keepdim=True)
'''
tensor([[0.0000, 0.2673, 0.5345, 0.8018],[0.3563, 0.4454, 0.5345, 0.6236],[0.4182, 0.4704, 0.5227, 0.5750]])
'''

nn.norm

计算方式

可以通过p参数指定是pro(Frobenium norm,其实就是平方和开根号)还是nuc(叫nuclear norm,其实就是SVD分解的奇异值,也就是Singular Value)

pytorch例子

a = torch.arange(12).reshape(3,4).float()
a.norm(dim=-1, keepdim=True)
'''
tensor([[ 3.7417],[11.2250],[19.1311]])
'''

LayerNorm

计算方式

分子减均值,分母对方差开根号,更多细节参考 超细节的BatchNorm/BN/LayerNorm/LN/SyncLN/ShuffleBN/RMSNorm知识点

pytorch例子

a = torch.arange(12).reshape(3,4).float()
(a - a.mean(dim=-1, keepdims=True)) / torch.sqrt(a.var(dim=-1, keepdims=True, correction=0))
'''
tensor([[-1.3416, -0.4472,  0.4472,  1.3416],[-1.3416, -0.4472,  0.4472,  1.3416],[-1.3416, -0.4472,  0.4472,  1.3416]])
'''

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词