torch.baddbmm¶
- torch.baddbmm(input, batch1, batch2, *, beta=1, alpha=1, out=None) Tensor ¶
执行
batch1
和batch2
中矩阵的批量矩阵乘法。结果中添加input
。batch1
和batch2
必须是 3-D 张量,且每个张量包含相同数量的矩阵。如果
batch1
是一个 张量,batch2
是一个 张量,则input
必须能够 广播 到一个 张量,并且out
将是一个 张量。alpha
和beta
的含义与torch.addbmm()
中使用的缩放因子相同。如果
beta
为 0,则忽略input
的内容,其中的nan
和inf
将不会传播。对于
FloatTensor
或DoubleTensor
类型的输入,参数beta
和alpha
必须是实数,否则应为整数。此算子支持 TensorFloat32。
在某些 ROCm 设备上,使用 float16 输入时,此模块在反向传播时会使用 不同的精度。
- 参数
- 关键字参数
beta (Number, optional) –
input
的乘数 ()alpha (Number, optional) – 的乘数 ()
out (Tensor, optional) – 输出张量。
示例
>>> M = torch.randn(10, 3, 5) >>> batch1 = torch.randn(10, 3, 4) >>> batch2 = torch.randn(10, 4, 5) >>> torch.baddbmm(M, batch1, batch2).size() torch.Size([10, 3, 5])