jax.numpy.rollaxis

目录

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 的副本。

返回类型:

Array

备注

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)