jax.numpy.matmul

内容

jax.numpy.matmul#

jax.numpy.matmul(a, b, *, precision=None, preferred_element_type=None)[source]#

执行矩阵乘法。

JAX 实现 numpy.matmul()

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

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

  • precision (PrecisionLike) – None (默认值),表示后端的默认精度,Precision 枚举值 (Precision.DEFAULT, Precision.HIGHPrecision.HIGHEST) 或两个这样的值的元组,分别表示 ab 的精度。

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

返回值:

包含输入矩阵乘积的数组。形状为 a.shape[:-1],如果 b.ndim == 1,否则形状为 (..., M),其中 ab 的前导维度一起广播。

返回类型:

数组

另请参见

示例

向量点积

>>> a = jnp.array([1, 2, 3])
>>> b = jnp.array([4, 5, 6])
>>> jnp.matmul(a, b)
Array(32, dtype=int32)

矩阵点积

>>> a = jnp.array([[1, 2, 3],
...                [4, 5, 6]])
>>> b = jnp.array([[1, 2],
...                [3, 4],
...                [5, 6]])
>>> jnp.matmul(a, b)
Array([[22, 28],
       [49, 64]], dtype=int32)

为了方便起见,在所有情况下,您都可以使用 @ 运算符执行相同的计算。

>>> a @ b
Array([[22, 28],
       [49, 64]], dtype=int32)