Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4WorkerRunManager.cc
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// G4WorkerRunManager implementation
27//
28// Original authors: X.Dong, A.Dotti - 2013
29// --------------------------------------------------------------------
30
31#include "G4WorkerRunManager.hh"
32
33#include "G4AutoLock.hh"
34#include "G4CopyRandomState.hh"
35#include "G4MTRunManager.hh"
38#include "G4RNGHelper.hh"
39#include "G4Run.hh"
40#include "G4SDManager.hh"
41#include "G4ScoringManager.hh"
42#include "G4Timer.hh"
44#include "G4UImanager.hh"
45#include "G4UserRunAction.hh"
49#include "G4VScoringMesh.hh"
52#include "G4VUserPhysicsList.hh"
54#include "G4VVisManager.hh"
56#include "G4WorkerThread.hh"
57
58#include "G4GeometryManager.hh" // For parallel geometry initialisation
59
60#include <fstream>
61#include <sstream>
62
63// --------------------------------------------------------------------
68
69// --------------------------------------------------------------------
74
75// --------------------------------------------------------------------
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
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
111 if (pVVis != nullptr) {
112 pVVis->SetUpForAThread();
113 visIsSetUp = true;
114 }
115#endif
116}
117
118// --------------------------------------------------------------------
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}
133
134// --------------------------------------------------------------------
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
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"
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}
169
170// --------------------------------------------------------------------
172{
173#ifdef G4MULTITHREADED
174 if (!visIsSetUp) {
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);
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}
250
251// --------------------------------------------------------------------
252void G4WorkerRunManager::DoEventLoop(G4int n_event, const char* macroFile, G4int n_select)
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}
290
291// --------------------------------------------------------------------
303
304// --------------------------------------------------------------------
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}
418
419// --------------------------------------------------------------------
421{
422 // Merge partial results into global run
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}
437
438// --------------------------------------------------------------------
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}
457
458// --------------------------------------------------------------------
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}
474
475// --------------------------------------------------------------------
476namespace
477{
478G4Mutex ConstructScoringWorldsMutex = G4MUTEX_INITIALIZER;
479}
480
481// --------------------------------------------------------------------
483{
484 using MeshShape = G4VScoringMesh::MeshShape;
485
486 // Return if unnecessary
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
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}
548
549// --------------------------------------------------------------------
551{
552 G4Exception("G4RunManager::SetUserInitialization(G4UserWorkerInitialization*)", "Run0118",
553 FatalException, "This method should be used only with an instance of G4MTRunManager");
554}
555
556// --------------------------------------------------------------------
558{
559 G4Exception("G4RunManager::SetUserInitialization(G4UserWorkerThreadInitialization*)", "Run0119",
560 FatalException, "This method should be used only with an instance of G4MTRunManager");
561}
562
563// --------------------------------------------------------------------
565{
566 G4Exception("G4RunManager::SetUserInitialization(G4VUserActionInitialization*)", "Run0120",
567 FatalException, "This method should be used only with an instance of G4MTRunManager");
568}
569
570// --------------------------------------------------------------------
572{
573 G4Exception("G4RunManager::SetUserInitialization(G4VUserDetectorConstruction*)", "Run0121",
574 FatalException, "This method should be used only with an instance of G4MTRunManager");
575}
576
577// --------------------------------------------------------------------
583
584// --------------------------------------------------------------------
586{
587 G4RunManager::SetUserAction(userAction);
588 if (userAction != nullptr) userAction->SetMaster(false);
589}
590
591// --------------------------------------------------------------------
600
601// Forward calls (avoid GCC compilation warnings)
602
603// --------------------------------------------------------------------
608
609// --------------------------------------------------------------------
614
615// --------------------------------------------------------------------
620
621// --------------------------------------------------------------------
626
627// --------------------------------------------------------------------
632
633// --------------------------------------------------------------------
635{
636 std::ostringstream os;
637 os << randomNumberStatusDir << "G4Worker" << workerContext->GetThreadId() << "_" << fn << ".rndm";
638 G4Random::saveEngineStatus(os.str().c_str());
639}
640
641// --------------------------------------------------------------------
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}
670
671// --------------------------------------------------------------------
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}
704
705// --------------------------------------------------------------------
707{
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}
G4TemplateAutoLock< G4Mutex > G4AutoLock
std::vector< G4InuclElementaryParticle >::iterator particleIterator
Helper function for copying random state files in G4run.
G4bool G4CopyRandomState(const G4fs::path &source, const G4fs::path &dest, const G4String &callsite)
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
@ idxPostStep
@ idxAtRest
@ idxAlongStep
G4TemplateRNGHelper< G4long > G4RNGHelper
#define G4MUTEX_INITIALIZER
std::mutex G4Mutex
long G4long
Definition G4Types.hh:87
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
static G4GeometryManager * GetInstance()
G4bool IsParallelOptimisationConfigured()
static G4int SeedOncePerCommunication()
virtual WorkerActionRequest ThisWorkerWaitForNextAction()
virtual void ThisWorkerProcessCommandsStackDone()
virtual G4int SetUpNEvents(G4Event *, G4SeedsQueue *seedsQueue, G4bool reseedRequired=true)
const CLHEP::HepRandomEngine * getMasterRandomEngine() const
static G4ScoringManager * GetMasterScoringManager()
virtual void ThisWorkerReady()
G4int GetEventModulo() const
static G4MTRunManager * GetMasterRunManager()
virtual void MergeRun(const G4Run *localRun)
static G4RunManagerKernel * GetMasterRunManagerKernel()
virtual void MergeScores(const G4ScoringManager *localScoringManager)
std::vector< G4String > GetCommandStack()
virtual G4bool SetUpAnEvent(G4Event *, G4long &s1, G4long &s2, G4long &s3, G4bool reseedRequired=true)
virtual void ThisWorkerEndEventLoop()
static G4ParallelWorldProcessStore * GetInstance()
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)
G4VPhysicalVolume * GetCurrentWorld() const
G4int GetNumberOfParallelWorld() const
G4bool isScoreNtupleWriter
G4bool geometryInitialized
virtual void CleanUpPreviousEvents()
G4int storeRandomNumberStatusToG4Event
G4UserWorkerInitialization * userWorkerInitialization
const G4UserWorkerInitialization * GetUserWorkerInitialization() const
std::list< G4Event * > * previousEvents
G4Timer * timer
G4UserWorkerThreadInitialization * userWorkerThreadInitialization
G4int numberOfEventProcessed
G4int GetNumberOfEventsToBeProcessed() const
virtual void InitializeEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
G4RunManagerKernel * kernel
G4Run * currentRun
static G4RunManager * GetRunManager()
G4DCtable * DCtable
G4String randomNumberStatusForThisRun
G4String msgText
virtual void BeamOn(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
G4UserRunAction * userRunAction
G4bool rngStatusEventsFlag
virtual void RunTermination()
const G4String & GetSelectMacro() const
G4VUserActionInitialization * userActionInitialization
static G4RUN_DLL G4bool fGeometryHasBeenDestroyed
G4VUserDetectorConstruction * userDetector
G4VUserPrimaryGeneratorAction * userPrimaryGeneratorAction
void UpdateScoring(const G4Event *evt=nullptr)
G4int numberOfEventToBeProcessed
G4String randomNumberStatusDir
virtual void SetUserAction(G4UserRunAction *userAction)
G4String randomNumberStatusForThisEvent
const G4UserWorkerThreadInitialization * GetUserWorkerThreadInitialization() const
G4int n_perviousEventsToBeStored
virtual void SetUserInitialization(G4VUserDetectorConstruction *userInit)
G4bool storeRandomNumberStatus
G4EventManager * eventManager
virtual void TerminateOneEvent()
G4int GetNumberOfSelectEvents() const
G4VUserPhysicsList * physicsList
virtual void AnalyzeEvent(G4Event *anEvent)
G4Event * currentEvent
Definition G4Run.hh:48
G4HCofThisEvent * PrepareNewEvent()
static G4SDManager * GetSDMpointerIfExist()
G4HCtable * GetHCtable() const
G4VScoringMesh * GetMesh(G4int i) const
static G4ScoringManager * GetScoringManager()
const G4String & GetWorldName(G4int i) const
std::size_t GetNumberOfMesh() const
static G4ScoringManager * GetScoringManagerIfExist()
static G4TemplateRNGHelper< G4long > * GetInstance()
virtual const T GetSeed(const G4int &sdId)
static G4TransportationManager * GetTransportationManager()
G4VPhysicalVolume * IsWorldExisting(const G4String &worldName)
void SetIgnoreCmdNotFound(G4bool val)
G4int ApplyCommand(const char *aCommand)
static G4UImanager * GetUIpointer()
virtual void SetMaster(G4bool val=true)
virtual void SetupRNGEngine(const CLHEP::HepRandomEngine *aRNGEngine) const
virtual G4bool Book(G4HCofThisEvent *hce)=0
static G4VScoreNtupleWriter * Instance()
virtual void OpenFile()=0
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()
virtual void InitializeWorker()
static G4VVisManager * GetConcreteInstance()
virtual void SetUpForAThread()
static G4WorkerRunManagerKernel * GetWorkerRunManagerKernel()
void InitializeGeometry() override
void rndmSaveThisRun() override
virtual void SetupDefaultRNGEngine()
void RunTermination() override
void SetUserAction(G4UserRunAction *userAction) override
G4Event * GenerateEvent(G4int i_event) override
virtual void MergePartialResults(G4bool mergeEvents=true)
G4WorkerThread * workerContext
void rndmSaveThisEvent() override
void TerminateEventLoop() override
void RunInitialization() override
void SetUserInitialization(G4VUserPhysicsList *userInit) override
void ProcessOneEvent(G4int i_event) override
static G4WorkerRunManager * GetWorkerRunManager()
void ConstructScoringWorlds() override
void DoEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1) override
void StoreRNGStatus(const G4String &filenamePrefix) override
G4int G4GetThreadId()
#define G4ThreadLocal
Definition tls.hh:77