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 10.0.p1)


  1 //                                                  1 
  2 // MIT License                                    
  3 // Copyright (c) 2020 Jonathan R. Madsen          
  4 // Permission is hereby granted, free of charg    
  5 // of this software and associated documentati    
  6 // in the Software without restriction, includ    
  7 // to use, copy, modify, merge, publish, distr    
  8 // copies of the Software, and to permit perso    
  9 // furnished to do so, subject to the followin    
 10 // The above copyright notice and this permiss    
 11 // all copies or substantial portions of the S    
 12 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPR    
 13 // LIMITED TO THE WARRANTIES OF MERCHANTABILIT    
 14 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SH    
 15 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR    
 16 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARIS    
 17 // WITH THE SOFTWARE OR THE USE OR OTHER DEALI    
 18 //                                                
 19 //  ------------------------------------------    
 20 //  Tasking class header                          
 21 //  Class Description:                            
 22 //      Abstract base class for creating a tas    
 23 //      ThreadPool                                
 24 //  ------------------------------------------    
 25 //  Author: Jonathan Madsen                       
 26 //  ------------------------------------------    
 27                                                   
 28 #pragma once                                      
 29                                                   
 30 #include "PTL/Macros.hh"                          
 31 #include "PTL/Types.hh"                           
 32                                                   
 33 #include <atomic>                                 
 34 #include <cstdint>                                
 35 #include <functional>                             
 36 #include <memory>                                 
 37 #include <set>                                    
 38                                                   
 39 namespace PTL                                     
 40 {                                                 
 41 class VTask;                                      
 42 class ThreadPool;                                 
 43 class ThreadData;                                 
 44                                                   
 45 class VUserTaskQueue                              
 46 {                                                 
 47 public:                                           
 48     using task_pointer  = std::shared_ptr<VTas    
 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                                                   
 54 public:                                           
 55     // Constructor - accepting the number of w    
 56     explicit VUserTaskQueue(intmax_t nworkers     
 57     // Virtual destructors are required by abs    
 58     // so add it by default, just in case         
 59     virtual ~VUserTaskQueue() = default;          
 60                                                   
 61 public:                                           
 62     // Virtual function for getting a task fro    
 63     // parameters:                                
 64     //      1. int - get from specific sub-que    
 65     //      2. int - number of iterations         
 66     // returns:                                   
 67     //      VTask* - a task or nullptr            
 68     virtual task_pointer GetTask(intmax_t subq    
 69                                                   
 70     // Virtual function for inserting a task i    
 71     // parameters:                                
 72     //      1. VTask* - task to insert            
 73     //      2. int - sub-queue to inserting in    
 74     // return:                                    
 75     //      int - subqueue inserted into          
 76     virtual intmax_t InsertTask(task_pointer&&    
 77                                 intmax_t subq     
 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)     
 90     virtual bool      bin_empty(size_type bin)    
 91                                                   
 92     // these are for slower checking, default     
 93     virtual size_type true_size() const { retu    
 94     virtual bool      true_empty() const { ret    
 95                                                   
 96     // a method of executing a specific functi    
 97     virtual void ExecuteOnAllThreads(ThreadPoo    
 98                                                   
 99     virtual void ExecuteOnSpecificThreads(Thre    
100                                           func    
101                                                   
102     intmax_t workers() const { return m_worker    
103                                                   
104     virtual VUserTaskQueue* clone() = 0;          
105                                                   
106 protected:                                        
107     intmax_t m_workers = 0;                       
108 };                                                
109                                                   
110 }  // namespace PTL                               
111