比较与torch.norm/torch.Tensor.norm的功能差异

torch.norm

torch.norm(
    input,
    p='fro',
    dim=None,
    keepdim=False,
    out=None,
    dtype=None
)

更多内容详见torch.norm

torch.Tensor.norm

torch.Tensor.norm(
    p='fro',
    dim=None,
    keepdim=False,
    dtype=None
)

更多内容详见torch.Tensor.norm

mindspore.ops.LpNorm

class mindspore.ops.LpNorm(
    axis,
    p=2,
    keep_dims=False,
    epsilon=1e-12
)(input)

更多内容详见mindspore.ops.LpNorm

使用方式

PyTorch:p参数可以支持int,float,inf,-inf,’fro’,’nuc’等类型或值,以实现不同类型的归一化。

MindSpore:目前仅支持整数p范式的归一化。

代码示例

import mindspore as ms
import mindspore.ops as ops
import torch
import numpy as np

# In MindSpore, only Lp norm is supported.
net = ops.LpNorm(axis=0, p=2)
input_x = ms.Tensor(np.array([[4, 4, 9, 1], [2, 1, 3, 6]]), ms.float32)
output = net(input_x)
print(output)
# Out:
# [4.472136 4.1231055 9.486833 6.0827627]

# In torch, p=2
input_x = torch.tensor(np.array([[4, 4, 9, 1], [2, 1, 3, 6]]), dtype=torch.float)
output1 = torch.norm(input_x, dim=0, p=2)
print(output1)
# Out:
# tensor([4.4721, 4.1231, 9.4868, 6.0828])

# In torch, p='nuc'
input_x = torch.tensor(np.array([[4, 4, 9, 1], [2, 1, 3, 6]]), dtype=torch.float)
output2 = torch.norm(input_x, dim=(0, 1), p='nuc')
print(output2)
# Out:
# tensor(16.8892)