From 49a30c9d0dd9afcab20eb46bc0d226fa9a2de9de Mon Sep 17 00:00:00 2001 From: antoinemeyer5 Date: Wed, 28 Dec 2022 20:46:31 +0100 Subject: [PATCH] kokkos#120: API/core/policies/TeamHandleConcept transition from .md to .rst init --- .../API/core/policies/TeamHandleConcept.md | 202 ------------------ .../API/core/policies/TeamHandleConcept.rst | 192 +++++++++++++++++ 2 files changed, 192 insertions(+), 202 deletions(-) delete mode 100644 docs/source/API/core/policies/TeamHandleConcept.md create mode 100644 docs/source/API/core/policies/TeamHandleConcept.rst diff --git a/docs/source/API/core/policies/TeamHandleConcept.md b/docs/source/API/core/policies/TeamHandleConcept.md deleted file mode 100644 index 437467a94..000000000 --- a/docs/source/API/core/policies/TeamHandleConcept.md +++ /dev/null @@ -1,202 +0,0 @@ -# `TeamHandleConcept` - -Header File: `Kokkos_Core.hpp` - -TeamHandleConcept defines the concept for the `member_type` of `TeamPolicy` and `TeamTask`. -The actual type is defined through the policies, but meets the following API requirements. -Note that the specific classes are only part of the public API as provided by `TeamPolicy` and -`TeamTask` and only their parts as defined by the `TeamHandleConcept`. -The actual name of the class, as well as potential template parameters, existing -constructors, member functions going beyond the concept, etc., are NOT part of the public Kokkos API -and are thus subject to change. - -## Synopsis -```c++ -class TeamHandleConcept { - public: - // Nested aliases - using execution_space = /*see details in the description below*/; - using scratch_memory_space = /*see details in the description below*/; - - // Constructor, Destructor, Assignment - TeamHandleConcept( TeamHandleConcept && ) = default ; - TeamHandleConcept( TeamHandleConcept const & ) = default ; - ~TeamHandleConcept() = default ; - TeamHandleConcept & operator = ( TeamHandleConcept && ) = default ; - TeamHandleConcept & operator = ( TeamHandleConcept const & ) = default ; - - // Indices - KOKKOS_INLINE_FUNCTION - int team_rank() const noexcept; - KOKKOS_INLINE_FUNCTION - int team_size() const noexcept; - KOKKOS_INLINE_FUNCTION - int league_rank() const noexcept; - KOKKOS_INLINE_FUNCTION - int league_size() const noexcept; - - // Scratch Space - KOKKOS_INLINE_FUNCTION - const scratch_memory_space & team_shmem() const; - KOKKOS_INLINE_FUNCTION - const scratch_memory_space & team_scratch(int level) const; - KOKKOS_INLINE_FUNCTION - const scratch_memory_space & thread_scratch(int level) const; - - // Team collectives - KOKKOS_INLINE_FUNCTION - void team_barrier() const noexcept; - template - KOKKOS_INLINE_FUNCTION - void team_broadcast( T & value , const int source_team_rank ) const noexcept; - template - KOKKOS_INLINE_FUNCTION - void team_broadcast( Closure const & f , T & value , const int source_team_rank) const noexcept; - template< typename ReducerType > - KOKKOS_INLINE_FUNCTION - void team_reduce( ReducerType const & reducer ) const noexcept; - template< typename T > - KOKKOS_INLINE_FUNCTION - T team_scan( T const & value , T * const global = 0 ) const noexcept; -}; -``` - -## Public Class Members - -### Nested aliases - - * `execution_space`: specifies the [execution space](https://kokkos.github.io/kokkos-core-wiki/API/core/execution_spaces.html) associated to the team - - * `scratch_memory_space`: the scratch memory space associated to this team's execution space - -### Constructors - - * ```c++ - TeamHandleConcept() - TeamHandleConcept(TeamHandleConcept && ) - TeamHandleConcept(const TeamHandleConcept &) - ~TeamHandleConcept() - ``` - Default, move and copy constructors as well as destructor. - -### Assignment - * ```c++ - TeamHandleConcept & operator = ( TeamHandleConcept && ) - ``` - Move assignment. - * ```c++ - TeamHandleConcept & operator = ( const TeamHandleConcept & ) - ``` - Assignment operators. - Returns: `*this`. - -### Index Queries - * ```c++ - inline int team_size() const noexcept; - ``` - Returns: the number of threads associated with the team. - * ```c++ - inline int team_rank() const noexcept; - ``` - Returns: the index `i` of the calling thread within the team with `0 <= i < team_size()` - * ```c++ - inline int league_size() const noexcept; - ``` - Returns: the number of teams/workitems launched in the kernel. - * ```c++ - inline int league_rank() const noexcept; - ``` - Returns: the index `i` of the calling team within the league with `0 <= i < league_size()` - -### Scratch Space Control - * ```c++ - inline const scratch_memory_space & team_scratch(int level) const; - ``` - This function returns a scratch memory handle shared by all threads in a team, - which allows access to scratch memory. This handle can be given as the first - argument to a `Kokkos::View` to make it use scratch memory. - * `level`: The level of requested scratch memory is either `0` or `1`. - Returns: a scratch memory handle to the team shared scratch memory specified by level. - * ```c++ - inline const scratch_memory_space & thread_scratch(int level) const; - ``` - This function returns a scratch memory handle specific to the calling thread, - which allows access to its private scratch memory. - This handle can be given as the first argument to a `Kokkos::View` to make it use - scratch memory. - * `level`: The level of requested scratch memory is either `0` or `1`. - Returns: a scratch memory handle to the thread scratch memory specified by level. - * ```c++ - inline const scratch_memory_space & team_shmem() const; - ``` - Equivalent to calling `team_scratch(0)`. - -### Team Collective Operations - The following functions must be called collectively by all members of a team. These - calls must be lexically the same call, i.e. it is not legal to have some members of a team - call a collective in one branch and the others in another branch of the code (see example). - - * ```c++ - inline void team_barrier() const noexcept; - ``` - All members of the team wait at the barrier, until the whole team arrived. This also issues - a memory fence. - * ```c++ - template - inline void team_broadcast( T & var , const int source_team_rank ) const noexcept; - ``` - After this call `var` contains for every member of the team the value of `var` from the thread - for which `team_rank() == source_team_rank`. - * `var`: a variable of type `T` which gets overwritten by the value of `var` from the source rank. - * `source_team_rank`: identifies the broadcasting member of the team. - * ```c++ - template - inline void team_broadcast( Closure const & f, T & var , const int source_team_rank ) const noexcept; - ``` - After this call `var` contains for every member of the team the value of `var` from the thread - for which `team_rank() == source_team_rank` after applying `f`. - * `f`: a function object with an `void operator() ( T & )` which is applied to `var` before broadcasting it. - * `var`: a variable of type `T` which gets overwritten by the value of `f(var)` from the source rank. - * `source_team_rank`: identifies the broadcasting member of the team. - * ```c++ - template< class ReducerType > - inline void team_reduce( ReducerType const & reducer ) const noexcept; - ``` - Performs a reduction accross all members of the team as specified by `reducer`. - `ReducerType` must meet the concept of `Kokkos::Reducer`. - * ```c++ - template< class T > - inline T team_scan( const T & var , T * const global = NULL ) cosnt noexcept; - ``` - Performs an exclusive scan over the `var` provided by the team members. - Let `t = team_rank()` and `VALUES[t]` the value of `var` from thread `t`. - Returns: `VALUES[0] + VALUES[1] + `...`+ VALUES[t-1]` or zero for `t==0`. - * `global` if provided will be set to `VALUES[0] + VALUES[1] + `...`+ VALUES[team_size()-1]`, must be the same - pointer for every team member. - -## Examples - -```c++ -typedef TeamPolciy<...> policy_type; -parallel_for(policy_type(N,TEAM_SIZE).set_scratch_size(PerTeam(0,4096)), - KOKKOS_LAMBDA (const typename policy_type::member_type& team_handle) { - int ts = team_handle.team_size(); // returns TEAM_SIZE - int tid = team_handle.team_rank(); // returns a number between 0 and TEAM_SIZE - int ls = team_handle.league_size(); // returns N - int lid = team_handle.league_rank(); // returns a number between 0 and N - - int value = tid * 5; - team_handle.team_broadcast(value, 3); - // value==15 on every thread - value += tid; - team_handle.team_broadcast([&] (int & var) { var*=2 }, value, 2); - // value==34 on every thread - int global; - int scan = team_handle.team_scan(tid+1, &global); - // scan == tid*(tid+1)/2 on every thread - // global == ts*(ts-1)/2 on every thread - Kokkos::View - a(team_handle.team_scratch(0), 1024); - -}); -``` diff --git a/docs/source/API/core/policies/TeamHandleConcept.rst b/docs/source/API/core/policies/TeamHandleConcept.rst new file mode 100644 index 000000000..1bc389f5e --- /dev/null +++ b/docs/source/API/core/policies/TeamHandleConcept.rst @@ -0,0 +1,192 @@ +``TeamHandleConcept`` +===================== + +.. role::cpp(code) + :language: cpp + +.. role:: cppkokkos(code) + :language: cppkokkos + +Header File: ```` + +TeamHandleConcept defines the concept for the ``member_type`` of ``TeamPolicy`` and ``TeamTask``. +The actual type is defined through the policies, but meets the following API requirements. +Note that the specific classes are only part of the public API as provided by ``TeamPolicy`` and +``TeamTask`` and only their parts as defined by the ``TeamHandleConcept``. +The actual name of the class, as well as potential template parameters, existing +constructors, member functions going beyond the concept, etc., are NOT part of the public Kokkos API +and are thus subject to change. + +Synopsis +-------- + +.. cpp:class:: TeamHandleConcept + + .. code-block:: cpp + + public: + // Nested aliases + using execution_space = /*see details in the description below*/; + + * ``execution_space``: specifies the `execution space `_ associated to the team + + .. code-block:: cpp + + using scratch_memory_space = /*see details in the description below*/; + + * ``scratch_memory_space``: the scratch memory space associated to this team's execution space + + .. code-block:: cpp + + // Constructor, Destructor, Assignment + + .. cpp:function:: TeamHandleConcept( TeamHandleConcept && ) = default ; + + .. cpp:function:: TeamHandleConcept( TeamHandleConcept const & ) = default ; + + .. cpp:function:: ~TeamHandleConcept() = default ; + + * Default, move and copy constructors as well as destructor. + + .. cpp:function:: TeamHandleConcept & operator = ( TeamHandleConcept && ) = default ; + + * Move assignment. + + .. cpp:function:: TeamHandleConcept & operator = ( TeamHandleConcept const & ) = default ; + + * Assignment operators. Returns: ``*this``. + + .. code-block:: cpp + + // Indices + KOKKOS_INLINE_FUNCTION + int team_rank() const noexcept; + + * Returns: the index ``i`` of the calling thread within the team with ``0 <= i < team_size()`` + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + int team_size() const noexcept; + + * Returns: the number of threads associated with the team. + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + int league_rank() const noexcept; + + * Returns: the index ``i`` of the calling team within the league with ``0 <= i < league_size()`` + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + int league_size() const noexcept; + + * Returns: the number of teams/workitems launched in the kernel. + + .. code-block:: cpp + + // Scratch Space + KOKKOS_INLINE_FUNCTION + const scratch_memory_space & team_shmem() const; + + * Equivalent to calling ``team_scratch(0)``. + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + const scratch_memory_space & team_scratch(int level) const; + + * This function returns a scratch memory handle shared by all threads in a team, which allows access to scratch memory. This handle can be given as the first argument to a ``Kokkos::View`` to make it use scratch memory. + - ``level``: The level of requested scratch memory is either ``0`` or ``1``. + - Returns: a scratch memory handle to the team shared scratch memory specified by level. + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + const scratch_memory_space & thread_scratch(int level) const; + + * This function returns a scratch memory handle specific to the calling thread, which allows access to its private scratch memory. This handle can be given as the first argument to a ``Kokkos::View`` to make it use scratch memory. + - ``level``: The level of requested scratch memory is either ``0`` or ``1``. + - Returns: a scratch memory handle to the thread scratch memory specified by level. + + .. code-block:: cpp + + // Team collectives + + The following functions must be called collectively by all members of a team. These calls must be lexically the same call, i.e. it is not legal to have some members of a team call a collective in one branch and the others in another branch of the code (see example). + + .. code-block:: cpp + + KOKKOS_INLINE_FUNCTION + void team_barrier() const noexcept; + + * All members of the team wait at the barrier, until the whole team arrived. This also issues a memory fence. + + .. code-block:: cpp + + template + KOKKOS_INLINE_FUNCTION + void team_broadcast( T & value , const int source_team_rank ) const noexcept; + + * After this call ``var`` contains for every member of the team the value of ``var`` from the thread for which ``team_rank() == source_team_rank``. + - ``var``: a variable of type ``T`` which gets overwritten by the value of ``var`` from the source rank. + - ``source_team_rank``: identifies the broadcasting member of the team. + + .. code-block:: cpp + + template + KOKKOS_INLINE_FUNCTION + void team_broadcast( Closure const & f , T & value , const int source_team_rank) const noexcept; + + * After this call ``var`` contains for every member of the team the value of ``var`` from the thread for which ``team_rank() == source_team_rank`` after applying ``f``. + - ``f``: a function object with an ``void operator() ( T & )`` which is applied to ``var`` before broadcasting it. + - ``var``: a variable of type ``T`` which gets overwritten by the value of ``f(var)`` from the source rank. + - ``source_team_rank``: identifies the broadcasting member of the team. + + .. code-block:: cpp + + template< typename ReducerType > + KOKKOS_INLINE_FUNCTION + void team_reduce( ReducerType const & reducer ) const noexcept; + + * Performs a reduction accross all members of the team as specified by ``reducer``. ``ReducerType`` must meet the concept of ``Kokkos::Reducer``. + + .. code-block:: cpp + + template< typename T > + KOKKOS_INLINE_FUNCTION + T team_scan( T const & value , T * const global = 0 ) const noexcept; + + * Performs an exclusive scan over the ``var`` provided by the team members. Let ``t = team_rank()`` and ``VALUES[t]`` the value of ``var`` from thread ``t``. + - Returns: ``VALUES[0] + VALUES[1] + ``...``+ VALUES[t-1]`` or zero for ``t==0``. + - ``global`` if provided will be set to ``VALUES[0] + VALUES[1] + ``...``+ VALUES[team_size()-1]``, must be the same pointer for every team member. + +Examples +-------- + +.. code-block:: cpp + + typedef TeamPolciy<...> policy_type; + parallel_for(policy_type(N,TEAM_SIZE).set_scratch_size(PerTeam(0,4096)), + KOKKOS_LAMBDA (const typename policy_type::member_type& team_handle) { + int ts = team_handle.team_size(); // returns TEAM_SIZE + int tid = team_handle.team_rank(); // returns a number between 0 and TEAM_SIZE + int ls = team_handle.league_size(); // returns N + int lid = team_handle.league_rank(); // returns a number between 0 and N + + int value = tid * 5; + team_handle.team_broadcast(value, 3); + // value==15 on every thread + value += tid; + team_handle.team_broadcast([&] (int & var) { var*=2 }, value, 2); + // value==34 on every thread + int global; + int scan = team_handle.team_scan(tid+1, &global); + // scan == tid*(tid+1)/2 on every thread + // global == ts*(ts-1)/2 on every thread + Kokkos::View + a(team_handle.team_scratch(0), 1024); + + });