评价此页

torch.mm#

torch.mm(input, mat2, out_dtype=None, *, out=None) Tensor#

执行矩阵 inputmat2 的矩阵乘法。

如果 input 是一个 (n×m)(n \times m) 张量,mat2 是一个 (m×p)(m \times p) 张量,out 将是一个 (n×p)(n \times p) 张量。

注意

此函数不支持 广播。有关广播矩阵乘积,请参见 torch.matmul()

支持具有 stridedsparse 布局的 2 维张量作为输入,并支持与 strided 输入进行自动求导。

此操作支持具有 sparse 布局 的参数。如果提供了 out,则将使用其布局。否则,结果布局将根据 input 的布局来推断。

警告

稀疏支持是测试版功能,某些布局/数据类型/设备组合可能不支持,或可能不支持自动求导。如果您发现缺少功能,请提交功能请求。

此操作符支持TensorFloat32

在某些 ROCm 设备上,当使用 float16 输入时,此模块将对反向传播使用不同精度

参数
  • input (Tensor) – 第一个要进行矩阵相乘的矩阵

  • mat2 (Tensor) – 第二个要进行矩阵相乘的矩阵

  • out_dtype (dtype, optional) – 输出张量的数据类型。仅在 CUDA 上支持,并且当输入数据类型为 torch.float16/torch.bfloat16 时,支持 torch.float32。

关键字参数

out (Tensor, optional) – 输出张量。

示例

>>> mat1 = torch.randn(2, 3)
>>> mat2 = torch.randn(3, 3)
>>> torch.mm(mat1, mat2)
tensor([[ 0.4851,  0.5037, -0.3633],
        [-0.0760, -3.6705,  2.4784]])