jax.numpy.linalg.tensordot

内容

jax.numpy.linalg.tensordot#

jax.numpy.linalg.tensordot(x1, x2, /, *, axes=2, precision=None, preferred_element_type=None)[source]#

计算两个 N 维数组的张量点积。

numpy.linalg.tensordot() 的 JAX 实现。

参数:
  • x1 (ArrayLike) – N 维数组

  • x2 (ArrayLike) – M 维数组

  • axes (int | tuple[Sequence[int], Sequence[int]]) – 整数或整数序列的元组。如果为整数 k,则按顺序对 x1 的最后 k 个轴和 x2 的前 k 个轴求和。如果为元组,则 axes[0] 指定 x1 的轴,而 axes[1] 指定 x2 的轴。

  • precision (PrecisionLike | None) – 可以是 None(默认值),表示使用后端的默认精度,也可以是 Precision 枚举值(Precision.DEFAULTPrecision.HIGHPrecision.HIGHEST),或者是一个包含两个枚举值的元组,分别表示 x1x2 的精度。

  • preferred_element_type (DTypeLike | None | None) – 可以是 None(默认值),表示使用输入类型的默认累加类型,也可以是数据类型,表示将结果累加到该数据类型并返回具有该数据类型的结果。

返回:

包含输入张量点积的数组

返回类型:

数组

另请参阅

示例

>>> x1 = jnp.arange(24.).reshape(2, 3, 4)
>>> x2 = jnp.ones((3, 4, 5))
>>> jnp.linalg.tensordot(x1, x2)
Array([[ 66.,  66.,  66.,  66.,  66.],
       [210., 210., 210., 210., 210.]], dtype=float32)

将轴指定为显式序列时获得等效结果

>>> jnp.linalg.tensordot(x1, x2, axes=([1, 2], [0, 1]))
Array([[ 66.,  66.,  66.,  66.,  66.],
       [210., 210., 210., 210., 210.]], dtype=float32)

通过 einsum() 获得等效结果

>>> jnp.einsum('ijk,jkm->im', x1, x2)
Array([[ 66.,  66.,  66.,  66.,  66.],
       [210., 210., 210., 210., 210.]], dtype=float32)

对于二维输入,设置 axes=1 等效于矩阵乘法

>>> x1 = jnp.array([[1, 2],
...                 [3, 4]])
>>> x2 = jnp.array([[1, 2, 3],
...                 [4, 5, 6]])
>>> jnp.linalg.tensordot(x1, x2, axes=1)
Array([[ 9, 12, 15],
       [19, 26, 33]], dtype=int32)
>>> x1 @ x2
Array([[ 9, 12, 15],
       [19, 26, 33]], dtype=int32)

对于一维输入,设置 axes=0 等效于 jax.numpy.linalg.outer()

>>> x1 = jnp.array([1, 2])
>>> x2 = jnp.array([1, 2, 3])
>>> jnp.linalg.tensordot(x1, x2, axes=0)
Array([[1, 2, 3],
       [2, 4, 6]], dtype=int32)
>>> jnp.linalg.outer(x1, x2)
Array([[1, 2, 3],
       [2, 4, 6]], dtype=int32)