Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
|
#include <ThreadPool.hh>
Classes | |
struct | Config |
Public Types | |
template<typename KeyT, typename MappedT, typename HashT = KeyT> | |
using | uomap = std::unordered_map<KeyT, MappedT, std::hash<HashT>> |
using | size_type = size_t |
using | task_count_type = std::shared_ptr<std::atomic_uintmax_t> |
using | atomic_int_type = std::shared_ptr<std::atomic_uintmax_t> |
using | pool_state_type = std::shared_ptr<std::atomic_short> |
using | atomic_bool_type = std::shared_ptr<std::atomic_bool> |
using | task_type = VTask |
using | lock_t = std::shared_ptr<Mutex> |
using | condition_t = std::shared_ptr<Condition> |
using | task_pointer = std::shared_ptr<task_type> |
using | task_queue_t = VUserTaskQueue |
using | thread_list_t = std::deque<ThreadId> |
using | bool_list_t = std::vector<bool> |
using | thread_id_map_t = std::map<ThreadId, uintmax_t> |
using | thread_index_map_t = std::map<uintmax_t, ThreadId> |
using | thread_vec_t = std::vector<Thread> |
using | thread_data_t = std::vector<std::shared_ptr<ThreadData>> |
using | initialize_func_t = std::function<void()> |
using | finalize_func_t = std::function<void()> |
using | affinity_func_t = std::function<intmax_t(intmax_t)> |
Static Public Member Functions | |
static affinity_func_t & | affinity_functor () |
static initialize_func_t & | initialization_functor () |
static finalize_func_t & | finalization_functor () |
static void | set_default_size (size_type _v) |
set the default pool size | |
static size_type | get_default_size () |
get the default pool size | |
static tbb_global_control_t *& | tbb_global_control () |
static const thread_id_map_t & | get_thread_ids () |
static uintmax_t | get_thread_id (ThreadId) |
static uintmax_t | get_this_thread_id () |
static uintmax_t | add_thread_id (ThreadId=ThisThread::get_id()) |
Definition at line 87 of file ThreadPool.hh.
using PTL::ThreadPool::affinity_func_t = std::function<intmax_t(intmax_t)> |
Definition at line 115 of file ThreadPool.hh.
using PTL::ThreadPool::atomic_bool_type = std::shared_ptr<std::atomic_bool> |
Definition at line 98 of file ThreadPool.hh.
using PTL::ThreadPool::atomic_int_type = std::shared_ptr<std::atomic_uintmax_t> |
Definition at line 96 of file ThreadPool.hh.
using PTL::ThreadPool::bool_list_t = std::vector<bool> |
Definition at line 107 of file ThreadPool.hh.
using PTL::ThreadPool::condition_t = std::shared_ptr<Condition> |
Definition at line 102 of file ThreadPool.hh.
using PTL::ThreadPool::finalize_func_t = std::function<void()> |
Definition at line 114 of file ThreadPool.hh.
using PTL::ThreadPool::initialize_func_t = std::function<void()> |
Definition at line 113 of file ThreadPool.hh.
using PTL::ThreadPool::lock_t = std::shared_ptr<Mutex> |
Definition at line 101 of file ThreadPool.hh.
using PTL::ThreadPool::pool_state_type = std::shared_ptr<std::atomic_short> |
Definition at line 97 of file ThreadPool.hh.
using PTL::ThreadPool::size_type = size_t |
Definition at line 94 of file ThreadPool.hh.
using PTL::ThreadPool::task_count_type = std::shared_ptr<std::atomic_uintmax_t> |
Definition at line 95 of file ThreadPool.hh.
using PTL::ThreadPool::task_pointer = std::shared_ptr<task_type> |
Definition at line 103 of file ThreadPool.hh.
Definition at line 104 of file ThreadPool.hh.
using PTL::ThreadPool::task_type = VTask |
Definition at line 100 of file ThreadPool.hh.
using PTL::ThreadPool::thread_data_t = std::vector<std::shared_ptr<ThreadData>> |
Definition at line 111 of file ThreadPool.hh.
using PTL::ThreadPool::thread_id_map_t = std::map<ThreadId, uintmax_t> |
Definition at line 108 of file ThreadPool.hh.
using PTL::ThreadPool::thread_index_map_t = std::map<uintmax_t, ThreadId> |
Definition at line 109 of file ThreadPool.hh.
using PTL::ThreadPool::thread_list_t = std::deque<ThreadId> |
Definition at line 106 of file ThreadPool.hh.
using PTL::ThreadPool::thread_vec_t = std::vector<Thread> |
Definition at line 110 of file ThreadPool.hh.
using PTL::ThreadPool::uomap = std::unordered_map<KeyT, MappedT, std::hash<HashT>> |
Definition at line 91 of file ThreadPool.hh.
|
explicit |
Definition at line 172 of file ThreadPool.cc.
Referenced by operator=(), operator=(), ThreadPool(), and ThreadPool().
PTL::ThreadPool::~ThreadPool | ( | ) |
Definition at line 199 of file ThreadPool.cc.
|
delete |
|
default |
|
inline |
Definition at line 411 of file ThreadPool.hh.
|
inline |
Definition at line 422 of file ThreadPool.hh.
|
static |
Definition at line 156 of file ThreadPool.cc.
Referenced by execute_on_all_threads(), and execute_on_specific_threads().
|
inlinestatic |
Definition at line 117 of file ThreadPool.hh.
ThreadPool::size_type PTL::ThreadPool::destroy_threadpool | ( | ) |
Definition at line 468 of file ThreadPool.cc.
|
inline |
Definition at line 454 of file ThreadPool.hh.
Referenced by destroy_threadpool(), and initialize_threadpool().
|
inline |
Definition at line 572 of file ThreadPool.hh.
|
inlinestatic |
Definition at line 133 of file ThreadPool.hh.
|
inline |
Definition at line 227 of file ThreadPool.hh.
|
inlinestatic |
get the default pool size
Definition at line 185 of file ThreadPool.hh.
|
inline |
Definition at line 175 of file ThreadPool.hh.
Referenced by execute_on_all_threads(), execute_on_specific_threads(), and PTL::TaskGroup< Tp, Arg, MaxDepth >::wait().
|
inline |
Definition at line 353 of file ThreadPool.hh.
Referenced by execute_on_all_threads(), and execute_on_specific_threads().
|
static |
Definition at line 148 of file ThreadPool.cc.
Referenced by PTL::UserTaskQueue::GetThreadBin(), initialize_threadpool(), G4TaskRunManagerKernel::InitializeWorker(), and ThreadPool().
Thread * PTL::ThreadPool::get_thread | ( | size_type | _n | ) | const |
Thread * PTL::ThreadPool::get_thread | ( | std::thread::id | id | ) | const |
|
static |
Definition at line 124 of file ThreadPool.cc.
Referenced by get_this_thread_id(), set_affinity(), and set_priority().
|
static |
Definition at line 116 of file ThreadPool.cc.
ThreadPool::task_queue_t *& PTL::ThreadPool::get_valid_queue | ( | task_queue_t *& | _queue | ) | const |
Definition at line 655 of file ThreadPool.cc.
Referenced by add_tasks().
|
inline |
Definition at line 234 of file ThreadPool.hh.
Referenced by destroy_threadpool(), execute_on_all_threads(), and execute_on_specific_threads().
|
inlinestatic |
Definition at line 127 of file ThreadPool.hh.
ThreadPool::size_type PTL::ThreadPool::initialize_threadpool | ( | size_type | proposed_size | ) |
Definition at line 298 of file ThreadPool.cc.
Referenced by resize(), and ThreadPool().
|
inline |
Definition at line 222 of file ThreadPool.hh.
Referenced by PTL::TaskGroup< Tp, Arg, MaxDepth >::wait().
bool PTL::ThreadPool::is_initialized | ( | ) | const |
Definition at line 227 of file ThreadPool.cc.
|
inline |
Definition at line 235 of file ThreadPool.hh.
Referenced by execute_on_all_threads().
|
inline |
Definition at line 178 of file ThreadPool.hh.
|
inline |
Definition at line 303 of file ThreadPool.hh.
Referenced by add_tasks().
|
inline |
Definition at line 322 of file ThreadPool.hh.
|
inline |
Definition at line 314 of file ThreadPool.hh.
|
delete |
|
default |
|
inline |
Definition at line 208 of file ThreadPool.hh.
|
inline |
Definition at line 204 of file ThreadPool.hh.
|
inline |
Definition at line 374 of file ThreadPool.hh.
Referenced by G4TaskRunManager::SetNumberOfThreads().
|
inline |
Definition at line 229 of file ThreadPool.hh.
Referenced by initialize_threadpool(), and ThreadPool().
void PTL::ThreadPool::set_affinity | ( | intmax_t | i, |
Thread & | _thread ) const |
Definition at line 251 of file ThreadPool.cc.
|
inlinestatic |
set the default pool size
Definition at line 182 of file ThreadPool.hh.
|
inline |
Definition at line 202 of file ThreadPool.hh.
|
inline |
Definition at line 201 of file ThreadPool.hh.
void PTL::ThreadPool::set_priority | ( | int | _prio, |
Thread & | _thread ) const |
Definition at line 274 of file ThreadPool.cc.
Referenced by initialize_threadpool().
|
inline |
Definition at line 233 of file ThreadPool.hh.
|
inline |
Definition at line 217 of file ThreadPool.hh.
Referenced by execute_on_all_threads(), execute_on_specific_threads(), get_task_arena(), G4TaskRunManagerKernel::InitializeWorker(), notify(), and PTL::TaskGroup< Tp, Arg, MaxDepth >::wait().
|
inline |
Definition at line 215 of file ThreadPool.hh.
Referenced by ThreadPool(), and PTL::TaskGroup< Tp, Arg, MaxDepth >::wait().
ThreadPool::size_type PTL::ThreadPool::stop_thread | ( | ) |
Definition at line 607 of file ThreadPool.cc.
Referenced by initialize_threadpool().
|
inlinestatic |
Definition at line 345 of file ThreadPool.hh.
Referenced by destroy_threadpool(), execute_on_all_threads(), get_task_arena(), and initialize_threadpool().
|
inline |
Definition at line 221 of file ThreadPool.hh.