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