jax.numpy.linalg.matmul#
- jax.numpy.linalg.matmul(x1, x2, /, *, precision=None, preferred_element_type=None)[源代码]#
执行矩阵乘法。
JAX 对
numpy.linalg.matmul()的实现。- 参数:
x1 (ArrayLike) – 第一个输入数组,形状为
(..., N)。x2 (ArrayLike) – 第二个输入数组。形状必须是
(N,)或(..., N, M)。在多维情况下,前导维度必须与x1的前导维度兼容广播。precision (lax.PrecisionLike) – 可以是
None(默认值),表示后端默认精度;一个Precision枚举值(Precision.DEFAULT、Precision.HIGH或Precision.HIGHEST);或者一个包含两个此类值的元组,分别指示x1和x2的精度。preferred_element_type (DTypeLike | None) – 可以是
None(默认值),表示输入类型的默认累加类型;或者一个数据类型,指示累加结果并以该数据类型返回结果。
- 返回:
包含输入矩阵乘积的数组。如果
x2.ndim == 1,则形状为x1.shape[:-1],否则形状为(..., M)。- 返回类型:
另请参阅
jax.numpy.matmul():此函数的 NumPy API。jax.numpy.linalg.vecdot():批处理向量乘积。jax.numpy.linalg.tensordot():批处理张量积。示例
向量点积
>>> x1 = jnp.array([1, 2, 3]) >>> x2 = jnp.array([4, 5, 6]) >>> jnp.linalg.matmul(x1, x2) Array(32, dtype=int32)
矩阵点积
>>> x1 = jnp.array([[1, 2, 3], ... [4, 5, 6]]) >>> x2 = jnp.array([[1, 2], ... [3, 4], ... [5, 6]]) >>> jnp.linalg.matmul(x1, x2) Array([[22, 28], [49, 64]], dtype=int32)
为了方便起见,在所有情况下,您都可以使用
@运算符执行相同的计算。>>> x1 @ x2 Array([[22, 28], [49, 64]], dtype=int32)