Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/run/include/G4MTRunManagerKernel.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 /run/include/G4MTRunManagerKernel.hh (Version 11.3.0) and /run/include/G4MTRunManagerKernel.hh (Version 11.2.1)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
 10 // *                                               10 // *                                                                  *
 11 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                               17 // *                                                                  *
 18 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distri     20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  ag     21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publicati     22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Sof     23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // *******************************************     24 // ********************************************************************
 25 //                                                 25 //
 26 // G4MTRunManagerKernel                            26 // G4MTRunManagerKernel
 27 //                                                 27 //
 28 // Class description:                              28 // Class description:
 29 //                                                 29 //
 30 // This is a class for mandatory control of th     30 // This is a class for mandatory control of the Geant4 kernel.
 31 // This class implements Worker behavior in a      31 // This class implements Worker behavior in a MT application.
 32 //                                                 32 //
 33 // This class is constructed by G4MTRunManager     33 // This class is constructed by G4MTRunManager. If a user uses his/her own
 34 // class instead of G4MTRunManager, this class     34 // class instead of G4MTRunManager, this class must be instantiated by at the
 35 // very beginning of the application and must      35 // very beginning of the application and must be deleted at the very end.
 36 // Also, the following methods must be invoked     36 // Also, the following methods must be invoked in the proper order:
 37 //       DefineWorldVolume()                       37 //       DefineWorldVolume()
 38 //       InitializePhysics()                       38 //       InitializePhysics()
 39 //       RunInitialization()                       39 //       RunInitialization()
 40 //       RunTermination()                          40 //       RunTermination()
 41 //                                                 41 //
 42 // User must provide his/her own classes deriv     42 // User must provide his/her own classes derived from the following
 43 // abstract class and register it to the RunMa     43 // abstract class and register it to the RunManagerKernel:
 44 //       G4VUserPhysicsList - Particle types,      44 //       G4VUserPhysicsList - Particle types, Processes and Cuts
 45 //                                                 45 //
 46 // G4MTRunManagerKernel does not have an event     46 // G4MTRunManagerKernel does not have an event loop. Handling of events
 47 // is managed by G4RunManager.                     47 // is managed by G4RunManager.
 48 //                                                 48 //
 49 // This class re-implements only the methods t     49 // This class re-implements only the methods that require special treatment
 50 // to implement worker behavior                    50 // to implement worker behavior
 51                                                    51 
 52 // Author: M.Asai - July 2013                      52 // Author: M.Asai - July 2013
 53 // -------------------------------------------     53 // --------------------------------------------------------------------
 54 #ifndef G4MTRunManagerKernel_hh                    54 #ifndef G4MTRunManagerKernel_hh
 55 #define G4MTRunManagerKernel_hh 1                  55 #define G4MTRunManagerKernel_hh 1
 56                                                    56 
 57 #include "G4MTRunManager.hh"                       57 #include "G4MTRunManager.hh"
 58 #include "G4RunManagerKernel.hh"                   58 #include "G4RunManagerKernel.hh"
 59 #include "G4Threading.hh"                          59 #include "G4Threading.hh"
 60                                                    60 
 61 #include <vector>                                  61 #include <vector>
 62                                                    62 
 63 class G4WorkerThread;                              63 class G4WorkerThread;
 64 class G4WorkerRunManager;                          64 class G4WorkerRunManager;
 65                                                    65 
 66 class G4MTRunManagerKernel : public G4RunManag     66 class G4MTRunManagerKernel : public G4RunManagerKernel
 67 {                                                  67 {
 68   public:                                          68   public:
 69     G4MTRunManagerKernel();                        69     G4MTRunManagerKernel();
 70     ~G4MTRunManagerKernel() override;              70     ~G4MTRunManagerKernel() override;
 71                                                    71 
 72     // Used to start a worker thread. Virtual      72     // Used to start a worker thread. Virtual methods to be invoked
 73     // from this method are defined in G4UserW     73     // from this method are defined in G4UserWorkerInitialization class.
 74     static void StartThread(G4WorkerThread* co     74     static void StartThread(G4WorkerThread* context);
 75                                                    75 
 76     static G4WorkerThread* GetWorkerThread();      76     static G4WorkerThread* GetWorkerThread();
 77                                                    77 
 78     // Fill decay tables with particle definit     78     // Fill decay tables with particle definition pointers of decay products.
 79     // This method has to be invoked by G4MTRu     79     // This method has to be invoked by G4MTRunManager before the event loop
 80     // starts on workers.                          80     // starts on workers.
 81     void SetUpDecayChannels();                     81     void SetUpDecayChannels();
 82                                                    82 
 83     // This method should be invoked by G4MTRu     83     // This method should be invoked by G4MTRunManager.
 84     void BroadcastAbortRun(G4bool softAbort);      84     void BroadcastAbortRun(G4bool softAbort);
 85                                                    85 
 86   protected:                                       86   protected:
 87     void SetupShadowProcess() const override;      87     void SetupShadowProcess() const override;
 88                                                    88 
 89   private:                                         89   private:
 90     static G4ThreadLocal G4WorkerThread* wThre     90     static G4ThreadLocal G4WorkerThread* wThreadContext;
 91                                                    91 
 92     static std::vector<G4WorkerRunManager*>* w     92     static std::vector<G4WorkerRunManager*>* workerRMvector;
 93 };                                                 93 };
 94                                                    94 
 95 #endif  // G4MTRunManagerKernel_hh                 95 #endif  // G4MTRunManagerKernel_hh
 96                                                    96