Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4WorkerTaskRunManagerKernel Class Reference

#include <G4WorkerTaskRunManagerKernel.hh>

+ Inheritance diagram for G4WorkerTaskRunManagerKernel:

Public Member Functions

 G4WorkerTaskRunManagerKernel ()
 
virtual ~G4WorkerTaskRunManagerKernel ()
 
- Public Member Functions inherited from G4RunManagerKernel
 G4RunManagerKernel ()
 
virtual ~G4RunManagerKernel ()
 
void DefineWorldVolume (G4VPhysicalVolume *worldVol, G4bool topologyIsChanged=true)
 
void WorkerDefineWorldVolume (G4VPhysicalVolume *worldVol, G4bool topologyIsChanged=true)
 
void SetPhysics (G4VUserPhysicsList *uPhys)
 
void InitializePhysics ()
 
G4bool RunInitialization (G4bool fakeRun=false)
 
void RunTermination ()
 
void UpdateRegion ()
 
void DumpRegion (const G4String &rname) const
 
void DumpRegion (G4Region *region=nullptr) const
 
void WorkerUpdateWorldVolume ()
 
void GeometryHasBeenModified ()
 
void PhysicsHasBeenModified ()
 
G4EventManagerGetEventManager () const
 
G4StackManagerGetStackManager () const
 
G4TrackingManagerGetTrackingManager () const
 
void SetPrimaryTransformer (G4PrimaryTransformer *pt)
 
G4PrimaryTransformerGetPrimaryTransformer () const
 
const G4StringGetVersionString () const
 
void SetVerboseLevel (G4int vl)
 
void SetGeometryToBeOptimized (G4bool vl)
 
G4int GetNumberOfParallelWorld () const
 
void SetNumberOfParallelWorld (G4int i)
 
G4VUserPhysicsListGetPhysicsList () const
 
G4VPhysicalVolumeGetCurrentWorld () const
 
G4int GetNumberOfStaticAllocators () const
 

Protected Member Functions

void SetupShadowProcess () const
 
- Protected Member Functions inherited from G4RunManagerKernel
 G4RunManagerKernel (RMKType rmkType)
 
void SetupDefaultRegion ()
 
void SetupPhysics ()
 
void ResetNavigator ()
 
void BuildPhysicsTables (G4bool fakeRun)
 
void CheckRegions ()
 
virtual void SetupShadowProcess () const
 
void PropagateGenericIonID ()
 

Additional Inherited Members

- Public Types inherited from G4RunManagerKernel
enum  RMKType { sequentialRMK , masterRMK , workerRMK }
 
- Static Public Member Functions inherited from G4RunManagerKernel
static G4RunManagerKernelGetRunManagerKernel ()
 
- Protected Attributes inherited from G4RunManagerKernel
RMKType runManagerKernelType
 
G4RegiondefaultRegion = nullptr
 
G4RegiondefaultRegionForParallelWorld = nullptr
 
G4bool geometryNeedsToBeClosed = true
 

Detailed Description

Definition at line 59 of file G4WorkerTaskRunManagerKernel.hh.

Constructor & Destructor Documentation

◆ G4WorkerTaskRunManagerKernel()

G4WorkerTaskRunManagerKernel::G4WorkerTaskRunManagerKernel ( )

Definition at line 32 of file G4WorkerTaskRunManagerKernel.cc.

34{
35 // This version of the constructor should never be called in sequential mode!
36#ifndef G4MULTITHREADED
38 msg << "Geant4 code is compiled without multi-threading support "
39 "(-DG4MULTITHREADED is set to off).";
40 msg << " This type of RunManager can only be used in mult-threaded "
41 "applications.";
42 G4Exception("G4RunManagerKernel::G4RunManagerKernel()", "Run0102",
43 FatalException, msg);
44#endif
45}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
Definition: G4Exception.cc:59
std::ostringstream G4ExceptionDescription
Definition: G4Exception.hh:40

◆ ~G4WorkerTaskRunManagerKernel()

G4WorkerTaskRunManagerKernel::~G4WorkerTaskRunManagerKernel ( )
virtual

Definition at line 49 of file G4WorkerTaskRunManagerKernel.cc.

50{
52}
void DestroyWorkerG4ParticleTable()
static G4ParticleTable * GetParticleTable()

Member Function Documentation

◆ SetupShadowProcess()

void G4WorkerTaskRunManagerKernel::SetupShadowProcess ( ) const
protectedvirtual

Reimplemented from G4RunManagerKernel.

Definition at line 56 of file G4WorkerTaskRunManagerKernel.cc.

57{
58 // Master thread has created processes and setup a pointer
59 // to the master process, get it and copy it in this instance
62 theParticleTable->GetIterator();
63 theParticleIterator->reset();
64 // loop on particles and get process manager from there list of processes
65 while((*theParticleIterator)())
66 {
70 if(!pm || !pmM)
71 {
73 msg
74 << "Process manager or process manager shadow to master are not set.\n";
75 msg << "Particle : " << pd->GetParticleName() << " (" << pd
76 << "), proc-manager: " << pm;
77 msg << " proc-manager-shadow: " << pmM;
78 G4Exception("G4WorkerTaskRunManagerKernel::SetupShadowProcess()",
79 "Run0116", FatalException, msg);
80 return;
81 }
82 G4ProcessVector& procs = *(pm->GetProcessList());
83 G4ProcessVector& procsM = *(pmM->GetProcessList());
84 if(procs.size() != procsM.size())
85 {
86 G4cout
87 << "G4WorkerTaskRunManagerKernel::SetupShadowProcess() for particle <"
88 << pd->GetParticleName() << ">" << G4endl;
89 G4cout << " ProcessManager : " << pm << " ProcessManagerShadow : " << pmM
90 << G4endl;
91
92 for(G4int iv1 = 0; iv1 < (G4int)procs.size(); ++iv1)
93 G4cout << " " << iv1 << " - " << procs[iv1]->GetProcessName()
94 << G4endl;
95
96 G4cout << "--------------------------------------------------------------"
97 << G4endl;
98
99 for(G4int iv2 = 0; iv2 < (G4int)procsM.size(); ++iv2)
100 G4cout << " " << iv2 << " - " << procsM[iv2]->GetProcessName()
101 << G4endl;
102
103 G4cout << "--------------------------------------------------------------"
104 << G4endl;
105
107 msg
108 << " Size of G4ProcessVector is inconsistent between master and worker "
109 "threads ";
110 msg << " for the particle <" << pd->GetParticleName() << ">. \n";
111 msg << " size of G4ProcessVector for worker thread is " << procs.size();
112 msg << " while master thread is " << procsM.size() << ".";
113 G4Exception("G4WorkerTaskRunManagerKernel::SetupShadowProcess()",
114 "Run0117", FatalException, msg);
115 }
116 // To each process add the reference to the same
117 // process from master. Note that we rely on
118 // processes being in the correct order!
119 // We could use some checking using process name or type
120 for(G4int idx = 0; idx < (G4int)procs.size(); ++idx)
121 {
122 procs[idx]->SetMasterProcess(procsM[idx]);
123 }
124 }
125}
int G4int
Definition: G4Types.hh:85
#define theParticleIterator
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
G4ProcessManager * GetProcessManager() const
G4ProcessManager * GetMasterProcessManager() const
const G4String & GetParticleName() const
G4PTblDicIterator * GetIterator() const
G4ProcessVector * GetProcessList() const
std::size_t size() const

The documentation for this class was generated from the following files: