tf.roll
Stay organized with collections
Save and categorize content based on your preferences.
Rolls the elements of a tensor along an axis.
tf.roll(
input, shift, axis, name=None
)
Used in the notebooks
The elements are shifted positively (towards larger indices) by the offset of
shift
along the dimension of axis
. Negative shift
values will shift
elements in the opposite direction. Elements that roll passed the last position
will wrap around to the first and vice versa. Multiple shifts along multiple
axes may be specified.
For example:
# 't' is [0, 1, 2, 3, 4]
roll(t, shift=2, axis=0) ==> [3, 4, 0, 1, 2]
# shifting along multiple dimensions
# 't' is [[0, 1, 2, 3, 4], [5, 6, 7, 8, 9]]
roll(t, shift=[1, -2], axis=[0, 1]) ==> [[7, 8, 9, 5, 6], [2, 3, 4, 0, 1]]
# shifting along the same axis multiple times
# 't' is [[0, 1, 2, 3, 4], [5, 6, 7, 8, 9]]
roll(t, shift=[2, -3], axis=[1, 1]) ==> [[1, 2, 3, 4, 0], [6, 7, 8, 9, 5]]
Args |
input
|
A Tensor .
|
shift
|
A Tensor . Must be one of the following types: int32 , int64 .
Dimension must be 0-D or 1-D. shift[i] specifies the number of places by which
elements are shifted positively (towards larger indices) along the dimension
specified by axis[i] . Negative shifts will roll the elements in the opposite
direction.
|
axis
|
A Tensor . Must be one of the following types: int32 , int64 .
Dimension must be 0-D or 1-D. axis[i] specifies the dimension that the shift
shift[i] should occur. If the same axis is referenced more than once, the
total shift for that axis will be the sum of all the shifts that belong to that
axis.
|
name
|
A name for the operation (optional).
|
Returns |
A Tensor . Has the same type as input .
|
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates. Some content is licensed under the numpy license.
Last updated 2024-04-26 UTC.
[null,null,["Last updated 2024-04-26 UTC."],[],[],null,["# tf.roll\n\n\u003cbr /\u003e\n\n|---------------------------------------------------------------------------------------------------------------------------|\n| [View source on GitHub](https://github.com/tensorflow/tensorflow/blob/v2.16.1/tensorflow/python/ops/manip_ops.py#L27-L31) |\n\nRolls the elements of a tensor along an axis.\n\n#### View aliases\n\n\n**Compat aliases for migration**\n\nSee\n[Migration guide](https://www.tensorflow.org/guide/migrate) for\nmore details.\n\n[`tf.compat.v1.manip.roll`](https://www.tensorflow.org/api_docs/python/tf/roll), [`tf.compat.v1.roll`](https://www.tensorflow.org/api_docs/python/tf/roll)\n\n\u003cbr /\u003e\n\n tf.roll(\n input, shift, axis, name=None\n )\n\n### Used in the notebooks\n\n| Used in the tutorials |\n|--------------------------------------------------------------------------|\n| - [DeepDream](https://www.tensorflow.org/tutorials/generative/deepdream) |\n\nThe elements are shifted positively (towards larger indices) by the offset of\n`shift` along the dimension of `axis`. Negative `shift` values will shift\nelements in the opposite direction. Elements that roll passed the last position\nwill wrap around to the first and vice versa. Multiple shifts along multiple\naxes may be specified.\n\n#### For example:\n\n # 't' is [0, 1, 2, 3, 4]\n roll(t, shift=2, axis=0) ==\u003e [3, 4, 0, 1, 2]\n\n # shifting along multiple dimensions\n # 't' is [[0, 1, 2, 3, 4], [5, 6, 7, 8, 9]]\n roll(t, shift=[1, -2], axis=[0, 1]) ==\u003e [[7, 8, 9, 5, 6], [2, 3, 4, 0, 1]]\n\n # shifting along the same axis multiple times\n # 't' is [[0, 1, 2, 3, 4], [5, 6, 7, 8, 9]]\n roll(t, shift=[2, -3], axis=[1, 1]) ==\u003e [[1, 2, 3, 4, 0], [6, 7, 8, 9, 5]]\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n| Args ---- ||\n|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| `input` | A `Tensor`. |\n| `shift` | A `Tensor`. Must be one of the following types: `int32`, `int64`. Dimension must be 0-D or 1-D. `shift[i]` specifies the number of places by which elements are shifted positively (towards larger indices) along the dimension specified by `axis[i]`. Negative shifts will roll the elements in the opposite direction. |\n| `axis` | A `Tensor`. Must be one of the following types: `int32`, `int64`. Dimension must be 0-D or 1-D. `axis[i]` specifies the dimension that the shift `shift[i]` should occur. If the same axis is referenced more than once, the total shift for that axis will be the sum of all the shifts that belong to that axis. |\n| `name` | A name for the operation (optional). |\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n| Returns ------- ||\n|---|---|\n| A `Tensor`. Has the same type as `input`. ||\n\n\u003cbr /\u003e"]]