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.HIGH
或Precision.HIGHEST
) 或两个这样的值的元组,分别表示a
和b
的精度。preferred_element_type (DTypeLike | None) –
None
(默认值),表示输入类型的默认累加类型,或数据类型,指示将结果累加到该数据类型并返回具有该数据类型的结果。
- 返回值:
包含输入矩阵乘积的数组。形状为
a.shape[:-1]
,如果b.ndim == 1
,否则形状为(..., M)
,其中a
和b
的前导维度一起广播。- 返回类型:
另请参见
jax.numpy.linalg.vecdot()
: 批处理向量积。jax.numpy.linalg.tensordot()
: 批处理张量积。jax.lax.dot_general()
: 通用 N 维批处理点积。
示例
向量点积
>>> 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)