``move_backward`` ================= Header: ```` Description ----------- Moves the elements from the range or from a rank-1 ``View`` in reverse order to the range beginning at ``d_last`` or to a target rank-1 ``View``. Interface --------- .. warning:: This is currently inside the ``Kokkos::Experimental`` namespace. Overload set accepting execution space ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. code-block:: cpp template IteratorType2 move_backward(const ExecutionSpace& ex, IteratorType1 first, (1) IteratorType1 last, IteratorType2 d_last); template auto move_backward(const ExecutionSpace& ex, (2) const ::Kokkos::View& source, ::Kokkos::View& dest); template IteratorType2 move_backward(const std::string& label, const ExecutionSpace& ex, (3) IteratorType1 first, IteratorType1 last, IteratorType2 d_last); template auto move_backward(const std::string& label, const ExecutionSpace& ex, (4) const ::Kokkos::View& source, ::Kokkos::View& dest); Overload set accepting a team handle ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. versionadded:: 4.2 .. code-block:: cpp template KOKKOS_FUNCTION IteratorType2 move_backward(const TeamHandleType& teamHandle, IteratorType1 first, (5) IteratorType1 last, IteratorType2 d_last); template KOKKOS_FUNCTION auto move_backward(const TeamHandleType& teamHandle, (6) const ::Kokkos::View& source, ::Kokkos::View& dest); Parameters and Requirements ~~~~~~~~~~~~~~~~~~~~~~~~~~~ - ``exespace``: execution space instance - ``teamHandle``: team handle instance given inside a parallel region when using a TeamPolicy - ``label``: string forwarded to internal parallel kernels for debugging purposes - for 1, the default string is: "Kokkos::move_backward_iterator_api_default" - for 3, the default string is: "Kokkos::move_backward_view_api_default" - NOTE: overloads accepting a team handle do not use a label internally - ``first``, ``last``, ``d_last``: range of elements to move from and to in a reverse order - must be *random access iterator* - must represent a valid range, i.e., ``last >= first`` - must be accessible from ``exespace`` or from the execution space associated with the team handle - ``source``, ``dest``: views to move from and to in a reverse order - must be rank-1, and have ``LayoutLeft``, ``LayoutRight``, or ``LayoutStride`` - must be accessible from ``exespace`` or from the execution space associated with the team handle Return Value ~~~~~~~~~~~~ - 1,3,5: an iterator equal to ``d_last - Kokkos::Experimental::distance(first, last)`` - 2,4,6: an iterator equal to ``Kokkos::Experimental::end(dest) - Kokkos::Experimental:distance(Kokkos::Experimental::begin(source), Kokkos::Experimental::end(source))``