Compadre  1.5.9
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Attributes | List of all members
Compadre::ParallelManager Class Reference

Parallel Manager. More...

Detailed Description

Parallel Manager.

This class sets and manages thread / teams levels, scratch memory sizes, and kernel executions. ex: Compadre::ConvertLayoutLeftToRight clr; Compadre::ParallelManager pm; // no tag specified pm.CallFunctorWithTeamThreads(clr, 100, "MyFunctorName"); // some tag specified pm.CallFunctorWithTeamThreads<DefaultTag>(clr, 100);

Definition at line 29 of file Compadre_ParallelManager.hpp.

#include <Compadre_ParallelManager.hpp>

Public Member Functions

Instantiation / Destruction
 ParallelManager ()
 
Accessors

Retrieve member variables through public member functions

Kokkos::TeamPolicy
< device_execution_space
TeamPolicyThreadsAndVectors (const global_index_type batch_size, const int threads_per_team=-1, const int vector_lanes_per_thread=-1) const
 Creates a team policy for a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default. More...
 
template<typename Tag , class C >
void CallFunctorWithTeamThreadsAndVectors (C functor, const global_index_type batch_size, const int threads_per_team=-1, const int vector_lanes_per_thread=-1) const
 Calls a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default. More...
 
template<class C >
void CallFunctorWithTeamThreadsAndVectors (C functor, const global_index_type batch_size, const int threads_per_team=-1, const int vector_lanes_per_thread=-1, std::string functor_name=typeid(C).name()) const
 Calls a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default. More...
 
template<typename Tag , class C >
void CallFunctorWithTeamThreads (C functor, const global_index_type batch_size) const
 Calls a parallel_for parallel_for will break out over loops over teams with each thread executing code be default. More...
 
template<class C >
void CallFunctorWithTeamThreads (C functor, const global_index_type batch_size, std::string functor_name=typeid(C).name()) const
 Calls a parallel_for parallel_for will break out over loops over teams with each thread executing code be default. More...
 
KOKKOS_INLINE_FUNCTION int getTeamScratchLevel (const int level) const
 
KOKKOS_INLINE_FUNCTION int getThreadScratchLevel (const int level) const
 
KOKKOS_INLINE_FUNCTION int getTeamScratchSize (const int level) const
 
KOKKOS_INLINE_FUNCTION int getThreadScratchSize (const int level) const
 
Modifiers

Changed member variables through public member functions

void setTeamScratchLevel (const int level, const int value)
 
void setThreadScratchLevel (const int level, const int value)
 
void setTeamScratchSize (const int level, const int value)
 
void setThreadScratchSize (const int level, const int value)
 
void clearScratchSizes ()
 

Public Attributes

int _scratch_team_level_a
 lowest level memory for Kokkos::parallel_for for team access memory More...
 
int _team_scratch_size_a
 
int _scratch_thread_level_a
 higher (slower) level memory for Kokkos::parallel_for for team access memory More...
 
int _thread_scratch_size_a
 
int _scratch_team_level_b
 lowest level memory for Kokkos::parallel_for for thread access memory More...
 
int _team_scratch_size_b
 
int _scratch_thread_level_b
 higher (slower) level memory for Kokkos::parallel_for for thread access memory More...
 
int _thread_scratch_size_b
 
int _default_threads
 largest team size More...
 
int _default_vector_lanes
 

Constructor & Destructor Documentation

Compadre::ParallelManager::ParallelManager ( )
inline

Definition at line 78 of file Compadre_ParallelManager.hpp.

Member Function Documentation

template<typename Tag , class C >
void Compadre::ParallelManager::CallFunctorWithTeamThreads ( functor,
const global_index_type  batch_size 
) const
inline

Calls a parallel_for parallel_for will break out over loops over teams with each thread executing code be default.

Definition at line 558 of file Compadre_ParallelManager.hpp.

template<class C >
void Compadre::ParallelManager::CallFunctorWithTeamThreads ( functor,
const global_index_type  batch_size,
std::string  functor_name = typeid(C).name() 
) const
inline

Calls a parallel_for parallel_for will break out over loops over teams with each thread executing code be default.

Definition at line 566 of file Compadre_ParallelManager.hpp.

template<typename Tag , class C >
void Compadre::ParallelManager::CallFunctorWithTeamThreadsAndVectors ( functor,
const global_index_type  batch_size,
const int  threads_per_team = -1,
const int  vector_lanes_per_thread = -1 
) const
inline

Calls a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default.

Definition at line 238 of file Compadre_ParallelManager.hpp.

template<class C >
void Compadre::ParallelManager::CallFunctorWithTeamThreadsAndVectors ( functor,
const global_index_type  batch_size,
const int  threads_per_team = -1,
const int  vector_lanes_per_thread = -1,
std::string  functor_name = typeid(C).name() 
) const
inline

Calls a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default.

Definition at line 399 of file Compadre_ParallelManager.hpp.

void Compadre::ParallelManager::clearScratchSizes ( )
inline

Definition at line 647 of file Compadre_ParallelManager.hpp.

KOKKOS_INLINE_FUNCTION int Compadre::ParallelManager::getTeamScratchLevel ( const int  level) const
inline

Definition at line 572 of file Compadre_ParallelManager.hpp.

KOKKOS_INLINE_FUNCTION int Compadre::ParallelManager::getTeamScratchSize ( const int  level) const
inline

Definition at line 590 of file Compadre_ParallelManager.hpp.

KOKKOS_INLINE_FUNCTION int Compadre::ParallelManager::getThreadScratchLevel ( const int  level) const
inline

Definition at line 581 of file Compadre_ParallelManager.hpp.

KOKKOS_INLINE_FUNCTION int Compadre::ParallelManager::getThreadScratchSize ( const int  level) const
inline

Definition at line 599 of file Compadre_ParallelManager.hpp.

void Compadre::ParallelManager::setTeamScratchLevel ( const int  level,
const int  value 
)
inline

Definition at line 615 of file Compadre_ParallelManager.hpp.

void Compadre::ParallelManager::setTeamScratchSize ( const int  level,
const int  value 
)
inline

Definition at line 631 of file Compadre_ParallelManager.hpp.

void Compadre::ParallelManager::setThreadScratchLevel ( const int  level,
const int  value 
)
inline

Definition at line 623 of file Compadre_ParallelManager.hpp.

void Compadre::ParallelManager::setThreadScratchSize ( const int  level,
const int  value 
)
inline

Definition at line 639 of file Compadre_ParallelManager.hpp.

Kokkos::TeamPolicy<device_execution_space> Compadre::ParallelManager::TeamPolicyThreadsAndVectors ( const global_index_type  batch_size,
const int  threads_per_team = -1,
const int  vector_lanes_per_thread = -1 
) const
inline

Creates a team policy for a parallel_for parallel_for will break out over loops over teams with each vector lane executing code be default.

Definition at line 125 of file Compadre_ParallelManager.hpp.

Member Data Documentation

int Compadre::ParallelManager::_default_threads

largest team size

Definition at line 49 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_default_vector_lanes

Definition at line 50 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_scratch_team_level_a

lowest level memory for Kokkos::parallel_for for team access memory

Definition at line 33 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_scratch_team_level_b

lowest level memory for Kokkos::parallel_for for thread access memory

Definition at line 41 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_scratch_thread_level_a

higher (slower) level memory for Kokkos::parallel_for for team access memory

Definition at line 37 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_scratch_thread_level_b

higher (slower) level memory for Kokkos::parallel_for for thread access memory

Definition at line 45 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_team_scratch_size_a

Definition at line 34 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_team_scratch_size_b

Definition at line 42 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_thread_scratch_size_a

Definition at line 38 of file Compadre_ParallelManager.hpp.

int Compadre::ParallelManager::_thread_scratch_size_b

Definition at line 46 of file Compadre_ParallelManager.hpp.


The documentation for this class was generated from the following file: