网络编程
位置:首页>> 网络编程>> Python编程>> 基于python及pytorch中乘法的使用详解

基于python及pytorch中乘法的使用详解

作者:_ReLU_  发布时间:2022-08-07 09:26:59 

标签:python,pytorch,乘法

numpy中的乘法


A = np.array([[1, 2, 3], [2, 3, 4]])
B = np.array([[1, 0, 1], [2, 1, -1]])
C = np.array([[1, 0], [0, 1], [-1, 0]])

A * B : # 对应位置相乘
np.array([[ 1, 0, 3], [ 4, 3, -4]])

A.dot(B) :  # 矩阵乘法
ValueError: shapes (2,3) and (2,3) not aligned: 3 (dim 1) != 2 (dim 0)

A.dot(C) : # 矩阵乘法  | < -- > np.dot(A, C)
np.array([[-2, 2],[-2, 3]])

总结 : 在numpy中,*表示为两个数组对应位置相乘; dot表示两个数组进行矩阵乘法

pytorch中的乘法


A = torch.tensor([[1, 2, 3], [2, 3, 4]])
B = torch.tensor([[1, 0, 1], [2, 1, -1]])
C = torch.tensor([[1, 0], [0, 1], [-1, 0]])

# 矩阵乘法
torch.mm(mat1, mat2, out=None) <--> torch.matmul(mat1, mat2, out=None)
eg :
 torch.mm(A, B)   : RuntimeError: size mismatch, m1: [2 x 3], m2: [2 x 3]
 torch.mm(A, C)   : tensor([[-2, 2], [-2, 3]])
 torch.matmul(A, C) : tensor([[-2, 2], [-2, 3]])

# 点乘
torch.mul(mat1, mat2, out=None)

eg :
 torch.mul(A, B) : tensor([[ 1, 0, 3], [ 4, 3, -4]])
 torch.mul(A, C) : RuntimeError: The size of tensor a (3) must match the size of tensor b (2) at non-singleton dimension 1

总结 : 在pytorch中,mul表示为两个数组对应位置相乘; mm和matmul表示两个数组进行矩阵乘法

来源:https://blog.csdn.net/on_theway10/article/details/88856494

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com