Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
VUserTaskQueue.hh
Go to the documentation of this file.
1//
2// MIT License
3// Copyright (c) 2020 Jonathan R. Madsen
4// Permission is hereby granted, free of charge, to any person obtaining a copy
5// of this software and associated documentation files (the "Software"), to deal
6// in the Software without restriction, including without limitation the rights
7// to use, copy, modify, merge, publish, distribute, sublicense, and
8// copies of the Software, and to permit persons to whom the Software is
9// furnished to do so, subject to the following conditions:
10// The above copyright notice and this permission notice shall be included in
11// all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED
12// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
13// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
15// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
16// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
17// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
18//
19// ---------------------------------------------------------------
20// Tasking class header
21// Class Description:
22// Abstract base class for creating a task queue used by
23// ThreadPool
24// ---------------------------------------------------------------
25// Author: Jonathan Madsen
26// ---------------------------------------------------------------
27
28#pragma once
29
30#include "PTL/Globals.hh"
31#include "PTL/Threading.hh"
32
33#include <atomic>
34#include <cstdint>
35#include <functional>
36#include <memory>
37#include <set>
38
39namespace PTL
40{
41class VTask;
42class ThreadPool;
43class ThreadData;
44
46{
47public:
48 using task_pointer = std::shared_ptr<VTask>;
49 using AtomicInt = std::atomic<intmax_t>;
50 using size_type = uintmax_t;
51 using function_type = std::function<void()>;
52 using ThreadIdSet = std::set<ThreadId>;
53
54public:
55 // Constructor - accepting the number of workers
56 explicit VUserTaskQueue(intmax_t nworkers = -1);
57 // Virtual destructors are required by abstract classes
58 // so add it by default, just in case
59 virtual ~VUserTaskQueue() = default;
60
61public:
62 // Virtual function for getting a task from the queue
63 // parameters:
64 // 1. int - get from specific sub-queue
65 // 2. int - number of iterations
66 // returns:
67 // VTask* - a task or nullptr
68 virtual task_pointer GetTask(intmax_t subq = -1, intmax_t nitr = -1) = 0;
69
70 // Virtual function for inserting a task into the queue
71 // parameters:
72 // 1. VTask* - task to insert
73 // 2. int - sub-queue to inserting into
74 // return:
75 // int - subqueue inserted into
76 virtual intmax_t InsertTask(task_pointer&&, ThreadData* = nullptr,
77 intmax_t subq = -1) PTL_NO_SANITIZE_THREAD = 0;
78
79 // Overload this function to hold threads
80 virtual void Wait() = 0;
81 virtual intmax_t GetThreadBin() const = 0;
82
83 virtual void resize(intmax_t) = 0;
84
85 // these are used for stanard checking
86 virtual size_type size() const = 0;
87 virtual bool empty() const = 0;
88
89 virtual size_type bin_size(size_type bin) const = 0;
90 virtual bool bin_empty(size_type bin) const = 0;
91
92 // these are for slower checking, default to returning normal size()/empty
93 virtual size_type true_size() const { return size(); }
94 virtual bool true_empty() const { return empty(); }
95
96 // a method of executing a specific function on all threads
98
100 function_type f) = 0;
101
102 intmax_t workers() const { return m_workers; }
103
104 virtual VUserTaskQueue* clone() = 0;
105
106protected:
107 intmax_t m_workers = 0;
108};
109
110} // namespace PTL
#define PTL_NO_SANITIZE_THREAD
Definition Globals.hh:47
virtual void ExecuteOnSpecificThreads(ThreadIdSet tid_set, ThreadPool *tp, function_type f)=0
virtual task_pointer GetTask(intmax_t subq=-1, intmax_t nitr=-1)=0
virtual size_type true_size() const
std::set< ThreadId > ThreadIdSet
virtual size_type bin_size(size_type bin) const =0
std::function< void()> function_type
virtual intmax_t InsertTask(task_pointer &&, ThreadData *=nullptr, intmax_t subq=-1) PTL_NO_SANITIZE_THREAD=0
virtual void ExecuteOnAllThreads(ThreadPool *tp, function_type f)=0
intmax_t workers() const
virtual bool empty() const =0
virtual void resize(intmax_t)=0
virtual ~VUserTaskQueue()=default
VUserTaskQueue(intmax_t nworkers=-1)
virtual VUserTaskQueue * clone()=0
virtual void Wait()=0
virtual size_type size() const =0
virtual intmax_t GetThreadBin() const =0
std::atomic< intmax_t > AtomicInt
virtual bool bin_empty(size_type bin) const =0
std::shared_ptr< VTask > task_pointer
virtual bool true_empty() const