jax.numpy.dot#

jax.numpy.dot(a, b, *, precision=None, preferred_element_type=None)[源代码]#

计算两个数组的点积。

numpy.dot() 的 JAX 实现。

这与 jax.numpy.matmul() 有两个方面的不同之处

  • 如果 ab 中任一一个是标量,则 dot 的结果等效于 jax.numpy.multiply(),而 matmul 的结果会报错。

  • 如果 ab 的维度都超过 2,则批次索引会被堆叠而不是广播。

参数:
  • a (ArrayLike) – 第一个输入数组,形状为 (..., N)

  • b (ArrayLike) – 第二个输入数组。必须具有形状 (N,)(..., N, M)。在多维情况下,前导维度必须与 a 的前导维度广播兼容。

  • precision (PrecisionLike) – 可以是 None (默认),表示后端的默认精度;一个 Precision 枚举值 (Precision.DEFAULT, Precision.HIGHPrecision.HIGHEST);或者是由两个这样的值组成的元组,表示 ab 的精度。

  • preferred_element_type (DTypeLike | None) – 可以是 None (默认),表示输入类型的默认累积类型,或者是一个数据类型,表示将结果累积到该数据类型并返回具有该数据类型的结果。

返回:

包含输入点积的数组,批次维度是 ab 的堆叠维度,而不是广播的维度。

返回类型:

Array

另请参阅

示例

对于标量输入,dot 计算元素级乘积

>>> x = jnp.array([1, 2, 3])
>>> jnp.dot(x, 2)
Array([2, 4, 6], dtype=int32)

对于向量或矩阵输入,dot 计算向量或矩阵乘积

>>> M = jnp.array([[2, 3, 4],
...                [5, 6, 7],
...                [8, 9, 0]])
>>> jnp.dot(M, x)
Array([20, 38, 26], dtype=int32)
>>> jnp.dot(M, M)
Array([[ 51,  60,  29],
       [ 96, 114,  62],
       [ 61,  78,  95]], dtype=int32)

对于更高维度的矩阵乘积,批次维度会被堆叠,而在 matmul() 中,它们会被广播。例如

>>> a = jnp.zeros((3, 2, 4))
>>> b = jnp.zeros((3, 4, 1))
>>> jnp.dot(a, b).shape
(3, 2, 3, 1)
>>> jnp.matmul(a, b).shape
(3, 2, 1)