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.0.p4)


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