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

#include <G4WorkerSubEvtRunManager.hh>

+ Inheritance diagram for G4WorkerSubEvtRunManager:

Public Member Functions

 G4WorkerSubEvtRunManager (G4int subEventType=0)
 
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
 
void DoWork () override
 
void RestoreRndmEachEvent (G4bool flag) override
 
void DoCleanup () override
 
void ProcessUI () override
 
void SetUserInitialization (G4VUserPhysicsList *userPL) override
 
void SetUserInitialization (G4VUserDetectorConstruction *userDC) override
 
void SetUserInitialization (G4UserWorkerInitialization *userInit) override
 
void SetUserInitialization (G4UserWorkerThreadInitialization *userInit) override
 
void SetUserInitialization (G4VUserActionInitialization *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
 
G4int GetSubEventType () const override
 
void SetSubEventType (G4int) override
 
- Public Member Functions inherited from G4WorkerTaskRunManager
 G4WorkerTaskRunManager ()=default
 
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
 
void DoWork () override
 
void RestoreRndmEachEvent (G4bool flag) override
 
G4WorkerThreadGetWorkerThread () const
 
G4StrVector GetCommandStack () const
 
- Public Member Functions inherited from G4WorkerRunManager
 G4WorkerRunManager ()
 
 ~G4WorkerRunManager () override
 
void InitializeGeometry () override
 
void SetWorkerThread (G4WorkerThread *wc)
 
- 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 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 G4WorkerSubEvtRunManagerGetWorkerRunManager ()
 
static G4WorkerSubEvtRunManagerKernelGetWorkerRunManagerKernel ()
 
- Static Public Member Functions inherited from G4WorkerTaskRunManager
static G4WorkerTaskRunManagerGetWorkerRunManager ()
 
static G4WorkerTaskRunManagerKernelGetWorkerRunManagerKernel ()
 
- Static Public Member Functions inherited from G4WorkerRunManager
static G4WorkerRunManagerGetWorkerRunManager ()
 
static G4WorkerRunManagerKernelGetWorkerRunManagerKernel ()
 
- Static Public Member Functions inherited from G4RunManager
static G4RunManagerGetRunManager ()
 
static G4bool IfGeometryHasBeenDestroyed ()
 

Protected Member Functions

void StoreRNGStatus (const G4String &filenamePrefix) override
 
void SetupDefaultRNGEngine () override
 
- Protected Member Functions inherited from G4WorkerTaskRunManager
void StoreRNGStatus (const G4String &filenamePrefix) override
 
void SetupDefaultRNGEngine () override
 
- Protected Member Functions inherited from G4WorkerRunManager
void ConstructScoringWorlds () override
 
void rndmSaveThisRun () override
 
void rndmSaveThisEvent () override
 
virtual void MergePartialResults (G4bool mergeEvents=true)
 
- 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 ()
 

Additional Inherited Members

- Public Types inherited from G4WorkerTaskRunManager
using G4StrVector = std::vector<G4String>
 
- Public Types inherited from G4RunManager
enum  RMType {
  sequentialRM , masterRM , workerRM , subEventMasterRM ,
  subEventWorkerRM
}
 
- Protected Attributes inherited from G4WorkerTaskRunManager
G4StrVector processedCommandStack
 
- Protected Attributes inherited from G4WorkerRunManager
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
 
- Static Protected Attributes inherited from G4RunManager
static G4RUN_DLL G4bool fGeometryHasBeenDestroyed = false
 

Detailed Description

Definition at line 51 of file G4WorkerSubEvtRunManager.hh.

Constructor & Destructor Documentation

◆ G4WorkerSubEvtRunManager()

G4WorkerSubEvtRunManager::G4WorkerSubEvtRunManager ( G4int subEventType = 0)

Definition at line 74 of file G4WorkerSubEvtRunManager.cc.

Referenced by GetWorkerRunManager().

Member Function Documentation

◆ DoCleanup()

void G4WorkerSubEvtRunManager::DoCleanup ( )
overridevirtual

Reimplemented from G4WorkerTaskRunManager.

Definition at line 433 of file G4WorkerSubEvtRunManager.cc.

434{
435 // Nothing to do for a run
436
437 //CleanUpPreviousEvents();
438 //
439 //delete currentRun;
440 //currentRun = nullptr;
441}

◆ DoEventLoop()

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

Reimplemented from G4WorkerRunManager.

Definition at line 170 of file G4WorkerSubEvtRunManager.cc.

171{
172//MAMAMAMA
173G4Exception("G4WorkerSubEvtRunManager::DoEventLoop()","SuvEvtXXX001",FatalException,"We should not be here!");
174//MAMAMAMA
175 if (userPrimaryGeneratorAction == nullptr) {
176 G4Exception("G4RunManager::GenerateEvent()", "Run0032", FatalException,
177 "G4VUserPrimaryGeneratorAction is not defined!");
178 }
179
180 // This is the same as in the sequential case, just the for-loop indexes are
181 // different
182 InitializeEventLoop(n_event, macroFile, n_select);
183
184 // Reset random number seeds queue
185 while (!seedsQueue.empty())
186 seedsQueue.pop();
187 // for each run, worker should receive at least one set of random number
188 // seeds.
189 // runIsSeeded = false;
190
191 // Event loop
192 eventLoopOnGoing = true;
193 G4int i_event = -1;
194 nevModulo = -1;
195 currEvID = -1;
196
197 for (G4int evt = 0; evt < n_event; ++evt) {
198 ProcessOneEvent(i_event);
199 if (eventLoopOnGoing) {
201 if (runAborted) eventLoopOnGoing = false;
202 }
203 if (!eventLoopOnGoing) break;
204 }
205}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
int G4int
Definition G4Types.hh:85
virtual void InitializeEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
G4VUserPrimaryGeneratorAction * userPrimaryGeneratorAction
virtual void TerminateOneEvent()
void ProcessOneEvent(G4int i_event) override

◆ DoWork()

void G4WorkerSubEvtRunManager::DoWork ( )
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 445 of file G4WorkerSubEvtRunManager.cc.

446{
447 if(verboseLevel>1) {
448 G4cout << "G4WorkerSubEvtRunManager::DoWork() starts.........." << G4endl;
449 }
450
451 //G4TaskRunManager* mrm = G4TaskRunManager::GetMasterRunManager();
452 G4SubEvtRunManager* mrm = G4SubEvtRunManager::GetMasterRunManager();
453 G4bool newRun = false;
454 const G4Run* run = mrm->GetCurrentRun();
455 G4ThreadLocalStatic G4int runId = -1;
456 if ((run != nullptr) && run->GetRunID() != runId) {
457 runId = run->GetRunID();
458 newRun = true;
459 if (runId > 0) { ProcessUI(); }
460 }
461
462 G4bool reseedRequired = false;
463 if (newRun) {
465 if (cond) {
468 }
469 reseedRequired = true;
470 }
471
472 assert(workerContext != nullptr);
473 workerContext->UpdateGeometryAndPhysicsVectorFromMaster();
474
475 eventManager->UseSubEventParallelism(true);
476
477 G4bool needMoreWork = true;
478 while(needMoreWork)
479 {
480 G4bool notReady = false;
481 G4long s1, s2, s3;
482 auto subEv = mrm->GetSubEvent(fSubEventType, notReady, s1, s2, s3, reseedRequired);
483 if(subEv==nullptr && notReady)
484 {
485 // Master is not yet ready for tasking a sub-event.
486 // Wait 1 second and retry.
487 G4THREADSLEEP(1);
488 }
489 else if(subEv==nullptr)
490 {
491 // No more sub-event to process
492 needMoreWork = false;
493 }
494 else
495 {
496 // Let's work for this sub-event.
497 if(reseedRequired)
498 {
499 G4long seeds[3] = {s1, s2, s3};
500 G4Random::setTheSeeds(seeds, -1);
501 reseedRequired = false;
502 }
503
504 // create a G4Event object for this sub-event. This G4Event object will contain output
505 // to be merged into the master event.
506 auto masterEvent = subEv->GetEvent();
507 G4Event* ev = new G4Event(masterEvent->GetEventID());
508 ev->FlagAsSubEvent(masterEvent,fSubEventType);
510
511 // Create a G4TrackVector as the input
512 G4TrackVector* tv = new G4TrackVector();
513 for(auto& stackedTrack : *subEv)
514 {
515 // tracks (and trajectories) stored in G4SubEvent object belong to the master thread
516 // and thus they must not be deleted by the worker thread. They must be cloned.
517 G4Track* tr = new G4Track();
518 tr->CopyTrackInfo(*(stackedTrack.GetTrack()),false);
519 tv->push_back(tr);
520 }
521
522 // Process this sub-event
523 currentEvent = ev;
524 eventManager->ProcessOneEvent(tv,ev);
525
526 // We don't need following two lines, as they are taken care by the master
527 //////AnalyzeEvent(ev);
528 //////UpdateScoring();
529
530 // Report the results to the master
531 mrm->SubEventFinished(subEv,ev);
532
533 // clean up
534 delete tv;
535 delete ev;
536 }
537 }
538
539 if(verboseLevel>1) {
540 G4cout << "G4WorkerSubEvtRunManager::DoWork() completed.........." << G4endl;
541 }
542
543}
#define G4THREADSLEEP(tick)
std::vector< G4Track * > G4TrackVector
long G4long
Definition G4Types.hh:87
bool G4bool
Definition G4Types.hh:86
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
void FlagAsSubEvent(G4Event *me, G4int ty)
Definition G4Event.hh:287
G4int numberOfEventProcessed
virtual G4bool ConfirmBeamOnCondition()
const G4Run * GetCurrentRun() const
G4EventManager * eventManager
G4Event * currentEvent
G4int GetRunID() const
Definition G4Run.hh:82
void SubEventFinished(const G4SubEvent *se, const G4Event *evt) override
static G4SubEvtRunManager * GetMasterRunManager()
const G4SubEvent * GetSubEvent(G4int ty, G4bool &notReady, G4long &s1, G4long &s2, G4long &s3, G4bool reseedRequired=true) override
void CopyTrackInfo(const G4Track &, G4bool copyTouchables=true)
Definition G4Track.cc:158
G4WorkerThread * workerContext
void ConstructScoringWorlds() override
#define G4ThreadLocalStatic
Definition tls.hh:76

◆ GenerateEvent()

G4Event * G4WorkerSubEvtRunManager::GenerateEvent ( G4int i_event)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 229 of file G4WorkerSubEvtRunManager.cc.

230{
231//MAMAMAMA
232G4Exception("G4WorkerSubEvtRunManager::GenerateEvent()","SuvEvtXXX003",FatalException,"We should not be here!");
233//MAMAMAMA
234 auto anEvent = new G4Event(i_event);
235 G4long s1 = 0;
236 G4long s2 = 0;
237 G4long s3 = 0;
238 G4bool eventHasToBeSeeded = true;
239 if (G4MTRunManager::SeedOncePerCommunication() == 1 && runIsSeeded) eventHasToBeSeeded = false;
240
241 if (i_event < 0) {
243 if (nevM == 1) {
245 eventHasToBeSeeded);
246 runIsSeeded = true;
247 }
248 else {
249 if (nevModulo <= 0) {
251 eventHasToBeSeeded);
252 if (nevToDo == 0)
253 eventLoopOnGoing = false;
254 else {
255 currEvID = anEvent->GetEventID();
256 nevModulo = nevToDo - 1;
257 }
258 }
259 else {
260 if (G4MTRunManager::SeedOncePerCommunication() > 0) eventHasToBeSeeded = false;
261 anEvent->SetEventID(++currEvID);
262 nevModulo--;
263 }
264 if (eventLoopOnGoing && eventHasToBeSeeded) {
265 s1 = seedsQueue.front();
266 seedsQueue.pop();
267 s2 = seedsQueue.front();
268 seedsQueue.pop();
269 }
270 }
271
272 if (!eventLoopOnGoing) {
273 delete anEvent;
274 return nullptr;
275 }
276 }
277 else if (eventHasToBeSeeded) {
278 // Need to reseed random number generator
280 s1 = helper->GetSeed(i_event * 2);
281 s2 = helper->GetSeed(i_event * 2 + 1);
282 }
283
284 if (eventHasToBeSeeded) {
285 G4long seeds[3] = {s1, s2, 0};
286 G4Random::setTheSeeds(seeds, -1);
287 runIsSeeded = true;
288 }
289
290 // Read from file seed.
291 // Andrea Dotti 4 November 2015
292 // This is required for strong-reproducibility, in MT mode we have that each
293 // thread produces, for each event a status file, we want to do that.
294 // Search a random file with the format run{%d}evt{%d}.rndm
295
296 // This is the filename base constructed from run and event
297 const auto filename = [&] {
298 std::ostringstream os;
299 os << "run" << currentRun->GetRunID() << "evt" << anEvent->GetEventID();
300 return os.str();
301 };
302
303 G4bool RNGstatusReadFromFile = false;
304 if (readStatusFromFile) {
305 // Build full path of RNG status file for this event
306 std::ostringstream os;
307 os << filename() << ".rndm";
308 const G4String& randomStatusFile = os.str();
309 std::ifstream ifile(randomStatusFile.c_str());
310 if (ifile) {
311 // File valid and readable
312 RNGstatusReadFromFile = true;
313 G4Random::restoreEngineStatus(randomStatusFile.c_str());
314 }
315 }
316
318 std::ostringstream oss;
319 G4Random::saveFullState(oss);
321 anEvent->SetRandomNumberStatus(randomNumberStatusForThisEvent);
322 }
323
324 if (storeRandomNumberStatus && !RNGstatusReadFromFile) {
325 // If reading from file, avoid to rewrite the same
326 G4String fileN = "currentEvent";
327 if (rngStatusEventsFlag) fileN = filename();
328 StoreRNGStatus(fileN);
329 }
330
331 if (printModulo > 0 && anEvent->GetEventID() % printModulo == 0) {
332 G4cout << "--> Event " << anEvent->GetEventID() << " starts";
333 if (eventHasToBeSeeded) G4cout << " with initial seeds (" << s1 << "," << s2 << ")";
334 G4cout << "." << G4endl;
335 }
336 userPrimaryGeneratorAction->GeneratePrimaries(anEvent);
337 return anEvent;
338}
G4TemplateRNGHelper< G4long > G4RNGHelper
static G4int SeedOncePerCommunication()
virtual G4int SetUpNEvents(G4Event *, G4SeedsQueue *seedsQueue, G4bool reseedRequired=true)
G4int GetEventModulo() const
static G4MTRunManager * GetMasterRunManager()
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().

◆ GetSubEventType()

G4int G4WorkerSubEvtRunManager::GetSubEventType ( ) const
inlineoverridevirtual

Reimplemented from G4RunManager.

Definition at line 92 of file G4WorkerSubEvtRunManager.hh.

93 { return fSubEventType; }

◆ GetWorkerRunManager()

G4WorkerSubEvtRunManager * G4WorkerSubEvtRunManager::GetWorkerRunManager ( )
static

Definition at line 60 of file G4WorkerSubEvtRunManager.cc.

61{
63}
static G4RunManager * GetRunManager()
G4WorkerSubEvtRunManager(G4int subEventType=0)

Referenced by GetWorkerRunManagerKernel().

◆ GetWorkerRunManagerKernel()

G4WorkerSubEvtRunManagerKernel * G4WorkerSubEvtRunManager::GetWorkerRunManagerKernel ( )
static

Definition at line 67 of file G4WorkerSubEvtRunManager.cc.

68{
70}
G4WorkerTaskRunManagerKernel G4WorkerSubEvtRunManagerKernel
G4RunManagerKernel * kernel
static G4WorkerSubEvtRunManager * GetWorkerRunManager()

◆ ProcessOneEvent()

void G4WorkerSubEvtRunManager::ProcessOneEvent ( G4int i_event)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 209 of file G4WorkerSubEvtRunManager.cc.

210{
211//MAMAMAMA
212G4Exception("G4WorkerSubEvtRunManager::ProcessOneEvent()","SuvEvtXXX002",FatalException,"We should not be here!");
213//MAMAMAMA
214 currentEvent = GenerateEvent(i_event);
215 if (eventLoopOnGoing) {
216 eventManager->ProcessOneEvent(currentEvent);
219 if (currentEvent->GetEventID() < n_select_msg) {
220 G4cout << "Applying command \"" << msgText << "\" @ " << __FUNCTION__ << ":" << __LINE__
221 << G4endl;
223 }
224 }
225}
G4String msgText
void UpdateScoring(const G4Event *evt=nullptr)
virtual void AnalyzeEvent(G4Event *anEvent)
G4int ApplyCommand(const char *aCommand)
static G4UImanager * GetUIpointer()
G4Event * GenerateEvent(G4int i_event) override

Referenced by DoEventLoop().

◆ ProcessUI()

void G4WorkerSubEvtRunManager::ProcessUI ( )
overridevirtual

Reimplemented from G4WorkerTaskRunManager.

Definition at line 405 of file G4WorkerSubEvtRunManager.cc.

406{
407 G4TaskRunManager* mrm = G4TaskRunManager::GetMasterRunManager();
408 if (mrm == nullptr) return;
409
410 //------------------------------------------------------------------------//
411 // Check UI commands not already processed
412 auto command_stack = mrm->GetCommandStack();
413 bool matching = (command_stack.size() == processedCommandStack.size());
414 if (matching) {
415 for (uintmax_t i = 0; i < command_stack.size(); ++i)
416 if (processedCommandStack.at(i) != command_stack.at(i)) {
417 matching = false;
418 break;
419 }
420 }
421
422 //------------------------------------------------------------------------//
423 // Execute UI commands stored in the master UI manager
424 if (!matching) {
425 for (const auto& itr : command_stack)
427 processedCommandStack = std::move(command_stack);
428 }
429}
std::vector< G4String > GetCommandStack()
static G4TaskRunManager * GetMasterRunManager()

Referenced by DoWork().

◆ RestoreRndmEachEvent()

void G4WorkerSubEvtRunManager::RestoreRndmEachEvent ( G4bool flag)
inlineoverridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 67 of file G4WorkerSubEvtRunManager.hh.

67{ readStatusFromFile = flag; }

◆ RunInitialization()

void G4WorkerSubEvtRunManager::RunInitialization ( )
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 80 of file G4WorkerSubEvtRunManager.cc.

81{
82#ifdef G4MULTITHREADED
83 if (!visIsSetUp) {
84 G4VVisManager* pVVis = G4VVisManager::GetConcreteInstance();
85 if (pVVis != nullptr) {
86 pVVis->SetUpForAThread();
87 visIsSetUp = true;
88 }
89 }
90#endif
91 runIsSeeded = false;
92
93 if (!(kernel->RunInitialization(fakeRun))) return;
94
95 // Signal this thread can start event loop.
96 // Note this will return only when all threads reach this point
98 if (fakeRun) return;
99
100 const G4UserWorkerInitialization* uwi =
102
104
105 delete currentRun;
106
107 currentRun = nullptr;
108
110
111 // Call a user hook: this is guaranteed all threads are "synchronized"
112 if (uwi != nullptr) uwi->WorkerRunStart();
113
114 if (userRunAction != nullptr) currentRun = userRunAction->GenerateRun();
115 if (currentRun == nullptr) currentRun = new G4Run();
116
117 currentRun->SetRunID(runIDCounter);
118 G4TaskRunManager* mrm = G4TaskRunManager::GetMasterRunManager();
120 currentRun->SetNumberOfEventToBeProcessed(numberOfEventToBeProcessed);
121
122 currentRun->SetDCtable(DCtable);
123 G4SDManager* fSDM = G4SDManager::GetSDMpointerIfExist();
124 if (fSDM != nullptr) {
125 currentRun->SetHCtable(fSDM->GetHCtable());
126 }
127
128 if (G4VScoreNtupleWriter::Instance() != nullptr) {
129 auto hce = (fSDM != nullptr) ? fSDM->PrepareNewEvent() : nullptr;
131 delete hce;
132 }
133
134 std::ostringstream oss;
135 G4Random::saveFullState(oss);
137 currentRun->SetRandomNumberStatus(randomNumberStatusForThisRun);
138
139 for (G4int i_prev = 0; i_prev < n_perviousEventsToBeStored; ++i_prev)
140 previousEvents->push_back(nullptr);
141
142 if (printModulo > 0 || verboseLevel > 0) {
143 G4cout << "### Run " << currentRun->GetRunID() << " starts on worker thread "
144 << G4Threading::G4GetThreadId() << "." << G4endl;
145 }
146
147 if (userRunAction != nullptr) userRunAction->BeginOfRunAction(currentRun);
148
151 }
152
154 G4String fileN = "currentRun";
156 std::ostringstream os;
157 os << "run" << currentRun->GetRunID();
158 fileN = os.str();
159 }
160 StoreRNGStatus(fileN);
161 }
162
163 runAborted = false;
165 if(verboseLevel > 0) timer->Start();
166}
virtual void ThisWorkerReady()
static G4ParallelWorldProcessStore * GetInstance()
G4bool isScoreNtupleWriter
virtual void CleanUpPreviousEvents()
const G4UserWorkerInitialization * GetUserWorkerInitialization() const
std::list< G4Event * > * previousEvents
G4Timer * timer
G4int GetNumberOfEventsToBeProcessed() const
G4DCtable * DCtable
G4String randomNumberStatusForThisRun
static G4bool IfGeometryHasBeenDestroyed()
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
static G4VVisManager * GetConcreteInstance()
virtual void SetUpForAThread()
G4int G4GetThreadId()

Referenced by DoWork().

◆ RunTermination()

void G4WorkerSubEvtRunManager::RunTermination ( )
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 342 of file G4WorkerSubEvtRunManager.cc.

343{
344 if (!fakeRun && (currentRun != nullptr)) {
346
347 // Call a user hook: note this is before the next barrier
348 // so threads execute this method asyncrhonouzly
349 //(TerminateRun allows for synch via G4RunAction::EndOfRun)
350 const G4UserWorkerInitialization* uwi =
352 if (uwi != nullptr) uwi->WorkerRunEnd();
353 }
354
355 if (currentRun != nullptr) {
357 }
358 // Signal this thread has finished envent-loop.
359 // Note this will return only whan all threads reach this point
361}
virtual void ThisWorkerEndEventLoop()
virtual void RunTermination()
virtual void MergePartialResults(G4bool mergeEvents=true)

◆ SetSubEventType()

void G4WorkerSubEvtRunManager::SetSubEventType ( G4int ty)
overridevirtual

Reimplemented from G4RunManager.

Definition at line 545 of file G4WorkerSubEvtRunManager.cc.

546{
548 mrm->RegisterSubEvtWorker(this,ty);
549 fSubEventType = ty;
550}

Referenced by G4WorkerSubEvtRunManager().

◆ SetupDefaultRNGEngine()

void G4WorkerSubEvtRunManager::SetupDefaultRNGEngine ( )
overrideprotectedvirtual

Reimplemented from G4WorkerRunManager.

Definition at line 384 of file G4WorkerSubEvtRunManager.cc.

385{
386 const CLHEP::HepRandomEngine* mrnge =
388 assert(mrnge); // Master has created RNG
389 const G4UserWorkerThreadInitialization* uwti =
391 uwti->SetupRNGEngine(mrnge);
392}
const CLHEP::HepRandomEngine * getMasterRandomEngine() const
const G4UserWorkerThreadInitialization * GetUserWorkerThreadInitialization() const
virtual void SetupRNGEngine(const CLHEP::HepRandomEngine *aRNGEngine) const

◆ SetUserAction() [1/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4UserEventAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 598 of file G4WorkerSubEvtRunManager.cc.

599{
601}
virtual void SetUserAction(G4UserRunAction *userAction)

◆ SetUserAction() [2/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4UserRunAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 589 of file G4WorkerSubEvtRunManager.cc.

590{
591 G4Exception("G4WorkerSubEvtRunManager::SetUserAction(G4UserRunAction*)", "RunSE0221",
592 FatalException, "This method should be used only with an instance of the master thread");
593}

◆ SetUserAction() [3/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4UserStackingAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 611 of file G4WorkerSubEvtRunManager.cc.

612{
614}

◆ SetUserAction() [4/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4UserSteppingAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 623 of file G4WorkerSubEvtRunManager.cc.

624{
626}

◆ SetUserAction() [5/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4UserTrackingAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 617 of file G4WorkerSubEvtRunManager.cc.

618{
620}

◆ SetUserAction() [6/6]

void G4WorkerSubEvtRunManager::SetUserAction ( G4VUserPrimaryGeneratorAction * userAction)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 604 of file G4WorkerSubEvtRunManager.cc.

605{
606 G4Exception("G4WorkerSubEvtRunManager::SetUserAction(G4VUserPrimaryGeneratorAction*)", "RunSE0223",
607 FatalException, "This method should be used only with an instance of the master thread");
608}

◆ SetUserInitialization() [1/5]

void G4WorkerSubEvtRunManager::SetUserInitialization ( G4UserWorkerInitialization * userInit)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 554 of file G4WorkerSubEvtRunManager.cc.

555{
556 G4Exception("G4WorkerSubEvtRunManager::SetUserInitialization(G4UserWorkerInitialization*)", "RunSE0118",
557 FatalException, "This method should be used only with an instance of the master thread");
558}

◆ SetUserInitialization() [2/5]

void G4WorkerSubEvtRunManager::SetUserInitialization ( G4UserWorkerThreadInitialization * userInit)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 561 of file G4WorkerSubEvtRunManager.cc.

562{
563 G4Exception("G4WorkerSubEvtRunManager::SetUserInitialization(G4UserWorkerThreadInitialization*)", "RunSE0119",
564 FatalException, "This method should be used only with an instance of the master thread");
565}

◆ SetUserInitialization() [3/5]

void G4WorkerSubEvtRunManager::SetUserInitialization ( G4VUserActionInitialization * userInit)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 568 of file G4WorkerSubEvtRunManager.cc.

569{
570 G4Exception("G4WorkerSubEvtRunManager::SetUserInitialization(G4VUserActionInitialization*)", "RunSE0120",
571 FatalException, "This method should be used only with an instance of the master thread");
572}

◆ SetUserInitialization() [4/5]

void G4WorkerSubEvtRunManager::SetUserInitialization ( G4VUserDetectorConstruction * userDC)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 575 of file G4WorkerSubEvtRunManager.cc.

576{
577 G4Exception("G4WorkerSubEvtRunManager::SetUserInitialization(G4VUserDetectorConstruction*)", "RunSE0121",
578 FatalException, "This method should be used only with an instance of the master thread");
579}

◆ SetUserInitialization() [5/5]

void G4WorkerSubEvtRunManager::SetUserInitialization ( G4VUserPhysicsList * userPL)
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 582 of file G4WorkerSubEvtRunManager.cc.

583{
584 pl->InitializeWorker();
586}
virtual void SetUserInitialization(G4VUserDetectorConstruction *userInit)

◆ StoreRNGStatus()

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

Reimplemented from G4WorkerRunManager.

Definition at line 396 of file G4WorkerSubEvtRunManager.cc.

397{
398 std::ostringstream os;
399 os << randomNumberStatusDir << "G4Worker" << workerContext->GetThreadId() << "_" << fn << ".rndm";
400 G4Random::saveEngineStatus(os.str().c_str());
401}
G4String randomNumberStatusDir

Referenced by GenerateEvent(), and RunInitialization().

◆ TerminateEventLoop()

void G4WorkerSubEvtRunManager::TerminateEventLoop ( )
overridevirtual

Reimplemented from G4WorkerRunManager.

Definition at line 365 of file G4WorkerSubEvtRunManager.cc.

366{
367 if (verboseLevel > 0 && !fakeRun) {
368 timer->Stop();
369 // prefix with thread # info due to how TBB calls this function
370 G4String prefix = "[thread " + std::to_string(workerContext->GetThreadId()) + "] ";
371 G4cout << prefix << "Thread-local run terminated." << G4endl;
372 G4cout << prefix << "Run Summary" << G4endl;
373 if (runAborted)
374 G4cout << prefix << " Run Aborted after " << numberOfEventProcessed << " sub-events processed."
375 << G4endl;
376 else
377 G4cout << prefix << " Number of sub-events processed : " << numberOfEventProcessed << G4endl;
378 G4cout << prefix << " " << *timer << G4endl;
379 }
380}

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