Geant4
10.7.0
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
////
27
//
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
43
//
44
// User must provide his/her own classes derived from the following
45
// abstract class and register it to the RunManagerKernel.
46
// G4VUserPhysicsList - Particle types, Processes and Cuts
47
//
48
// G4MTRunManagerKernel does not have any eveny loop. Handling of events
49
// is managed by G4RunManager.
50
//
51
// This class re-implements only the method that require special treatment
52
// to implement worker behavior
53
54
#ifndef G4MTRunManagerKernel_h
55
#define G4MTRunManagerKernel_h 1
56
57
#include "
G4MTRunManager.hh
"
58
#include "
G4RunManagerKernel.hh
"
59
#include "
G4Threading.hh
"
60
61
class
G4WorkerThread
;
62
class
G4WorkerRunManager
;
63
#include <vector>
64
65
class
G4MTRunManagerKernel
:
public
G4RunManagerKernel
66
{
67
public
:
68
G4MTRunManagerKernel
();
69
virtual
~G4MTRunManagerKernel
();
70
71
protected
:
72
void
SetupShadowProcess
()
const
;
73
74
public
:
// with descroption
75
// This static method is used to start a worker thread.
76
// Virtual methods to be invoked from this methos are
77
// defined in G4UserWorkerInitialization class.
78
static
void
StartThread
(
G4WorkerThread
* context);
79
80
// private:
81
// static void ReinitializeGeometry();
82
private
:
83
static
G4ThreadLocal
G4WorkerThread
* wThreadContext;
84
85
public
:
86
static
G4WorkerThread
*
GetWorkerThread
();
87
88
public
:
// with descroption
89
// Fill decay tables with particle definition pointers of
90
// decay products. This method has to be invoked by
91
// MTRunManager before event loop starts on workers.
92
void
SetUpDecayChannels
();
93
94
private
:
95
static
std::vector<G4WorkerRunManager*>* workerRMvector;
96
97
public
:
98
// This method should be invoked by G4MTRunManager
99
void
BroadcastAbortRun
(
G4bool
softAbort);
100
};
101
102
#endif
// G4MTRunManagerKernel_h
G4MTRunManager.hh
G4RunManagerKernel.hh
G4Threading.hh
G4bool
bool G4bool
Definition:
G4Types.hh:86
G4MTRunManagerKernel
Definition:
G4MTRunManagerKernel.hh:66
G4MTRunManagerKernel::BroadcastAbortRun
void BroadcastAbortRun(G4bool softAbort)
Definition:
G4MTRunManagerKernel.cc:269
G4MTRunManagerKernel::GetWorkerThread
static G4WorkerThread * GetWorkerThread()
Definition:
G4MTRunManagerKernel.cc:109
G4MTRunManagerKernel::SetUpDecayChannels
void SetUpDecayChannels()
Definition:
G4MTRunManagerKernel.cc:250
G4MTRunManagerKernel::~G4MTRunManagerKernel
virtual ~G4MTRunManagerKernel()
Definition:
G4MTRunManagerKernel.cc:61
G4MTRunManagerKernel::SetupShadowProcess
void SetupShadowProcess() const
Definition:
G4MTRunManagerKernel.cc:79
G4MTRunManagerKernel::G4MTRunManagerKernel
G4MTRunManagerKernel()
Definition:
G4MTRunManagerKernel.cc:39
G4MTRunManagerKernel::StartThread
static void StartThread(G4WorkerThread *context)
Definition:
G4MTRunManagerKernel.cc:114
G4RunManagerKernel
Definition:
G4RunManagerKernel.hh:68
G4WorkerRunManager
Definition:
G4WorkerRunManager.hh:48
G4WorkerThread
Definition:
G4WorkerThread.hh:43
G4ThreadLocal
#define G4ThreadLocal
Definition:
tls.hh:77
geant4-v10.7.0
source
run
include
G4MTRunManagerKernel.hh
Generated by
1.9.6