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 10.5)


  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 ////
 27 //                                                 27 //
 28 // Class description:                          <<  28 
                                                   >>  29 // class description:
                                                   >>  30 //
                                                   >>  31 //     This is a class for mandatory control of GEANT4 kernel.
                                                   >>  32 //     This class implements Worker behavior in a MT application.
                                                   >>  33 //
                                                   >>  34 //     This class is constructed by G4MTRunManager. If a user uses his/her own
                                                   >>  35 //     class instead of G4MTRunManager, this class must be instantiated by
                                                   >>  36 //     him/herself at the very beginning of the application and must be deleted
                                                   >>  37 //     at the very end of the application. Also, following methods must be
                                                   >>  38 //     invoked in the proper order.
                                                   >>  39 //       DefineWorldVolume
                                                   >>  40 //       InitializePhysics
                                                   >>  41 //       RunInitialization
                                                   >>  42 //       RunTermination
 29 //                                                 43 //
 30 // This is a class for mandatory control of th <<  44 //     User must provide his/her own classes derived from the following
 31 // This class implements Worker behavior in a  <<  45 //     abstract class and register it to the RunManagerKernel.
                                                   >>  46 //        G4VUserPhysicsList - Particle types, Processes and Cuts
 32 //                                                 47 //
 33 // This class is constructed by G4MTRunManager <<  48 //     G4MTRunManagerKernel does not have any eveny loop. Handling of events
 34 // class instead of G4MTRunManager, this class <<  49 //     is managed by G4RunManager.
 35 // very beginning of the application and must  <<  50 //
 36 // Also, the following methods must be invoked <<  51 //     This class re-implements only the method that require special treatment
 37 //       DefineWorldVolume()                   <<  52 //     to implement worker behavior
 38 //       InitializePhysics()                   <<  53 
 39 //       RunInitialization()                   <<  54 #ifndef G4MTRunManagerKernel_h
 40 //       RunTermination()                      <<  55 #define G4MTRunManagerKernel_h 1
 41 //                                             << 
 42 // User must provide his/her own classes deriv << 
 43 // abstract class and register it to the RunMa << 
 44 //       G4VUserPhysicsList - Particle types,  << 
 45 //                                             << 
 46 // G4MTRunManagerKernel does not have an event << 
 47 // is managed by G4RunManager.                 << 
 48 //                                             << 
 49 // This class re-implements only the methods t << 
 50 // to implement worker behavior                << 
 51                                                << 
 52 // Author: M.Asai - July 2013                  << 
 53 // ------------------------------------------- << 
 54 #ifndef G4MTRunManagerKernel_hh                << 
 55 #define G4MTRunManagerKernel_hh 1              << 
 56                                                    56 
 57 #include "G4MTRunManager.hh"                   << 
 58 #include "G4RunManagerKernel.hh"                   57 #include "G4RunManagerKernel.hh"
 59 #include "G4Threading.hh"                          58 #include "G4Threading.hh"
 60                                                <<  59 #include "G4MTRunManager.hh"
 61 #include <vector>                              << 
 62                                                    60 
 63 class G4WorkerThread;                              61 class G4WorkerThread;
 64 class G4WorkerRunManager;                          62 class G4WorkerRunManager;
                                                   >>  63 #include <vector>
 65                                                    64 
 66 class G4MTRunManagerKernel : public G4RunManag <<  65 class G4MTRunManagerKernel : public G4RunManagerKernel {
 67 {                                              <<  66 public:
 68   public:                                      << 
 69     G4MTRunManagerKernel();                        67     G4MTRunManagerKernel();
 70     ~G4MTRunManagerKernel() override;          <<  68     virtual ~G4MTRunManagerKernel();
 71                                                <<  69 protected:
 72     // Used to start a worker thread. Virtual  <<  70     void SetupShadowProcess() const;
 73     // from this method are defined in G4UserW <<  71 
                                                   >>  72 public: // with descroption
                                                   >>  73     // This static method is used to start a worker thread.
                                                   >>  74     // Virtual methods to be invoked from this methos are
                                                   >>  75     // defined in G4UserWorkerInitialization class.
 74     static void StartThread(G4WorkerThread* co     76     static void StartThread(G4WorkerThread* context);
 75                                                    77 
                                                   >>  78 //private:
                                                   >>  79 //    static void ReinitializeGeometry();
                                                   >>  80 private:
                                                   >>  81     static G4ThreadLocal G4WorkerThread* wThreadContext;
                                                   >>  82 public:
 76     static G4WorkerThread* GetWorkerThread();      83     static G4WorkerThread* GetWorkerThread();
 77                                                    84 
 78     // Fill decay tables with particle definit <<  85 public: // with descroption
 79     // This method has to be invoked by G4MTRu <<  86     // Fill decay tables with particle definition pointers of
 80     // starts on workers.                      <<  87     // decay products. This method has to be invoked by 
                                                   >>  88     // MTRunManager before event loop starts on workers.
 81     void SetUpDecayChannels();                     89     void SetUpDecayChannels();
 82                                                    90 
 83     // This method should be invoked by G4MTRu <<  91 private:
 84     void BroadcastAbortRun(G4bool softAbort);  << 
 85                                                << 
 86   protected:                                   << 
 87     void SetupShadowProcess() const override;  << 
 88                                                << 
 89   private:                                     << 
 90     static G4ThreadLocal G4WorkerThread* wThre << 
 91                                                << 
 92     static std::vector<G4WorkerRunManager*>* w     92     static std::vector<G4WorkerRunManager*>* workerRMvector;
                                                   >>  93 
                                                   >>  94 public:
                                                   >>  95     // This method should be invoked by G4MTRunManager
                                                   >>  96     void BroadcastAbortRun(G4bool softAbort);
 93 };                                                 97 };
 94                                                    98 
 95 #endif  // G4MTRunManagerKernel_hh             <<  99 #endif //G4MTRunManagerKernel_h
 96                                                   100