Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/ptl/include/PTL/VUserTaskQueue.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/ptl/include/PTL/VUserTaskQueue.hh (Version 11.3.0) and /externals/ptl/include/PTL/VUserTaskQueue.hh (Version 11.2.2)


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