jax.numpy.max#
- jax.numpy.max(a, axis=None, out=None, keepdims=False, initial=None, where=None)[源代码]#
返回给定轴上数组元素的最大值。
JAX 对
numpy.max()的实现。- 参数:
a (ArrayLike) – 输入数组。
axis (Axis) – int 或 array,默认为 None。计算最大值的轴。如果为 None,则沿所有轴计算最大值。
keepdims (bool) – bool,默认为 False。如果为 True,则保留大小为 1 的约简轴。
initial (ArrayLike | None) – int 或 array,默认为 None。最大值的初始值。
where (ArrayLike | None) – int 或布尔类型的 array,默认为 None。用于计算最大值的元素。Array 应与输入兼容广播。当使用
where时,必须指定initial。out (None) – JAX 未使用。
- 返回:
沿给定轴的最大值组成的 array。
- 返回类型:
另请参阅
jax.numpy.min(): 计算给定轴上数组元素的最小值。jax.numpy.sum(): 计算给定轴上数组元素的总和。jax.numpy.prod(): 计算给定轴上数组元素的乘积。
示例
默认情况下,
jnp.max计算沿所有轴的元素的最大值。>>> x = jnp.array([[9, 3, 4, 5], ... [5, 2, 7, 4], ... [8, 1, 3, 6]]) >>> jnp.max(x) Array(9, dtype=int32)
如果
axis=1,将沿轴 1 计算最大值。>>> jnp.max(x, axis=1) Array([9, 7, 8], dtype=int32)
如果
keepdims=True,输出的ndim将与输入的相同。>>> jnp.max(x, axis=1, keepdims=True) Array([[9], [7], [8]], dtype=int32)
要在计算最大值时只包含特定元素,可以使用
where。它可以与输入具有相同的维度>>> where=jnp.array([[0, 0, 1, 0], ... [0, 0, 1, 1], ... [1, 1, 1, 0]], dtype=bool) >>> jnp.max(x, axis=1, keepdims=True, initial=0, where=where) Array([[4], [7], [8]], dtype=int32)
或者必须与输入广播兼容。
>>> where = jnp.array([[False], ... [False], ... [False]]) >>> jnp.max(x, axis=0, keepdims=True, initial=0, where=where) Array([[0, 0, 0, 0]], dtype=int32)