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

#include <G4WorkerRunManager.hh>

+ Inheritance diagram for G4WorkerRunManager:

Public Member Functions

 G4WorkerRunManager ()
 
 ~G4WorkerRunManager () override
 
void InitializeGeometry () override
 
void RunInitialization () override
 
void DoEventLoop (G4int n_event, const char *macroFile=nullptr, G4int n_select=-1) override
 
void ProcessOneEvent (G4int i_event) override
 
G4EventGenerateEvent (G4int i_event) override
 
void RunTermination () override
 
void TerminateEventLoop () override
 
virtual void DoWork ()
 
void SetWorkerThread (G4WorkerThread *wc)
 
void SetUserInitialization (G4VUserPhysicsList *userInit) override
 
void SetUserInitialization (G4VUserDetectorConstruction *userInit) override
 
void SetUserInitialization (G4VUserActionInitialization *userInit) override
 
void SetUserInitialization (G4UserWorkerInitialization *userInit) override
 
void SetUserInitialization (G4UserWorkerThreadInitialization *userInit) override
 
void SetUserAction (G4UserRunAction *userAction) override
 
void SetUserAction (G4VUserPrimaryGeneratorAction *userAction) override
 
void SetUserAction (G4UserEventAction *userAction) override
 
void SetUserAction (G4UserStackingAction *userAction) override
 
void SetUserAction (G4UserTrackingAction *userAction) override
 
void SetUserAction (G4UserSteppingAction *userAction) override
 
void RestoreRndmEachEvent (G4bool flag) override
 
- Public Member Functions inherited from G4RunManager
 G4RunManager ()
 
virtual ~G4RunManager ()
 
 G4RunManager (const G4RunManager &)=delete
 
G4RunManageroperator= (const G4RunManager &)=delete
 
virtual void BeamOn (G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
 
virtual void Initialize ()
 
virtual void DefineWorldVolume (G4VPhysicalVolume *worldVol, G4bool topologyIsChanged=true)
 
virtual void AbortRun (G4bool softAbort=false)
 
virtual void AbortEvent ()
 
virtual void InitializePhysics ()
 
virtual G4bool ConfirmBeamOnCondition ()
 
virtual void InitializeEventLoop (G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
 
virtual void TerminateOneEvent ()
 
virtual void AnalyzeEvent (G4Event *anEvent)
 
virtual void SetNumberOfThreads (G4int)
 
virtual G4int GetNumberOfThreads () const
 
void DumpRegion (const G4String &rname) const
 
void DumpRegion (G4Region *region=nullptr) const
 
void GeometryHasBeenModified (G4bool prop=true)
 
void ReinitializeGeometry (G4bool destroyFirst=false, G4bool prop=true)
 
void PhysicsHasBeenModified ()
 
void CutOffHasBeenModified ()
 
void ReOptimizeMotherOf (G4VPhysicalVolume *)
 
void ReOptimize (G4LogicalVolume *)
 
void SetGeometryToBeOptimized (G4bool vl)
 
G4bool GetGeometryToBeOptimized ()
 
void GeometryDirectlyUpdated (G4bool val=true)
 
virtual void RestoreRandomNumberStatus (const G4String &fileN)
 
const G4VUserDetectorConstructionGetUserDetectorConstruction () const
 
const G4VUserPhysicsListGetUserPhysicsList () const
 
const G4VUserActionInitializationGetUserActionInitialization () const
 
G4VUserActionInitializationGetNonConstUserActionInitialization () const
 
const G4UserWorkerInitializationGetUserWorkerInitialization () const
 
const G4UserWorkerThreadInitializationGetUserWorkerThreadInitialization () const
 
const G4UserRunActionGetUserRunAction () const
 
const G4VUserPrimaryGeneratorActionGetUserPrimaryGeneratorAction () const
 
const G4UserEventActionGetUserEventAction () const
 
const G4UserStackingActionGetUserStackingAction () const
 
const G4UserTrackingActionGetUserTrackingAction () const
 
const G4UserSteppingActionGetUserSteppingAction () const
 
void SetNumberOfAdditionalWaitingStacks (G4int iAdd)
 
void SetDefaultClassification (G4TrackStatus ts, G4ClassificationOfNewTrack val, G4ExceptionSeverity es=G4ExceptionSeverity::IgnoreTheIssue)
 
void SetDefaultClassification (const G4ParticleDefinition *pd, G4ClassificationOfNewTrack val, G4ExceptionSeverity es=G4ExceptionSeverity::IgnoreTheIssue)
 
const G4StringGetVersionString () const
 
void SetPrimaryTransformer (G4PrimaryTransformer *pt)
 
void StoreRandomNumberStatusToG4Event (G4int vl)
 
G4int GetFlagRandomNumberStatusToG4Event () const
 
void SetRandomNumberStore (G4bool flag)
 
G4bool GetRandomNumberStore () const
 
void SetRandomNumberStoreDir (const G4String &dir)
 
const G4StringGetRandomNumberStoreDir () const
 
const G4StringGetRandomNumberStatusForThisRun () const
 
const G4StringGetRandomNumberStatusForThisEvent () const
 
void SetRandomNumberStorePerEvent (G4bool flag)
 
G4bool GetRandomNumberStorePerEvent () const
 
void SetVerboseLevel (G4int vl)
 
G4int GetVerboseLevel () const
 
G4int GetPrintProgress ()
 
void SetPrintProgress (G4int i)
 
void SetNumberOfEventsToBeStored (G4int val)
 
const G4RunGetCurrentRun () const
 
G4RunGetNonConstCurrentRun () const
 
const G4EventGetCurrentEvent () const
 
const G4EventGetPreviousEvent (G4int i) const
 
void SetRunIDCounter (G4int i)
 
G4int GetNumberOfParallelWorld () const
 
void SetNumberOfEventsToBeProcessed (G4int val)
 
G4int GetNumberOfEventsToBeProcessed () const
 
G4int GetNumberOfSelectEvents () const
 
const G4StringGetSelectMacro () const
 
void SetDCtable (G4DCtable *DCtbl)
 
RMType GetRunManagerType () const
 
virtual void RegisterSubEventType (G4int, G4int)
 
virtual void MergeTrajectories (const G4SubEvent *, const G4Event *)
 
virtual void UpdateScoringForSubEvent (const G4SubEvent *, const G4Event *)
 
virtual const G4SubEventGetSubEvent (G4int, G4bool &, G4long &, G4long &, G4long &, G4bool)
 
virtual void SubEventFinished (const G4SubEvent *, const G4Event *)
 
virtual G4int GetSubEventType () const
 
virtual void SetSubEventType (G4int)
 
virtual std::size_t GetMaxNTrack () const
 
virtual void TrajectoriesToBeMerged (G4bool)
 
virtual void ReportEventDeletion (const G4Event *evt)
 
void ResetNavigatorAtInitialization (G4bool val=true)
 

Static Public Member Functions

static G4WorkerRunManagerGetWorkerRunManager ()
 
static G4WorkerRunManagerKernelGetWorkerRunManagerKernel ()
 
- Static Public Member Functions inherited from G4RunManager
static G4RunManagerGetRunManager ()
 
static G4bool IfGeometryHasBeenDestroyed ()
 

Protected Member Functions

void ConstructScoringWorlds () override
 
void StoreRNGStatus (const G4String &filenamePrefix) override
 
void rndmSaveThisRun () override
 
void rndmSaveThisEvent () override
 
virtual void MergePartialResults (G4bool mergeEvents=true)
 
virtual void SetupDefaultRNGEngine ()
 
- Protected Member Functions inherited from G4RunManager
 G4RunManager (RMType rmType)
 
virtual void StackPreviousEvent (G4Event *anEvent)
 
virtual void CleanUpPreviousEvents ()
 
virtual void CleanUpUnnecessaryEvents (G4int keepNEvents)
 
void UpdateScoring (const G4Event *evt=nullptr)
 
virtual void DeleteUserInitializations ()
 

Protected Attributes

G4WorkerThreadworkerContext = nullptr
 
G4bool eventLoopOnGoing = false
 
G4bool runIsSeeded = false
 
G4int nevModulo = -1
 
G4int currEvID = -1
 
G4int luxury = -1
 
G4SeedsQueue seedsQueue
 
G4bool readStatusFromFile = false
 
- Protected Attributes inherited from G4RunManager
G4RunManagerKernelkernel = nullptr
 
G4EventManagereventManager = nullptr
 
G4VUserDetectorConstructionuserDetector = nullptr
 
G4VUserPhysicsListphysicsList = nullptr
 
G4VUserActionInitializationuserActionInitialization = nullptr
 
G4UserWorkerInitializationuserWorkerInitialization = nullptr
 
G4UserWorkerThreadInitializationuserWorkerThreadInitialization = nullptr
 
G4UserRunActionuserRunAction = nullptr
 
G4VUserPrimaryGeneratorActionuserPrimaryGeneratorAction = nullptr
 
G4UserEventActionuserEventAction = nullptr
 
G4UserStackingActionuserStackingAction = nullptr
 
G4UserTrackingActionuserTrackingAction = nullptr
 
G4UserSteppingActionuserSteppingAction = nullptr
 
G4bool geometryInitialized = false
 
G4bool physicsInitialized = false
 
G4bool runAborted = false
 
G4bool initializedAtLeastOnce = false
 
G4bool geometryToBeOptimized = true
 
G4int runIDCounter = 0
 
G4int verboseLevel = 0
 
G4int printModulo = -1
 
G4Timertimer = nullptr
 
G4DCtableDCtable = nullptr
 
G4RuncurrentRun = nullptr
 
G4EventcurrentEvent = nullptr
 
std::list< G4Event * > * previousEvents = nullptr
 
G4int n_perviousEventsToBeStored = 0
 
G4int numberOfEventToBeProcessed = 0
 
G4bool storeRandomNumberStatus = false
 
G4int storeRandomNumberStatusToG4Event = 0
 
G4String randomNumberStatusDir = "./"
 
G4String randomNumberStatusForThisRun = ""
 
G4String randomNumberStatusForThisEvent = ""
 
G4bool rngStatusEventsFlag = false
 
G4VPhysicalVolumecurrentWorld = nullptr
 
G4int nParallelWorlds = 0
 
G4String msgText = " "
 
G4int n_select_msg = -1
 
G4int numberOfEventProcessed = 0
 
G4String selectMacro = ""
 
G4bool fakeRun = false
 
G4bool isScoreNtupleWriter = false
 
G4bool geometryDirectlyUpdated = false
 
RMType runManagerType
 

Additional Inherited Members

- Public Types inherited from G4RunManager
enum  RMType {
  sequentialRM , masterRM , workerRM , subEventMasterRM ,
  subEventWorkerRM
}
 
- Static Protected Attributes inherited from G4RunManager
static G4RUN_DLL G4bool fGeometryHasBeenDestroyed = false
 

Detailed Description

Definition at line 48 of file G4WorkerRunManager.hh.

Constructor & Destructor Documentation

◆ G4WorkerRunManager()

G4WorkerRunManager::G4WorkerRunManager ( )

Definition at line 76 of file G4WorkerRunManager.cc.

77{
78 // This constructor should never be called in non-multithreaded mode
79
80#ifndef G4MULTITHREADED
82 msg << "Geant4 code is compiled without multi-threading support "
83 "(-DG4MULTITHREADED "
84 "is set to off).";
85 msg << " This type of RunManager can only be used in mult-threaded "
86 "applications.";
87 G4Exception("G4WorkerRunManager::G4WorkerRunManager()", "Run0103", FatalException, msg);
88#endif
89 // G4ParticleTable::GetParticleTable()->WorkerG4ParticleTable();
90 // WorkerG4ParticleTable() would be performed twice,
91 // as it is called already from G4ParticleTable::GetParticleTable()
92 // which is called beforehand by other Geant4 classes
93 G4ScoringManager* masterScM = G4MTRunManager::GetMasterScoringManager();
94 if (masterScM != nullptr) G4ScoringManager::GetScoringManager(); // TLS instance for a worker
95
96 // Properly initialise luxury level for Ranlux* engines...
97 //
98 if (dynamic_cast<const CLHEP::Ranlux64Engine*>(G4Random::getTheEngine()) != nullptr) {
99 const auto theEngine = dynamic_cast<const CLHEP::Ranlux64Engine*>(G4Random::getTheEngine());
100 luxury = theEngine->getLuxury();
101 }
102 else if (dynamic_cast<const CLHEP::RanluxEngine*>(G4Random::getTheEngine()) != nullptr) {
103 const auto theEngine = dynamic_cast<const CLHEP::RanluxEngine*>(G4Random::getTheEngine());
104 luxury = theEngine->getLuxury();
105 }
106
108
109#ifdef G4MULTITHREADED
110 G4VVisManager* pVVis = G4VVisManager::GetConcreteInstance();
111 if (pVVis != nullptr) {
112 pVVis->SetUpForAThread();
113 visIsSetUp = true;
114 }
115#endif
116}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
static G4ScoringManager * GetMasterScoringManager()
static G4ScoringManager * GetScoringManager()
void SetIgnoreCmdNotFound(G4bool val)
static G4UImanager * GetUIpointer()
static G4VVisManager * GetConcreteInstance()
virtual void SetUpForAThread()

Referenced by GetWorkerRunManager().

◆ ~G4WorkerRunManager()

G4WorkerRunManager::~G4WorkerRunManager ( )
override

Definition at line 119 of file G4WorkerRunManager.cc.

120{
122 // Put these pointers to zero: owned by master thread
123 // If not to zero, the base class destructor will attempt to
124 // delete them
125 userDetector = nullptr;
126 userWorkerInitialization = nullptr;
128 userActionInitialization = nullptr;
129 physicsList->TerminateWorker();
130 physicsList = nullptr;
131 if (verboseLevel > 1) G4cout << "Destroying WorkerRunManager (" << this << ")" << G4endl;
132}
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
virtual void CleanUpPreviousEvents()
G4UserWorkerInitialization * userWorkerInitialization
G4UserWorkerThreadInitialization * userWorkerThreadInitialization
G4VUserActionInitialization * userActionInitialization
G4VUserDetectorConstruction * userDetector
G4VUserPhysicsList * physicsList

Member Function Documentation

◆ ConstructScoringWorlds()

void G4WorkerRunManager::ConstructScoringWorlds ( )
overrideprotectedvirtual

Reimplemented from G4RunManager.

Definition at line 482 of file G4WorkerRunManager.cc.

483{
484 using MeshShape = G4VScoringMesh::MeshShape;
485
486 // Return if unnecessary
487 G4ScoringManager* ScM = G4ScoringManager::GetScoringManagerIfExist();
488 if (ScM == nullptr) return;
489 auto nPar = (G4int)ScM->GetNumberOfMesh();
490 if (nPar < 1) return;
491
492 // Update thread-local G4TransportationManager of all the world volumes
493 kernel->WorkerUpdateWorldVolume();
494
495 G4ScoringManager* masterScM = G4MTRunManager::GetMasterScoringManager();
496
498
499 for (G4int iw = 0; iw < nPar; ++iw) {
500 G4VScoringMesh* mesh = ScM->GetMesh(iw);
502 G4VPhysicalVolume* pWorld = nullptr;
503 if (mesh->GetShape() != MeshShape::realWorldLogVol) {
504 pWorld =
506 if (pWorld == nullptr) {
508 ed << "Mesh name <" << ScM->GetWorldName(iw) << "> is not found in the master thread.";
509 G4Exception("G4WorkerRunManager::ConstructScoringWorlds()", "RUN79001", FatalException, ed);
510 }
511 }
512 if ((mesh->GetMeshElementLogical()) == nullptr) {
513 G4AutoLock l(&ConstructScoringWorldsMutex);
514 G4VScoringMesh* masterMesh = masterScM->GetMesh(iw);
515 mesh->SetMeshElementLogical(masterMesh->GetMeshElementLogical());
516 l.unlock();
517
518 if (mesh->GetShape() != MeshShape::realWorldLogVol) {
519 G4ParallelWorldProcess* theParallelWorldProcess = mesh->GetParallelWorldProcess();
520 if (theParallelWorldProcess != nullptr) {
521 theParallelWorldProcess->SetParallelWorld(ScM->GetWorldName(iw));
522 }
523 else {
524 theParallelWorldProcess = new G4ParallelWorldProcess(ScM->GetWorldName(iw));
525 mesh->SetParallelWorldProcess(theParallelWorldProcess);
526 theParallelWorldProcess->SetParallelWorld(ScM->GetWorldName(iw));
527
528 particleIterator->reset();
529 while ((*particleIterator)()) {
530 G4ParticleDefinition* particle = particleIterator->value();
531 G4ProcessManager* pmanager = particle->GetProcessManager();
532 if (pmanager != nullptr) {
533 pmanager->AddProcess(theParallelWorldProcess);
534 if (theParallelWorldProcess->IsAtRestRequired(particle)) {
535 pmanager->SetProcessOrdering(theParallelWorldProcess, idxAtRest, 9900);
536 }
537 pmanager->SetProcessOrderingToSecond(theParallelWorldProcess, idxAlongStep);
538 pmanager->SetProcessOrdering(theParallelWorldProcess, idxPostStep, 9900);
539 } // if(pmanager)
540 } // while
541 }
542 theParallelWorldProcess->SetLayeredMaterialFlag(mesh->LayeredMassFlg());
543 }
544 }
545 mesh->WorkerConstruct(pWorld);
546 }
547}
G4TemplateAutoLock< G4Mutex > G4AutoLock
std::vector< G4InuclElementaryParticle >::iterator particleIterator
@ idxPostStep
@ idxAtRest
@ idxAlongStep
int G4int
Definition G4Types.hh:85
void SetLayeredMaterialFlag(G4bool flg=true)
void SetParallelWorld(G4String parallelWorldName)
G4bool IsAtRestRequired(G4ParticleDefinition *)
G4ProcessManager * GetProcessManager() const
G4PTblDicIterator * GetIterator() const
static G4ParticleTable * GetParticleTable()
void SetProcessOrdering(G4VProcess *aProcess, G4ProcessVectorDoItIndex idDoIt, G4int ordDoIt=ordDefault)
void SetProcessOrderingToSecond(G4VProcess *aProcess, G4ProcessVectorDoItIndex idDoIt)
G4int AddProcess(G4VProcess *aProcess, G4int ordAtRestDoIt=ordInActive, G4int ordAlongSteptDoIt=ordInActive, G4int ordPostStepDoIt=ordInActive)
G4RunManagerKernel * kernel
static G4RUN_DLL G4bool fGeometryHasBeenDestroyed
G4VScoringMesh * GetMesh(G4int i) const
const G4String & GetWorldName(G4int i) const
std::size_t GetNumberOfMesh() const
static G4ScoringManager * GetScoringManagerIfExist()
static G4TransportationManager * GetTransportationManager()
G4VPhysicalVolume * IsWorldExisting(const G4String &worldName)
MeshShape GetShape() const
G4LogicalVolume * GetMeshElementLogical() const
virtual void WorkerConstruct(G4VPhysicalVolume *fWorldPhys)
void GeometryHasBeenDestroyed()
G4ParallelWorldProcess * GetParallelWorldProcess() const
void SetParallelWorldProcess(G4ParallelWorldProcess *proc)
void SetMeshElementLogical(G4LogicalVolume *val)
G4bool LayeredMassFlg()

Referenced by G4WorkerSubEvtRunManager::DoWork(), and G4WorkerTaskRunManager::DoWork().

◆ DoEventLoop()

void G4WorkerRunManager::DoEventLoop ( G4int n_event,
const char * macroFile = nullptr,
G4int n_select = -1 )
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 252 of file G4WorkerRunManager.cc.

253{
254 if (userPrimaryGeneratorAction == nullptr) {
255 G4Exception("G4RunManager::GenerateEvent()", "Run0032", FatalException,
256 "G4VUserPrimaryGeneratorAction is not defined!");
257 }
258
259 // This is the same as in the sequential case, just the for-loop indexes are
260 // different
261 InitializeEventLoop(n_event, macroFile, n_select);
262
263 // Reset random number seeds queue
264 while (!seedsQueue.empty()) {
265 seedsQueue.pop();
266 }
267 // for each run, worker should receive at least one set of random number
268 // seeds.
269 runIsSeeded = false;
270
271 // Event loop
272 eventLoopOnGoing = true;
273 /////// G4int i_event = workerContext->GetThreadId();
274 G4int i_event = -1;
275 nevModulo = -1;
276 currEvID = -1;
277
278 while (eventLoopOnGoing) {
279 ProcessOneEvent(i_event);
280 if (eventLoopOnGoing) {
282 if (runAborted) {
283 eventLoopOnGoing = false;
284 }
285 }
286 }
287
289}
virtual void InitializeEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
G4VUserPrimaryGeneratorAction * userPrimaryGeneratorAction
virtual void TerminateOneEvent()
void TerminateEventLoop() override
void ProcessOneEvent(G4int i_event) override

◆ DoWork()

void G4WorkerRunManager::DoWork ( )
virtual

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 706 of file G4WorkerRunManager.cc.

707{
708 G4MTRunManager* mrm = G4MTRunManager::GetMasterRunManager();
711 if (nextAction == G4MTRunManager::WorkerActionRequest::NEXTITERATION) // start the next
712 // run
713 {
714 // The following code deals with changing materials between runs
715 static G4ThreadLocal G4bool skipInitialization = true;
716 if (skipInitialization) {
717 // re-initialization is not necessary for the first run
718 skipInitialization = false;
719 }
720 else {
721 // ReinitializeGeometry();
722 workerContext->UpdateGeometryAndPhysicsVectorFromMaster();
723 }
724
725 // Execute UI commands stored in the master UI manager
726 std::vector<G4String> cmds = mrm->GetCommandStack();
727 G4UImanager* uimgr = G4UImanager::GetUIpointer(); // TLS instance
728 for (const auto& cmd : cmds) {
729 uimgr->ApplyCommand(cmd);
730 }
731 // Start this run
732 G4int numevents = mrm->GetNumberOfEventsToBeProcessed();
733 G4String macroFile = mrm->GetSelectMacro();
734 G4int numSelect = mrm->GetNumberOfSelectEvents();
735 if (macroFile.empty() || macroFile == " ") {
736 this->BeamOn(numevents);
737 }
738 else {
739 this->BeamOn(numevents, macroFile, numSelect);
740 }
741 }
742 else if (nextAction == G4MTRunManager::WorkerActionRequest::PROCESSUI) {
743 std::vector<G4String> cmds = mrm->GetCommandStack();
744 G4UImanager* uimgr = G4UImanager::GetUIpointer(); // TLS instance
745 for (const auto& cmd : cmds) {
746 uimgr->ApplyCommand(cmd);
747 }
749 }
750 else {
752 d << "Cannot continue, this worker has been requested an unknown action: "
753 << static_cast<std::underlying_type<G4MTRunManager::WorkerActionRequest>::type>(nextAction);
754 G4Exception("G4WorkerRunManager::DoWork", "Run0104", FatalException, d);
755 }
756
757 // Now wait for master thread to signal new action to be performed
758 nextAction = mrm->ThisWorkerWaitForNextAction();
759 } // No more actions to perform
760
761 return;
762}
bool G4bool
Definition G4Types.hh:86
virtual WorkerActionRequest ThisWorkerWaitForNextAction()
virtual void ThisWorkerProcessCommandsStackDone()
static G4MTRunManager * GetMasterRunManager()
std::vector< G4String > GetCommandStack()
G4int GetNumberOfEventsToBeProcessed() const
virtual void BeamOn(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
const G4String & GetSelectMacro() const
G4int GetNumberOfSelectEvents() const
G4int ApplyCommand(const char *aCommand)
G4WorkerThread * workerContext
#define G4ThreadLocal
Definition tls.hh:77

Referenced by G4MTRunManagerKernel::StartThread().

◆ GenerateEvent()

G4Event * G4WorkerRunManager::GenerateEvent ( G4int i_event)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 305 of file G4WorkerRunManager.cc.

306{
307 auto anEvent = new G4Event(i_event);
308 G4long s1 = 0;
309 G4long s2 = 0;
310 G4long s3 = 0;
311 G4bool eventHasToBeSeeded = true;
313 eventHasToBeSeeded = false;
314 }
315
316 if (i_event < 0) {
318 if (nevM == 1) {
320 eventHasToBeSeeded);
321 runIsSeeded = true;
322 }
323 else {
324 if (nevModulo <= 0) {
326 eventHasToBeSeeded);
327 if (nevToDo == 0) {
328 eventLoopOnGoing = false;
329 }
330 else {
331 currEvID = anEvent->GetEventID();
332 nevModulo = nevToDo - 1;
333 }
334 }
335 else {
336 if (G4MTRunManager::SeedOncePerCommunication() > 0) eventHasToBeSeeded = false;
337 anEvent->SetEventID(++currEvID);
338 --nevModulo;
339 }
340 if (eventLoopOnGoing && eventHasToBeSeeded) {
341 s1 = seedsQueue.front();
342 seedsQueue.pop();
343 s2 = seedsQueue.front();
344 seedsQueue.pop();
345 }
346 }
347
348 if (!eventLoopOnGoing) {
349 delete anEvent;
350 return nullptr;
351 }
352 }
353 else if (eventHasToBeSeeded) {
354 // Need to reseed random number generator
356 s1 = helper->GetSeed(i_event * 2);
357 s2 = helper->GetSeed(i_event * 2 + 1);
358 }
359
360 if (eventHasToBeSeeded) {
361 G4long seeds[3] = {s1, s2, 0};
362 G4Random::setTheSeeds(seeds, luxury);
363 runIsSeeded = true;
364 }
365
366 // Read from file seed.
367 // Andrea Dotti 4 November 2015
368 // This is required for strong-reproducibility, in MT mode we have that each
369 // thread produces, for each event a status file, we want to do that.
370 // Search a random file with the format run{%d}evt{%d}.rndm
371
372 // This is the filename base constructed from run and event
373 const auto filename = [&] {
374 std::ostringstream os;
375 os << "run" << currentRun->GetRunID() << "evt" << anEvent->GetEventID();
376 return os.str();
377 };
378
379 G4bool RNGstatusReadFromFile = false;
380 if (readStatusFromFile) {
381 // Build full path of RNG status file for this event
382 std::ostringstream os;
383 os << filename() << ".rndm";
384 const G4String& randomStatusFile = os.str();
385 std::ifstream ifile(randomStatusFile.c_str());
386 if (ifile) { // File valid and readable
387 RNGstatusReadFromFile = true;
388 G4Random::restoreEngineStatus(randomStatusFile.c_str());
389 }
390 }
391
393 std::ostringstream oss;
394 G4Random::saveFullState(oss);
396 anEvent->SetRandomNumberStatus(randomNumberStatusForThisEvent);
397 }
398
399 if (storeRandomNumberStatus && !RNGstatusReadFromFile)
400 { // If reading from file, avoid to rewrite the same
401 G4String fileN = "currentEvent";
403 fileN = filename();
404 }
405 StoreRNGStatus(fileN);
406 }
407
408 if (printModulo > 0 && anEvent->GetEventID() % printModulo == 0) {
409 G4cout << "--> Event " << anEvent->GetEventID() << " starts";
410 if (eventHasToBeSeeded) {
411 G4cout << " with initial seeds (" << s1 << "," << s2 << ")";
412 }
413 G4cout << "." << G4endl;
414 }
415 userPrimaryGeneratorAction->GeneratePrimaries(anEvent);
416 return anEvent;
417}
G4TemplateRNGHelper< G4long > G4RNGHelper
long G4long
Definition G4Types.hh:87
static G4int SeedOncePerCommunication()
virtual G4int SetUpNEvents(G4Event *, G4SeedsQueue *seedsQueue, G4bool reseedRequired=true)
G4int GetEventModulo() const
virtual G4bool SetUpAnEvent(G4Event *, G4long &s1, G4long &s2, G4long &s3, G4bool reseedRequired=true)
G4int storeRandomNumberStatusToG4Event
G4Run * currentRun
G4bool rngStatusEventsFlag
G4String randomNumberStatusForThisEvent
G4bool storeRandomNumberStatus
static G4TemplateRNGHelper< G4long > * GetInstance()
virtual const T GetSeed(const G4int &sdId)
void StoreRNGStatus(const G4String &filenamePrefix) override

Referenced by ProcessOneEvent().

◆ GetWorkerRunManager()

G4WorkerRunManager * G4WorkerRunManager::GetWorkerRunManager ( )
static

◆ GetWorkerRunManagerKernel()

G4WorkerRunManagerKernel * G4WorkerRunManager::GetWorkerRunManagerKernel ( )
static

Definition at line 70 of file G4WorkerRunManager.cc.

71{
72 return static_cast<G4WorkerRunManagerKernel*>(GetWorkerRunManager()->kernel);
73}
static G4WorkerRunManager * GetWorkerRunManager()

◆ InitializeGeometry()

void G4WorkerRunManager::InitializeGeometry ( )
overridevirtual

Reimplemented from G4RunManager.

Definition at line 135 of file G4WorkerRunManager.cc.

136{
137 if (userDetector == nullptr) {
138 G4Exception("G4RunManager::InitializeGeometry", "Run0033", FatalException,
139 "G4VUserDetectorConstruction is not defined!");
140 return;
141 }
142
145 }
146
147 // Step 0: Contribute to the voxelisation of the geometry
148 G4GeometryManager* geomManager = G4GeometryManager::GetInstance();
149 if( geomManager->IsParallelOptimisationConfigured() ) {
150 G4cout << "G4RunManager::InitializeGeometry calling GeometryManager's UndertakeOptimisation"
151 << G4endl; // TODO - suppress / delete this in final version
152 geomManager->UndertakeOptimisation();
153 }
154 // A barrier must ensure that all that all threads have finished this work.
155 // Currently we rely on the (later) barrier at the end of initialisation.
156
157 // Step1: Get pointer to the physiWorld (note: needs to get the "super
158 // pointer, i.e. the one shared by all threads"
159 G4RunManagerKernel* masterKernel = G4MTRunManager::GetMasterRunManagerKernel();
160 G4VPhysicalVolume* worldVol = masterKernel->GetCurrentWorld();
161 // Step2:, Call a new "WorkerDefineWorldVolume( pointer from 2-, false);
162 kernel->WorkerDefineWorldVolume(worldVol, false);
163 kernel->SetNumberOfParallelWorld(masterKernel->GetNumberOfParallelWorld());
164 // Step3: Call user's ConstructSDandField()
165 userDetector->ConstructSDandField();
166 userDetector->ConstructParallelSD();
167 geometryInitialized = true;
168}
static G4GeometryManager * GetInstance()
G4bool IsParallelOptimisationConfigured()
static G4RunManagerKernel * GetMasterRunManagerKernel()
G4VPhysicalVolume * GetCurrentWorld() const
G4int GetNumberOfParallelWorld() const
G4bool geometryInitialized

◆ MergePartialResults()

void G4WorkerRunManager::MergePartialResults ( G4bool mergeEvents = true)
protectedvirtual

Definition at line 420 of file G4WorkerRunManager.cc.

421{
422 // Merge partial results into global run
423 G4MTRunManager* mtRM = G4MTRunManager::GetMasterRunManager();
424 G4ScoringManager* ScM = G4ScoringManager::GetScoringManagerIfExist();
425 if (ScM != nullptr) mtRM->MergeScores(ScM);
426#ifdef G4VERBOSE
427 if(mergeEvents && verboseLevel>3) {
428 auto eventVector = currentRun->GetEventVector();
429 if(eventVector!=nullptr || !(eventVector->empty())) {
430 G4cout<<"G4WorkerRunManager::MergePartialResults : merging "
431 <<eventVector->size()<<" events."<<G4endl;
432 }
433 }
434#endif
435 if(mergeEvents) mtRM->MergeRun(currentRun);
436}
virtual void MergeRun(const G4Run *localRun)
virtual void MergeScores(const G4ScoringManager *localScoringManager)

Referenced by RunTermination(), G4WorkerSubEvtRunManager::RunTermination(), and G4WorkerTaskRunManager::RunTermination().

◆ ProcessOneEvent()

void G4WorkerRunManager::ProcessOneEvent ( G4int i_event)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 292 of file G4WorkerRunManager.cc.

293{
294 currentEvent = GenerateEvent(i_event);
295 if (eventLoopOnGoing) {
296 eventManager->ProcessOneEvent(currentEvent);
299 if (currentEvent->GetEventID() < n_select_msg)
301 }
302}
G4String msgText
void UpdateScoring(const G4Event *evt=nullptr)
G4EventManager * eventManager
virtual void AnalyzeEvent(G4Event *anEvent)
G4Event * currentEvent
G4Event * GenerateEvent(G4int i_event) override

Referenced by DoEventLoop().

◆ RestoreRndmEachEvent()

void G4WorkerRunManager::RestoreRndmEachEvent ( G4bool flag)
inlineoverridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 85 of file G4WorkerRunManager.hh.

85{ readStatusFromFile = flag; }

◆ rndmSaveThisEvent()

void G4WorkerRunManager::rndmSaveThisEvent ( )
overrideprotectedvirtual

Reimplemented from G4RunManager.

Definition at line 672 of file G4WorkerRunManager.cc.

673{
674 if (currentEvent == nullptr) {
675 G4cerr << "Warning from G4RunManager::rndmSaveThisEvent():"
676 << " there is no currentEvent available." << G4endl << "Command ignored." << G4endl;
677 return;
678 }
679
681 G4cerr << "Warning from G4RunManager::rndmSaveThisEvent():"
682 << " Random number engine status is not available." << G4endl
683 << "/random/setSavingFlag command must be issued "
684 << "prior to the start of the run. Command ignored." << G4endl;
685 return;
686 }
687
688 std::ostringstream oos;
689 oos << "G4Worker" << workerContext->GetThreadId() << "_"
690 << "currentEvent.rndm"
691 << "\0";
692 G4fs::path fileIn = randomNumberStatusDir + oos.str();
693
694 std::ostringstream os;
695 os << "run" << currentRun->GetRunID() << "evt" << currentEvent->GetEventID() << ".rndm" << '\0';
696 G4fs::path fileOut = randomNumberStatusDir + os.str();
697
698 if (G4CopyRandomState(fileIn, fileOut, "G4WorkerRunManager::rndmSaveThisEvent()")
699 && verboseLevel > 0)
700 {
701 G4cout << fileIn << " is copied to " << fileOut << G4endl;
702 }
703}
G4bool G4CopyRandomState(const G4fs::path &source, const G4fs::path &dest, const G4String &callsite)
G4GLOB_DLL std::ostream G4cerr
G4String randomNumberStatusDir

◆ rndmSaveThisRun()

void G4WorkerRunManager::rndmSaveThisRun ( )
overrideprotectedvirtual

Reimplemented from G4RunManager.

Definition at line 642 of file G4WorkerRunManager.cc.

643{
644 G4int runNumber = 0;
645 if (currentRun != nullptr) runNumber = currentRun->GetRunID();
647 G4cerr << "Warning from G4RunManager::rndmSaveThisRun():"
648 << " Random number status was not stored prior to this run." << G4endl
649 << "/random/setSavingFlag command must be issued. "
650 << "Command ignored." << G4endl;
651 return;
652 }
653
654 std::ostringstream oos;
655 oos << "G4Worker" << workerContext->GetThreadId() << "_"
656 << "currentRun.rndm"
657 << "\0";
658 G4fs::path fileIn = randomNumberStatusDir + oos.str();
659
660 std::ostringstream os;
661 os << "run" << runNumber << ".rndm" << '\0';
662 G4fs::path fileOut = randomNumberStatusDir + os.str();
663
664 if (G4CopyRandomState(fileIn, fileOut, "G4WorkerRunManager::rndmSaveThisRun()")
665 && verboseLevel > 0)
666 {
667 G4cout << fileIn << " is copied to " << fileOut << G4endl;
668 }
669}

◆ RunInitialization()

void G4WorkerRunManager::RunInitialization ( )
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 171 of file G4WorkerRunManager.cc.

172{
173#ifdef G4MULTITHREADED
174 if (!visIsSetUp) {
175 G4VVisManager* pVVis = G4VVisManager::GetConcreteInstance();
176 if (pVVis != nullptr) {
177 pVVis->SetUpForAThread();
178 visIsSetUp = true;
179 }
180 }
181#endif
182
183 if (!(kernel->RunInitialization(fakeRun))) return;
184
185 // Signal this thread can start event loop.
186 // Note this will return only when all threads reach this point
188 if (fakeRun) return;
189
190 const G4UserWorkerInitialization* uwi =
193 delete currentRun;
194 currentRun = nullptr;
195
197 // Call a user hook: this is guaranteed all threads are "synchronized"
198 if (uwi != nullptr) uwi->WorkerRunStart();
199
200 if (userRunAction != nullptr) currentRun = userRunAction->GenerateRun();
201 if (currentRun == nullptr) currentRun = new G4Run();
202
203 currentRun->SetRunID(runIDCounter);
204 currentRun->SetNumberOfEventToBeProcessed(numberOfEventToBeProcessed);
205
206 currentRun->SetDCtable(DCtable);
207 G4SDManager* fSDM = G4SDManager::GetSDMpointerIfExist();
208 if (fSDM != nullptr) {
209 currentRun->SetHCtable(fSDM->GetHCtable());
210 }
211
212 if (G4VScoreNtupleWriter::Instance() != nullptr) {
213 auto hce = (fSDM != nullptr) ? fSDM->PrepareNewEvent() : nullptr;
215 delete hce;
216 }
217
218 std::ostringstream oss;
219 G4Random::saveFullState(oss);
221 currentRun->SetRandomNumberStatus(randomNumberStatusForThisRun);
222
223 for (G4int i_prev = 0; i_prev < n_perviousEventsToBeStored; ++i_prev) {
224 previousEvents->push_back(nullptr);
225 }
226
227 if (printModulo > 0 || verboseLevel > 0) {
228 G4cout << "### Run " << currentRun->GetRunID() << " starts on worker thread "
229 << G4Threading::G4GetThreadId() << "." << G4endl;
230 }
231 if (userRunAction != nullptr) userRunAction->BeginOfRunAction(currentRun);
232
235 }
236
238 G4String fileN = "currentRun";
240 std::ostringstream os;
241 os << "run" << currentRun->GetRunID();
242 fileN = os.str();
243 }
244 StoreRNGStatus(fileN);
245 }
246
247 runAborted = false;
249}
virtual void ThisWorkerReady()
static G4ParallelWorldProcessStore * GetInstance()
G4bool isScoreNtupleWriter
const G4UserWorkerInitialization * GetUserWorkerInitialization() const
std::list< G4Event * > * previousEvents
G4int numberOfEventProcessed
G4DCtable * DCtable
G4String randomNumberStatusForThisRun
G4UserRunAction * userRunAction
G4int numberOfEventToBeProcessed
G4int n_perviousEventsToBeStored
G4HCofThisEvent * PrepareNewEvent()
static G4SDManager * GetSDMpointerIfExist()
G4HCtable * GetHCtable() const
virtual G4bool Book(G4HCofThisEvent *hce)=0
static G4VScoreNtupleWriter * Instance()
virtual void OpenFile()=0
G4int G4GetThreadId()

◆ RunTermination()

void G4WorkerRunManager::RunTermination ( )
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 439 of file G4WorkerRunManager.cc.

440{
441 if (!fakeRun) {
443
444 // Call a user hook: note this is before the next barrier
445 // so threads execute this method asyncrhonouzly
446 //(TerminateRun allows for synch via G4RunAction::EndOfRun)
447 const G4UserWorkerInitialization* uwi =
449 if (uwi != nullptr) uwi->WorkerRunEnd();
450 }
451
453 // Signal this thread has finished envent-loop.
454 // Note this will return only whan all threads reach this point
456}
virtual void ThisWorkerEndEventLoop()
virtual void RunTermination()
virtual void MergePartialResults(G4bool mergeEvents=true)

◆ SetupDefaultRNGEngine()

void G4WorkerRunManager::SetupDefaultRNGEngine ( )
protectedvirtual

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 592 of file G4WorkerRunManager.cc.

593{
594 const CLHEP::HepRandomEngine* mrnge =
596 const G4UserWorkerThreadInitialization* uwti =
598 uwti->SetupRNGEngine(mrnge);
599}
const CLHEP::HepRandomEngine * getMasterRandomEngine() const
const G4UserWorkerThreadInitialization * GetUserWorkerThreadInitialization() const
virtual void SetupRNGEngine(const CLHEP::HepRandomEngine *aRNGEngine) const

◆ SetUserAction() [1/6]

void G4WorkerRunManager::SetUserAction ( G4UserEventAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 604 of file G4WorkerRunManager.cc.

605{
607}
virtual void SetUserAction(G4UserRunAction *userAction)

◆ SetUserAction() [2/6]

void G4WorkerRunManager::SetUserAction ( G4UserRunAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 585 of file G4WorkerRunManager.cc.

586{
587 G4RunManager::SetUserAction(userAction);
588 if (userAction != nullptr) userAction->SetMaster(false);
589}
virtual void SetMaster(G4bool val=true)

Referenced by G4RTWorkerInitialization::WorkerRunEnd(), and G4RTWorkerInitialization::WorkerRunStart().

◆ SetUserAction() [3/6]

void G4WorkerRunManager::SetUserAction ( G4UserStackingAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 616 of file G4WorkerRunManager.cc.

617{
619}

◆ SetUserAction() [4/6]

void G4WorkerRunManager::SetUserAction ( G4UserSteppingAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 628 of file G4WorkerRunManager.cc.

629{
631}

◆ SetUserAction() [5/6]

void G4WorkerRunManager::SetUserAction ( G4UserTrackingAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 622 of file G4WorkerRunManager.cc.

623{
625}

◆ SetUserAction() [6/6]

void G4WorkerRunManager::SetUserAction ( G4VUserPrimaryGeneratorAction * userAction)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 610 of file G4WorkerRunManager.cc.

611{
613}

◆ SetUserInitialization() [1/5]

void G4WorkerRunManager::SetUserInitialization ( G4UserWorkerInitialization * userInit)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 550 of file G4WorkerRunManager.cc.

551{
552 G4Exception("G4RunManager::SetUserInitialization(G4UserWorkerInitialization*)", "Run0118",
553 FatalException, "This method should be used only with an instance of G4MTRunManager");
554}

◆ SetUserInitialization() [2/5]

void G4WorkerRunManager::SetUserInitialization ( G4UserWorkerThreadInitialization * userInit)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 557 of file G4WorkerRunManager.cc.

558{
559 G4Exception("G4RunManager::SetUserInitialization(G4UserWorkerThreadInitialization*)", "Run0119",
560 FatalException, "This method should be used only with an instance of G4MTRunManager");
561}

◆ SetUserInitialization() [3/5]

void G4WorkerRunManager::SetUserInitialization ( G4VUserActionInitialization * userInit)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 564 of file G4WorkerRunManager.cc.

565{
566 G4Exception("G4RunManager::SetUserInitialization(G4VUserActionInitialization*)", "Run0120",
567 FatalException, "This method should be used only with an instance of G4MTRunManager");
568}

◆ SetUserInitialization() [4/5]

void G4WorkerRunManager::SetUserInitialization ( G4VUserDetectorConstruction * userInit)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 571 of file G4WorkerRunManager.cc.

572{
573 G4Exception("G4RunManager::SetUserInitialization(G4VUserDetectorConstruction*)", "Run0121",
574 FatalException, "This method should be used only with an instance of G4MTRunManager");
575}

◆ SetUserInitialization() [5/5]

void G4WorkerRunManager::SetUserInitialization ( G4VUserPhysicsList * userInit)
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 578 of file G4WorkerRunManager.cc.

579{
580 pl->InitializeWorker();
582}
virtual void SetUserInitialization(G4VUserDetectorConstruction *userInit)

Referenced by G4MTRunManagerKernel::StartThread().

◆ SetWorkerThread()

void G4WorkerRunManager::SetWorkerThread ( G4WorkerThread * wc)
inline

Definition at line 71 of file G4WorkerRunManager.hh.

71{ workerContext = wc; }

Referenced by G4MTRunManagerKernel::StartThread().

◆ StoreRNGStatus()

void G4WorkerRunManager::StoreRNGStatus ( const G4String & filenamePrefix)
overrideprotectedvirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 634 of file G4WorkerRunManager.cc.

635{
636 std::ostringstream os;
637 os << randomNumberStatusDir << "G4Worker" << workerContext->GetThreadId() << "_" << fn << ".rndm";
638 G4Random::saveEngineStatus(os.str().c_str());
639}

Referenced by GenerateEvent(), and RunInitialization().

◆ TerminateEventLoop()

void G4WorkerRunManager::TerminateEventLoop ( )
overridevirtual

Reimplemented from G4RunManager.

Reimplemented in G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 459 of file G4WorkerRunManager.cc.

460{
461 if (verboseLevel > 0 && !fakeRun) {
462 timer->Stop();
463 G4cout << "Thread-local run terminated." << G4endl;
464 G4cout << "Run Summary" << G4endl;
465 if (runAborted) {
466 G4cout << " Run Aborted after " << numberOfEventProcessed << " events processed." << G4endl;
467 }
468 else {
469 G4cout << " Number of events processed : " << numberOfEventProcessed << G4endl;
470 }
471 G4cout << " " << *timer << G4endl;
472 }
473}
G4Timer * timer

Referenced by DoEventLoop().

Member Data Documentation

◆ currEvID

◆ eventLoopOnGoing

◆ luxury

G4int G4WorkerRunManager::luxury = -1
protected

Definition at line 107 of file G4WorkerRunManager.hh.

Referenced by G4WorkerRunManager(), and GenerateEvent().

◆ nevModulo

◆ readStatusFromFile

◆ runIsSeeded

◆ seedsQueue

◆ workerContext


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