80#ifndef G4MULTITHREADED
82 msg <<
"Geant4 code is compiled without multi-threading support "
85 msg <<
" This type of RunManager can only be used in mult-threaded "
100 luxury = theEngine->getLuxury();
104 luxury = theEngine->getLuxury();
109#ifdef G4MULTITHREADED
111 if (pVVis !=
nullptr) {
139 "G4VUserDetectorConstruction is not defined!");
150 G4cout <<
"G4RunManager::InitializeGeometry calling GeometryManager's UndertakeOptimisation"
162 kernel->WorkerDefineWorldVolume(worldVol,
false);
173#ifdef G4MULTITHREADED
176 if (pVVis !=
nullptr) {
208 if (fSDM !=
nullptr) {
218 std::ostringstream oss;
219 G4Random::saveFullState(oss);
228 G4cout <<
"### Run " <<
currentRun->GetRunID() <<
" starts on worker thread "
240 std::ostringstream os;
256 "G4VUserPrimaryGeneratorAction is not defined!");
307 auto anEvent =
new G4Event(i_event);
311 G4bool eventHasToBeSeeded =
true;
313 eventHasToBeSeeded =
false;
353 else if (eventHasToBeSeeded) {
356 s1 = helper->
GetSeed(i_event * 2);
357 s2 = helper->
GetSeed(i_event * 2 + 1);
360 if (eventHasToBeSeeded) {
361 G4long seeds[3] = {s1, s2, 0};
362 G4Random::setTheSeeds(seeds,
luxury);
373 const auto filename = [&] {
374 std::ostringstream os;
375 os <<
"run" <<
currentRun->GetRunID() <<
"evt" << anEvent->GetEventID();
379 G4bool RNGstatusReadFromFile =
false;
382 std::ostringstream os;
383 os << filename() <<
".rndm";
384 const G4String& randomStatusFile = os.str();
385 std::ifstream ifile(randomStatusFile.c_str());
387 RNGstatusReadFromFile =
true;
388 G4Random::restoreEngineStatus(randomStatusFile.c_str());
393 std::ostringstream oss;
394 G4Random::saveFullState(oss);
409 G4cout <<
"--> Event " << anEvent->GetEventID() <<
" starts";
410 if (eventHasToBeSeeded) {
411 G4cout <<
" with initial seeds (" << s1 <<
"," << s2 <<
")";
428 auto eventVector =
currentRun->GetEventVector();
429 if(eventVector!=
nullptr || !(eventVector->empty())) {
430 G4cout<<
"G4WorkerRunManager::MergePartialResults : merging "
431 <<eventVector->size()<<
" events."<<
G4endl;
488 if (ScM ==
nullptr)
return;
490 if (nPar < 1)
return;
493 kernel->WorkerUpdateWorldVolume();
499 for (
G4int iw = 0; iw < nPar; ++iw) {
503 if (mesh->
GetShape() != MeshShape::realWorldLogVol) {
506 if (pWorld ==
nullptr) {
508 ed <<
"Mesh name <" << ScM->
GetWorldName(iw) <<
"> is not found in the master thread.";
518 if (mesh->
GetShape() != MeshShape::realWorldLogVol) {
520 if (theParallelWorldProcess !=
nullptr) {
532 if (pmanager !=
nullptr) {
533 pmanager->
AddProcess(theParallelWorldProcess);
552 G4Exception(
"G4RunManager::SetUserInitialization(G4UserWorkerInitialization*)",
"Run0118",
553 FatalException,
"This method should be used only with an instance of G4MTRunManager");
559 G4Exception(
"G4RunManager::SetUserInitialization(G4UserWorkerThreadInitialization*)",
"Run0119",
560 FatalException,
"This method should be used only with an instance of G4MTRunManager");
566 G4Exception(
"G4RunManager::SetUserInitialization(G4VUserActionInitialization*)",
"Run0120",
567 FatalException,
"This method should be used only with an instance of G4MTRunManager");
573 G4Exception(
"G4RunManager::SetUserInitialization(G4VUserDetectorConstruction*)",
"Run0121",
574 FatalException,
"This method should be used only with an instance of G4MTRunManager");
588 if (userAction !=
nullptr) userAction->
SetMaster(
false);
636 std::ostringstream os;
638 G4Random::saveEngineStatus(os.str().c_str());
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;
654 std::ostringstream oos;
660 std::ostringstream os;
661 os <<
"run" << runNumber <<
".rndm" <<
'\0';
667 G4cout << fileIn <<
" is copied to " << fileOut <<
G4endl;
675 G4cerr <<
"Warning from G4RunManager::rndmSaveThisEvent():"
676 <<
" there is no currentEvent available." <<
G4endl <<
"Command ignored." <<
G4endl;
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;
688 std::ostringstream oos;
690 <<
"currentEvent.rndm"
694 std::ostringstream os;
698 if (
G4CopyRandomState(fileIn, fileOut,
"G4WorkerRunManager::rndmSaveThisEvent()")
701 G4cout << fileIn <<
" is copied to " << fileOut <<
G4endl;
716 if (skipInitialization) {
718 skipInitialization =
false;
728 for (
const auto& cmd : cmds) {
735 if (macroFile.empty() || macroFile ==
" ") {
739 this->
BeamOn(numevents, macroFile, numSelect);
745 for (
const auto& cmd : cmds) {
752 d <<
"Cannot continue, this worker has been requested an unknown action: "
753 <<
static_cast<std::underlying_type<G4MTRunManager::WorkerActionRequest>::type
>(nextAction);
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)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
G4TemplateRNGHelper< G4long > G4RNGHelper
#define G4MUTEX_INITIALIZER
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
static G4GeometryManager * GetInstance()
G4bool IsParallelOptimisationConfigured()
void UndertakeOptimisation()
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
G4UserWorkerThreadInitialization * userWorkerThreadInitialization
G4int numberOfEventProcessed
G4int GetNumberOfEventsToBeProcessed() const
virtual void InitializeEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
G4RunManagerKernel * kernel
static G4RunManager * GetRunManager()
G4String randomNumberStatusForThisRun
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)
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 ClearParallelWorlds()
void SetIgnoreCmdNotFound(G4bool val)
G4int ApplyCommand(const char *aCommand)
static G4UImanager * GetUIpointer()
virtual void SetMaster(G4bool val=true)
virtual void WorkerRunEnd() const
virtual void WorkerRunStart() const
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)
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)
G4bool readStatusFromFile
G4WorkerThread * workerContext
void rndmSaveThisEvent() override
void TerminateEventLoop() override
~G4WorkerRunManager() 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