jax.numpy.rollaxis#

jax.numpy.rollaxis(a, axis, start=0)[源代码]#

将指定的轴滚动到给定位置。

JAX 实现的 numpy.rollaxis()

此函数是为了与 NumPy 兼容而存在的,但在大多数情况下,使用较新的 jax.numpy.moveaxis() 代替,因为它参数的含义更直观。

参数:
  • a (ArrayLike) – 输入数组。

  • axis (int) – 要向前滚动的轴的索引。

  • start (int) – 轴滚动到的索引位置(默认值 = 0)。在标准化负轴之后,如果 start <= axis,则轴将滚动到 start 索引;如果 start > axis,则轴将滚动到 start 索引之前的位置。

返回:

带有滚动轴的 a 的副本。

返回类型:

数组

说明

numpy.rollaxis() 不同,jax.numpy.rollaxis() 将返回输入数组的副本,而不是视图。 但是,在 JIT 下,编译器会在可能的情况下优化掉此类副本,因此在实践中不会影响性能。

另请参阅

示例

>>> a = jnp.ones((2, 3, 4, 5))

将轴 2 滚动到数组的开头

>>> jnp.rollaxis(a, 2).shape
(4, 2, 3, 5)

将轴 1 滚动到数组的末尾

>>> jnp.rollaxis(a, 1, a.ndim).shape
(2, 4, 5, 3)

使用 moveaxis() 实现的等效操作

>>> jnp.moveaxis(a, 2, 0).shape
(4, 2, 3, 5)
>>> jnp.moveaxis(a, 1, -1).shape
(2, 4, 5, 3)