Geant4-11
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#include "PTL/Types.hh"
33
34#include <cstddef>
35#include <memory>
36#include <set>
37#include <tuple>
38#include <type_traits>
39#include <utility>
40
41namespace PTL
42{
43class VTask;
44class ThreadPool;
45class ThreadData;
46
48{
49public:
50 typedef std::shared_ptr<VTask> task_pointer;
51 typedef std::atomic<intmax_t> AtomicInt;
52 typedef uintmax_t size_type;
54 typedef std::set<ThreadId> ThreadIdSet;
55
56public:
57 // Constructor - accepting the number of workers
58 explicit VUserTaskQueue(intmax_t nworkers = -1);
59 // Virtual destructors are required by abstract classes
60 // so add it by default, just in case
61 virtual ~VUserTaskQueue() = default;
62
63public:
64 // Virtual function for getting a task from the queue
65 // parameters:
66 // 1. int - get from specific sub-queue
67 // 2. int - number of iterations
68 // returns:
69 // VTask* - a task or nullptr
70 virtual task_pointer GetTask(intmax_t subq = -1, intmax_t nitr = -1) = 0;
71
72 // Virtual function for inserting a task into the queue
73 // parameters:
74 // 1. VTask* - task to insert
75 // 2. int - sub-queue to inserting into
76 // return:
77 // int - subqueue inserted into
78 virtual intmax_t InsertTask(task_pointer&&, ThreadData* = nullptr,
79 intmax_t subq = -1) PTL_NO_SANITIZE_THREAD = 0;
80
81 // Overload this function to hold threads
82 virtual void Wait() = 0;
83 virtual intmax_t GetThreadBin() const = 0;
84
85 virtual void resize(intmax_t) = 0;
86
87 // these are used for stanard checking
88 virtual size_type size() const = 0;
89 virtual bool empty() const = 0;
90
91 virtual size_type bin_size(size_type bin) const = 0;
92 virtual bool bin_empty(size_type bin) const = 0;
93
94 // these are for slower checking, default to returning normal size()/empty
95 virtual size_type true_size() const { return size(); }
96 virtual bool true_empty() const { return empty(); }
97
98 // a method of executing a specific function on all threads
100
102 function_type f) = 0;
103
104 intmax_t workers() const { return m_workers; }
105
106 virtual VUserTaskQueue* clone() = 0;
107
108protected:
109 intmax_t m_workers = 0;
110};
111
112} // namespace PTL
G4double(* function)(G4double)
#define PTL_NO_SANITIZE_THREAD
Definition: Globals.hh:61
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
virtual size_type bin_size(size_type bin) const =0
std::atomic< intmax_t > AtomicInt
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
std::set< ThreadId > ThreadIdSet
virtual void Wait()=0
virtual size_type size() const =0
virtual intmax_t GetThreadBin() const =0
virtual bool bin_empty(size_type bin) const =0
std::function< void()> function_type
std::shared_ptr< VTask > task_pointer
virtual bool true_empty() const
Definition: AutoLock.hh:254