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

#include <G4RunManager.hh>

+ Inheritance diagram for G4RunManager:

Public Types

enum  RMType {
  sequentialRM , masterRM , workerRM , subEventMasterRM ,
  subEventWorkerRM
}
 

Public Member Functions

 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 InitializeGeometry ()
 
virtual void InitializePhysics ()
 
virtual G4bool ConfirmBeamOnCondition ()
 
virtual void RunInitialization ()
 
virtual void DoEventLoop (G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
 
virtual void RunTermination ()
 
virtual void InitializeEventLoop (G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
 
virtual void ProcessOneEvent (G4int i_event)
 
virtual void TerminateOneEvent ()
 
virtual void TerminateEventLoop ()
 
virtual G4EventGenerateEvent (G4int i_event)
 
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 ConstructScoringWorlds ()
 
virtual void rndmSaveThisRun ()
 
virtual void rndmSaveThisEvent ()
 
virtual void RestoreRandomNumberStatus (const G4String &fileN)
 
virtual void RestoreRndmEachEvent (G4bool)
 
virtual void SetUserInitialization (G4VUserDetectorConstruction *userInit)
 
virtual void SetUserInitialization (G4VUserPhysicsList *userInit)
 
virtual void SetUserInitialization (G4VUserActionInitialization *userInit)
 
virtual void SetUserInitialization (G4UserWorkerInitialization *userInit)
 
virtual void SetUserInitialization (G4UserWorkerThreadInitialization *userInit)
 
virtual void SetUserAction (G4UserRunAction *userAction)
 
virtual void SetUserAction (G4VUserPrimaryGeneratorAction *userAction)
 
virtual void SetUserAction (G4UserEventAction *userAction)
 
virtual void SetUserAction (G4UserStackingAction *userAction)
 
virtual void SetUserAction (G4UserTrackingAction *userAction)
 
virtual void SetUserAction (G4UserSteppingAction *userAction)
 
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 G4RunManagerGetRunManager ()
 
static G4bool IfGeometryHasBeenDestroyed ()
 

Protected Member Functions

 G4RunManager (RMType rmType)
 
virtual void StackPreviousEvent (G4Event *anEvent)
 
virtual void CleanUpPreviousEvents ()
 
virtual void CleanUpUnnecessaryEvents (G4int keepNEvents)
 
virtual void StoreRNGStatus (const G4String &filenamePrefix)
 
void UpdateScoring (const G4Event *evt=nullptr)
 
virtual void DeleteUserInitializations ()
 

Protected Attributes

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

static G4RUN_DLL G4bool fGeometryHasBeenDestroyed = false
 

Friends

class G4RunManagerFactory
 

Detailed Description

Definition at line 137 of file G4RunManager.hh.

Member Enumeration Documentation

◆ RMType

Enumerator
sequentialRM 
masterRM 
workerRM 
subEventMasterRM 
subEventWorkerRM 

Definition at line 521 of file G4RunManager.hh.

Constructor & Destructor Documentation

◆ G4RunManager() [1/3]

G4RunManager::G4RunManager ( )

Definition at line 111 of file G4RunManager.cc.

112{
113 if (fRunManager != nullptr) {
114 G4Exception("G4RunManager::G4RunManager()", "Run0031", FatalException,
115 "G4RunManager constructed twice.");
116 }
117 fRunManager = this;
118
119 kernel = new G4RunManagerKernel();
120 eventManager = kernel->GetEventManager();
121
122 timer = new G4Timer();
123 runMessenger = new G4RunMessenger(this);
124 previousEvents = new std::list<G4Event*>;
127 std::ostringstream oss;
128 G4Random::saveFullState(oss);
132 G4UImanager::GetUIpointer()->SetAlias("RunMode sequential");
133}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
static G4ParticleTable * GetParticleTable()
G4UImessenger * CreateMessenger()
static G4ProcessTable * GetProcessTable()
std::list< G4Event * > * previousEvents
G4Timer * timer
G4RunManagerKernel * kernel
G4String randomNumberStatusForThisRun
G4String randomNumberStatusForThisEvent
RMType runManagerType
G4EventManager * eventManager
void SetAlias(const char *aliasLine)
static G4UImanager * GetUIpointer()

Referenced by G4MTRunManager::G4MTRunManager(), G4RunManager(), G4RunManagerFactory, G4WorkerRunManager::G4WorkerRunManager(), GetRunManager(), and operator=().

◆ ~G4RunManager()

G4RunManager::~G4RunManager ( )
virtual

Definition at line 186 of file G4RunManager.cc.

187{
188 G4StateManager* pStateManager = G4StateManager::GetStateManager();
189 // set the application state to the quite state
190 if (pStateManager->GetCurrentState() != G4State_Quit) {
191 if (verboseLevel > 1) G4cout << "G4 kernel has come to Quit state." << G4endl;
192 pStateManager->SetNewState(G4State_Quit);
193 }
194
196 if (verboseLevel > 1 && currentRun!=nullptr) {
197 G4cout << "Deleting G4Run (id:" << currentRun->GetRunID() << ") ";
198 if(currentRun->GetEventVectorSize()>0) {
199 G4cout << " that has " << currentRun->GetEventVectorSize()
200 << " events kept in eventVector";
201 }
202 G4cout << G4endl;
203 }
204 delete currentRun;
205 delete timer;
206 delete runMessenger;
207 delete previousEvents;
208
209 // The following will work for all RunManager types
210 // if derived class does the correct thing in the derived
211 // destructor that is: set to zero pointers of
212 // user initialization objects for which have no
213 // ownership
215 delete userRunAction;
216 userRunAction = nullptr;
217 if (verboseLevel > 1) G4cout << "UserRunAction deleted." << G4endl;
218
221 if (verboseLevel > 1) G4cout << "UserPrimaryGenerator deleted." << G4endl;
222
223 if (verboseLevel > 1) G4cout << "RunManager is deleting RunManagerKernel." << G4endl;
224
225 delete kernel;
226
227 fRunManager = nullptr;
228
229 if (verboseLevel > 1) G4cout << "RunManager is deleted." << G4endl;
230}
@ G4State_Quit
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
virtual void CleanUpPreviousEvents()
virtual void DeleteUserInitializations()
G4Run * currentRun
G4UserRunAction * userRunAction
G4VUserPrimaryGeneratorAction * userPrimaryGeneratorAction
const G4ApplicationState & GetCurrentState() const
static G4StateManager * GetStateManager()
G4bool SetNewState(const G4ApplicationState &requestedState)

◆ G4RunManager() [2/3]

G4RunManager::G4RunManager ( const G4RunManager & )
delete

◆ G4RunManager() [3/3]

G4RunManager::G4RunManager ( RMType rmType)
protected

Definition at line 136 of file G4RunManager.cc.

137{
138 // This version of the constructor should never be called in sequential mode!
139#ifndef G4MULTITHREADED
141 msg << "Geant4 code is compiled without multi-threading support "
142 "(-DG4MULTITHREADED is set to off).";
143 msg << " This type of RunManager can only be used in mult-threaded "
144 "applications.";
145 G4Exception("G4RunManager::G4RunManager(G4bool)", "Run0107", FatalException, msg);
146#endif
147
148 if (fRunManager != nullptr) {
149 G4Exception("G4RunManager::G4RunManager()", "Run0031", FatalException,
150 "G4RunManager constructed twice.");
151 return;
152 }
153 fRunManager = this;
154
155 switch (rmType) {
156 case masterRM:
157 kernel = new G4MTRunManagerKernel();
158 break;
159 case workerRM:
160 kernel = new G4WorkerRunManagerKernel();
161 break;
162 default:
164 msgx << "This type of RunManager can only be used in multi-threaded "
165 "applications.";
166 G4Exception("G4RunManager::G4RunManager(G4bool)", "Run0108", FatalException, msgx);
167 return;
168 }
169 runManagerType = rmType;
170
171 eventManager = kernel->GetEventManager();
172
173 timer = new G4Timer();
174 runMessenger = new G4RunMessenger(this);
175 previousEvents = new std::list<G4Event*>;
179 std::ostringstream oss;
180 G4Random::saveFullState(oss);
183}
std::ostringstream G4ExceptionDescription
G4String randomNumberStatusDir

Member Function Documentation

◆ AbortEvent()

void G4RunManager::AbortEvent ( )
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, and G4TaskRunManager.

Definition at line 705 of file G4RunManager.cc.

706{
707 // This method is valid only for EventProc state
709 if (currentState == G4State_EventProc) {
710 currentEvent->SetEventAborted();
711 eventManager->AbortCurrentEvent();
712 }
713 else {
714 G4cerr << "Event is not in progress. AbortEevnt() ignored." << G4endl;
715 }
716}
G4ApplicationState
@ G4State_EventProc
G4GLOB_DLL std::ostream G4cerr
G4Event * currentEvent

Referenced by G4ExceptionHandler::Notify().

◆ AbortRun()

void G4RunManager::AbortRun ( G4bool softAbort = false)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, and G4TaskRunManager.

Definition at line 688 of file G4RunManager.cc.

689{
690 // This method is valid only for GeomClosed or EventProc state
692 if (currentState == G4State_GeomClosed || currentState == G4State_EventProc) {
693 runAborted = true;
694 if (currentState == G4State_EventProc && !softAbort) {
695 currentEvent->SetEventAborted();
696 eventManager->AbortCurrentEvent();
697 }
698 }
699 else {
700 G4cerr << "Run is not in progress. AbortRun() ignored." << G4endl;
701 }
702}
@ G4State_GeomClosed

Referenced by G4ExceptionHandler::Notify().

◆ AnalyzeEvent()

void G4RunManager::AnalyzeEvent ( G4Event * anEvent)
virtual

Definition at line 488 of file G4RunManager.cc.

489{
490 G4VPersistencyManager* fPersM = G4VPersistencyManager::GetPersistencyManager();
491 if (fPersM != nullptr) fPersM->Store(anEvent);
492 currentRun->RecordEvent(anEvent);
493}
static G4VPersistencyManager * GetPersistencyManager()
virtual G4bool Store(const G4Event *anEvent)=0

Referenced by ProcessOneEvent(), G4WorkerRunManager::ProcessOneEvent(), G4WorkerSubEvtRunManager::ProcessOneEvent(), and G4WorkerTaskRunManager::ProcessOneEvent().

◆ BeamOn()

void G4RunManager::BeamOn ( G4int n_event,
const char * macroFile = nullptr,
G4int n_select = -1 )
virtual

Definition at line 257 of file G4RunManager.cc.

258{
259 fakeRun = n_event <= 0;
261 if (cond) {
266 DoEventLoop(n_event, macroFile, n_select);
268 }
269 fakeRun = false;
270}
bool G4bool
Definition G4Types.hh:86
G4int numberOfEventProcessed
virtual G4bool ConfirmBeamOnCondition()
virtual void RunTermination()
G4int numberOfEventToBeProcessed
virtual void DoEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
virtual void RunInitialization()
virtual void ConstructScoringWorlds()

Referenced by G4WorkerRunManager::DoWork(), G4MTRunManager::Initialize(), G4SubEvtRunManager::Initialize(), G4TaskRunManager::Initialize(), and G4AdjointSimManager::RunAdjointSimulation().

◆ CleanUpPreviousEvents()

void G4RunManager::CleanUpPreviousEvents ( )
protectedvirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 523 of file G4RunManager.cc.

524{
525 // Delete all events carried over from previous run.
526 // This method is invoked at the beginning of the next run
527 // or from the destructor of G4RunManager at the very end of
528 // the program.
529 // N.B. If ToBeKept() is true, the pointer of this event is
530 // kept in G4Run of the previous run, and deleted along with
531 // the deletion of G4Run.
532
533 auto evItr = previousEvents->cbegin();
534 while (evItr != previousEvents->cend()) {
535 G4Event* evt = *evItr;
536 if (evt != nullptr && !(evt->ToBeKept())) {
538 delete evt;
539 }
540 evItr = previousEvents->erase(evItr);
541 }
542
543}
G4bool ToBeKept() const
Definition G4Event.hh:105
virtual void ReportEventDeletion(const G4Event *evt)

Referenced by G4WorkerTaskRunManager::DoCleanup(), RunInitialization(), G4WorkerRunManager::RunInitialization(), G4WorkerSubEvtRunManager::RunInitialization(), G4WorkerTaskRunManager::RunInitialization(), ~G4RunManager(), and G4WorkerRunManager::~G4WorkerRunManager().

◆ CleanUpUnnecessaryEvents()

void G4RunManager::CleanUpUnnecessaryEvents ( G4int keepNEvents)
protectedvirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 546 of file G4RunManager.cc.

547{
548 // Delete events that are no longer necessary for post
549 // processing such as visualization.
550 // N.B. If ToBeKept() is true, the pointer of this event is
551 // kept in G4Run of the previous run, and deleted along with
552 // the deletion of G4Run.
553
554 auto evItr = previousEvents->cbegin();
555 while (evItr != previousEvents->cend()) {
556 if (G4int(previousEvents->size()) <= keepNEvents) return;
557
558 G4Event* evt = *evItr;
559 if (evt != nullptr) {
560 if (evt->GetNumberOfGrips() == 0) {
561 if (!(evt->ToBeKept())) {
563 delete evt;
564 }
565 evItr = previousEvents->erase(evItr);
566 }
567 else {
568 ++evItr;
569 }
570 }
571 else {
572 evItr = previousEvents->erase(evItr);
573 }
574 }
575}
int G4int
Definition G4Types.hh:85
G4int GetNumberOfGrips() const
Definition G4Event.hh:123

Referenced by RunTermination(), and StackPreviousEvent().

◆ ConfirmBeamOnCondition()

G4bool G4RunManager::ConfirmBeamOnCondition ( )
virtual

Definition at line 273 of file G4RunManager.cc.

274{
275 G4StateManager* stateManager = G4StateManager::GetStateManager();
276
277 G4ApplicationState currentState = stateManager->GetCurrentState();
278 if (currentState != G4State_PreInit && currentState != G4State_Idle) {
279 G4cerr << "Illegal application state - BeamOn() ignored." << G4endl;
280 return false;
281 }
282
284 G4cerr << " Geant4 kernel should be initialized" << G4endl;
285 G4cerr << "before the first BeamOn(). - BeamOn ignored." << G4endl;
286 return false;
287 }
288
290 if (verboseLevel > 0) {
291 G4cout << "Start re-initialization because " << G4endl;
292 if (!geometryInitialized) G4cout << " Geometry" << G4endl;
293 if (!physicsInitialized) G4cout << " Physics processes" << G4endl;
294 G4cout << "has been modified since last Run." << G4endl;
295 }
296 Initialize();
297 }
298 return true;
299}
@ G4State_Idle
@ G4State_PreInit
G4bool geometryInitialized
virtual void Initialize()
G4bool physicsInitialized
G4bool initializedAtLeastOnce

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

◆ ConstructScoringWorlds()

void G4RunManager::ConstructScoringWorlds ( )
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4TaskRunManager, and G4WorkerRunManager.

Definition at line 808 of file G4RunManager.cc.

809{
810 using MeshShape = G4VScoringMesh::MeshShape;
811
812 G4ScoringManager* ScM = G4ScoringManager::GetScoringManagerIfExist();
813 if (ScM == nullptr) return;
814
815 auto nPar = (G4int)ScM->GetNumberOfMesh();
816 if (nPar < 1) return;
817
819 for (G4int iw = 0; iw < nPar; ++iw) {
820 G4VScoringMesh* mesh = ScM->GetMesh(iw);
822 G4VPhysicalVolume* pWorld = nullptr;
823 if (mesh->GetShape() != MeshShape::realWorldLogVol) {
824 pWorld =
826 if (pWorld == nullptr) {
828 ScM->GetWorldName(iw));
829 pWorld->SetName(ScM->GetWorldName(iw));
830
831 G4ParallelWorldProcess* theParallelWorldProcess = mesh->GetParallelWorldProcess();
832 if (theParallelWorldProcess != nullptr) {
833 theParallelWorldProcess->SetParallelWorld(ScM->GetWorldName(iw));
834 }
835 else {
836 theParallelWorldProcess = new G4ParallelWorldProcess(ScM->GetWorldName(iw));
837 mesh->SetParallelWorldProcess(theParallelWorldProcess);
838 theParallelWorldProcess->SetParallelWorld(ScM->GetWorldName(iw));
839
840 theParticleIterator->reset();
841 while ((*theParticleIterator)()) {
842 G4ParticleDefinition* particle = theParticleIterator->value();
843 G4ProcessManager* pmanager = particle->GetProcessManager();
844 if (pmanager != nullptr) {
845 pmanager->AddProcess(theParallelWorldProcess);
846 if (theParallelWorldProcess->IsAtRestRequired(particle)) {
847 pmanager->SetProcessOrdering(theParallelWorldProcess, idxAtRest, 9900);
848 }
849 pmanager->SetProcessOrderingToSecond(theParallelWorldProcess, idxAlongStep);
850 pmanager->SetProcessOrdering(theParallelWorldProcess, idxPostStep, 9900);
851 }
852 }
853 }
854 theParallelWorldProcess->SetLayeredMaterialFlag(mesh->LayeredMassFlg());
855 }
856 }
857 mesh->Construct(pWorld);
858 }
860}
@ idxPostStep
@ idxAtRest
@ idxAlongStep
#define theParticleIterator
void SetLayeredMaterialFlag(G4bool flg=true)
void SetParallelWorld(G4String parallelWorldName)
G4bool IsAtRestRequired(G4ParticleDefinition *)
G4ProcessManager * GetProcessManager() const
G4PTblDicIterator * GetIterator() const
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)
static G4RUN_DLL G4bool fGeometryHasBeenDestroyed
void GeometryHasBeenModified(G4bool prop=true)
G4VScoringMesh * GetMesh(G4int i) const
const G4String & GetWorldName(G4int i) const
std::size_t GetNumberOfMesh() const
static G4ScoringManager * GetScoringManagerIfExist()
G4VPhysicalVolume * GetParallelWorld(const G4String &worldName)
static G4TransportationManager * GetTransportationManager()
G4VPhysicalVolume * IsWorldExisting(const G4String &worldName)
void SetName(const G4String &pName)
MeshShape GetShape() const
void GeometryHasBeenDestroyed()
G4ParallelWorldProcess * GetParallelWorldProcess() const
void SetParallelWorldProcess(G4ParallelWorldProcess *proc)
virtual void Construct(G4VPhysicalVolume *fWorldPhys)
G4bool LayeredMassFlg()

Referenced by BeamOn(), G4MTRunManager::ConstructScoringWorlds(), G4SubEvtRunManager::ConstructScoringWorlds(), and G4TaskRunManager::ConstructScoringWorlds().

◆ CutOffHasBeenModified()

void G4RunManager::CutOffHasBeenModified ( )
inline

Definition at line 288 of file G4RunManager.hh.

289 {
290 G4cerr << "CutOffHasBeenModified becomes obsolete." << G4endl;
291 G4cerr << "It is safe to remove invoking this method." << G4endl;
292 }

◆ DefineWorldVolume()

void G4RunManager::DefineWorldVolume ( G4VPhysicalVolume * worldVol,
G4bool topologyIsChanged = true )
virtual

Definition at line 719 of file G4RunManager.cc.

720{
721 kernel->DefineWorldVolume(worldVol, topologyIsChanged);
722}

Referenced by G4GDMLMessenger::SetNewValue().

◆ DeleteUserInitializations()

void G4RunManager::DeleteUserInitializations ( )
protectedvirtual

Definition at line 233 of file G4RunManager.cc.

234{
235 if (verboseLevel > 1) G4cout << "UserDetectorConstruction deleted " << userDetector << G4endl;
236 delete userDetector;
237 userDetector = nullptr;
238
239 if (verboseLevel > 1) G4cout << "UserPhysicsList deleted " << physicsList << G4endl;
240 delete physicsList;
241 physicsList = nullptr;
242
243 if (verboseLevel > 1) G4cout << "UserActionInitialization deleted " << userActionInitialization << G4endl;
245 userActionInitialization = nullptr;
246
247 if (verboseLevel > 1) G4cout << "UserWorkerInitialization deleted " << userWorkerInitialization << G4endl;
249 userWorkerInitialization = nullptr;
250
251 if (verboseLevel > 1) G4cout << "UserWorkerThreadInitialization deleted " << userWorkerThreadInitialization << G4endl;
254}
G4UserWorkerInitialization * userWorkerInitialization
G4UserWorkerThreadInitialization * userWorkerThreadInitialization
G4VUserActionInitialization * userActionInitialization
G4VUserDetectorConstruction * userDetector
G4VUserPhysicsList * physicsList

Referenced by ~G4RunManager().

◆ DoEventLoop()

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

Reimplemented in G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 373 of file G4RunManager.cc.

374{
375 InitializeEventLoop(n_event, macroFile, n_select);
376
377 // Event loop
378 for (G4int i_event = 0; i_event < n_event; ++i_event) {
379 ProcessOneEvent(i_event);
381 if (runAborted) break;
382 }
383
384 // For G4MTRunManager, TerminateEventLoop() is invoked after all threads are
385 // finished.
387}
virtual void InitializeEventLoop(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
virtual void TerminateEventLoop()
virtual void ProcessOneEvent(G4int i_event)
virtual void TerminateOneEvent()

Referenced by BeamOn().

◆ DumpRegion() [1/2]

void G4RunManager::DumpRegion ( const G4String & rname) const

Definition at line 796 of file G4RunManager.cc.

797{
798 kernel->DumpRegion(rname);
799}

◆ DumpRegion() [2/2]

void G4RunManager::DumpRegion ( G4Region * region = nullptr) const

Definition at line 802 of file G4RunManager.cc.

803{
804 kernel->DumpRegion(region);
805}

◆ GenerateEvent()

G4Event * G4RunManager::GenerateEvent ( G4int i_event)
virtual

Reimplemented in G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 446 of file G4RunManager.cc.

447{
448 if (userPrimaryGeneratorAction == nullptr) {
449 G4Exception("G4RunManager::GenerateEvent()", "Run0032", FatalException,
450 "G4VUserPrimaryGeneratorAction is not defined!");
451 return nullptr;
452 }
453
454 auto anEvent = new G4Event(i_event);
455
457 std::ostringstream oss;
458 G4Random::saveFullState(oss);
460 anEvent->SetRandomNumberStatus(randomNumberStatusForThisEvent);
461 }
462
464 G4String fileN = "currentEvent";
466 std::ostringstream os;
467 os << "run" << currentRun->GetRunID() << "evt" << anEvent->GetEventID();
468 fileN = os.str();
469 }
470 StoreRNGStatus(fileN);
471 }
472
473 if (printModulo > 0 && anEvent->GetEventID() % printModulo == 0) {
474 G4cout << "--> Event " << anEvent->GetEventID() << " starts." << G4endl;
475 }
476 userPrimaryGeneratorAction->GeneratePrimaries(anEvent);
477 return anEvent;
478}
G4int storeRandomNumberStatusToG4Event
G4bool rngStatusEventsFlag
G4bool storeRandomNumberStatus
virtual void StoreRNGStatus(const G4String &filenamePrefix)

Referenced by ProcessOneEvent(), and G4SubEvtRunManager::ProcessOneEvent().

◆ GeometryDirectlyUpdated()

void G4RunManager::GeometryDirectlyUpdated ( G4bool val = true)
inline

Definition at line 314 of file G4RunManager.hh.

G4bool geometryDirectlyUpdated

Referenced by G4GDMLMessenger::SetNewValue().

◆ GeometryHasBeenModified()

void G4RunManager::GeometryHasBeenModified ( G4bool prop = true)

Definition at line 1003 of file G4RunManager.cc.

1004{
1005 if (prop) {
1006 G4UImanager::GetUIpointer()->ApplyCommand("/run/geometryModified");
1007 }
1008 else {
1009 kernel->GeometryHasBeenModified();
1010 }
1011}
G4int ApplyCommand(const char *aCommand)

Referenced by ConstructScoringWorlds().

◆ GetCurrentEvent()

const G4Event * G4RunManager::GetCurrentEvent ( ) const
inline

Definition at line 491 of file G4RunManager.hh.

491{ return currentEvent; }

◆ GetCurrentRun()

◆ GetFlagRandomNumberStatusToG4Event()

G4int G4RunManager::GetFlagRandomNumberStatusToG4Event ( ) const
inline

Definition at line 427 of file G4RunManager.hh.

428 {
430 }

◆ GetGeometryToBeOptimized()

G4bool G4RunManager::GetGeometryToBeOptimized ( )
inline

Definition at line 312 of file G4RunManager.hh.

312{ return geometryToBeOptimized; }
G4bool geometryToBeOptimized

◆ GetMaxNTrack()

virtual std::size_t G4RunManager::GetMaxNTrack ( ) const
inlinevirtual

Definition at line 572 of file G4RunManager.hh.

573 { return 0; }

◆ GetNonConstCurrentRun()

G4Run * G4RunManager::GetNonConstCurrentRun ( ) const
inline

Definition at line 487 of file G4RunManager.hh.

487{ return currentRun; }

◆ GetNonConstUserActionInitialization()

G4VUserActionInitialization * G4RunManager::GetNonConstUserActionInitialization ( ) const
inline

◆ GetNumberOfEventsToBeProcessed()

G4int G4RunManager::GetNumberOfEventsToBeProcessed ( ) const
inline

◆ GetNumberOfParallelWorld()

G4int G4RunManager::GetNumberOfParallelWorld ( ) const
inline

Definition at line 514 of file G4RunManager.hh.

514{ return nParallelWorlds; }
G4int nParallelWorlds

◆ GetNumberOfSelectEvents()

G4int G4RunManager::GetNumberOfSelectEvents ( ) const
inline

Definition at line 517 of file G4RunManager.hh.

517{ return n_select_msg; }

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

◆ GetNumberOfThreads()

virtual G4int G4RunManager::GetNumberOfThreads ( ) const
inlinevirtual

Reimplemented in G4MTRunManager, and G4TaskRunManager.

Definition at line 253 of file G4RunManager.hh.

253{ return 1; }

◆ GetPreviousEvent()

const G4Event * G4RunManager::GetPreviousEvent ( G4int i) const
inline

Definition at line 498 of file G4RunManager.hh.

499 {
500 if (i >= 1 && i <= n_perviousEventsToBeStored) {
501 auto itr = previousEvents->cbegin();
502 for (G4int j = 1; j < i; ++j) {
503 ++itr;
504 }
505 return *itr;
506 }
507 return nullptr;
508 }
G4int n_perviousEventsToBeStored

◆ GetPrintProgress()

G4int G4RunManager::GetPrintProgress ( )
inline

Definition at line 475 of file G4RunManager.hh.

475{ return printModulo; }

Referenced by G4TheMTRayTracer::CreateBitMap().

◆ GetRandomNumberStatusForThisEvent()

const G4String & G4RunManager::GetRandomNumberStatusForThisEvent ( ) const
inline

Definition at line 458 of file G4RunManager.hh.

459 {
461 G4Exception("GrRunManager::SetRandomNumberStoreDir", "Run0072", JustWarning,
462 "Random number status is not available for this event.");
463 }
465 }
@ JustWarning

◆ GetRandomNumberStatusForThisRun()

const G4String & G4RunManager::GetRandomNumberStatusForThisRun ( ) const
inline

Definition at line 454 of file G4RunManager.hh.

455 {
457 }

◆ GetRandomNumberStore()

G4bool G4RunManager::GetRandomNumberStore ( ) const
inline

Definition at line 433 of file G4RunManager.hh.

433{ return storeRandomNumberStatus; }

◆ GetRandomNumberStoreDir()

const G4String & G4RunManager::GetRandomNumberStoreDir ( ) const
inline

Definition at line 453 of file G4RunManager.hh.

453{ return randomNumberStatusDir; }

◆ GetRandomNumberStorePerEvent()

G4bool G4RunManager::GetRandomNumberStorePerEvent ( ) const
inline

Definition at line 467 of file G4RunManager.hh.

467{ return rngStatusEventsFlag; }

◆ GetRunManager()

◆ GetRunManagerType()

RMType G4RunManager::GetRunManagerType ( ) const
inline

Definition at line 530 of file G4RunManager.hh.

530{ return runManagerType; }

◆ GetSelectMacro()

const G4String & G4RunManager::GetSelectMacro ( ) const
inline

Definition at line 518 of file G4RunManager.hh.

518{ return selectMacro; }
G4String selectMacro

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

◆ GetSubEvent()

virtual const G4SubEvent * G4RunManager::GetSubEvent ( G4int ,
G4bool & ,
G4long & ,
G4long & ,
G4long & ,
G4bool  )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 549 of file G4RunManager.hh.

551 {
552 G4Exception("G4RunManager::GetSubEvent","RunSE1002",FatalException,
553 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
554 return nullptr;
555 }

◆ GetSubEventType()

virtual G4int G4RunManager::GetSubEventType ( ) const
inlinevirtual

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 561 of file G4RunManager.hh.

562 {
563 G4Exception("G4RunManager::GetSubEventType","RunSE1010",FatalException,
564 "Base class method is invoked for RunManager that is not a worker in sub-event parallel mode");
565 return -1;
566 }

◆ GetUserActionInitialization()

const G4VUserActionInitialization * G4RunManager::GetUserActionInitialization ( ) const
inline

◆ GetUserDetectorConstruction()

const G4VUserDetectorConstruction * G4RunManager::GetUserDetectorConstruction ( ) const
inline

Definition at line 355 of file G4RunManager.hh.

356 {
357 return userDetector;
358 }

Referenced by G4TaskRunManagerKernel::InitializeWorker(), and G4MTRunManagerKernel::StartThread().

◆ GetUserEventAction()

const G4UserEventAction * G4RunManager::GetUserEventAction ( ) const
inline

Definition at line 381 of file G4RunManager.hh.

381{ return userEventAction; }
G4UserEventAction * userEventAction

Referenced by G4RTWorkerInitialization::WorkerRunStart().

◆ GetUserPhysicsList()

const G4VUserPhysicsList * G4RunManager::GetUserPhysicsList ( ) const
inline

◆ GetUserPrimaryGeneratorAction()

const G4VUserPrimaryGeneratorAction * G4RunManager::GetUserPrimaryGeneratorAction ( ) const
inline

Definition at line 377 of file G4RunManager.hh.

378 {
380 }

Referenced by G4RTWorkerInitialization::WorkerRunStart().

◆ GetUserRunAction()

const G4UserRunAction * G4RunManager::GetUserRunAction ( ) const
inline

◆ GetUserStackingAction()

const G4UserStackingAction * G4RunManager::GetUserStackingAction ( ) const
inline

Definition at line 382 of file G4RunManager.hh.

382{ return userStackingAction; }
G4UserStackingAction * userStackingAction

Referenced by G4RTWorkerInitialization::WorkerRunStart().

◆ GetUserSteppingAction()

const G4UserSteppingAction * G4RunManager::GetUserSteppingAction ( ) const
inline

Definition at line 384 of file G4RunManager.hh.

384{ return userSteppingAction; }
G4UserSteppingAction * userSteppingAction

Referenced by G4RTWorkerInitialization::WorkerRunStart().

◆ GetUserTrackingAction()

const G4UserTrackingAction * G4RunManager::GetUserTrackingAction ( ) const
inline

Definition at line 383 of file G4RunManager.hh.

383{ return userTrackingAction; }
G4UserTrackingAction * userTrackingAction

Referenced by G4RTWorkerInitialization::WorkerRunStart().

◆ GetUserWorkerInitialization()

◆ GetUserWorkerThreadInitialization()

◆ GetVerboseLevel()

G4int G4RunManager::GetVerboseLevel ( ) const
inline

Definition at line 474 of file G4RunManager.hh.

474{ return verboseLevel; }

Referenced by G4TheMTRayTracer::CreateBitMap().

◆ GetVersionString()

const G4String & G4RunManager::GetVersionString ( ) const
inline

Definition at line 409 of file G4RunManager.hh.

409{ return kernel->GetVersionString(); }

◆ IfGeometryHasBeenDestroyed()

G4bool G4RunManager::IfGeometryHasBeenDestroyed ( )
static

◆ Initialize()

void G4RunManager::Initialize ( )
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, and G4TaskRunManager.

Definition at line 615 of file G4RunManager.cc.

616{
617 G4StateManager* stateManager = G4StateManager::GetStateManager();
618 G4ApplicationState currentState = stateManager->GetCurrentState();
619 if (currentState != G4State_PreInit && currentState != G4State_Idle) {
620 G4cerr << "Illegal application state - "
621 << "G4RunManager::Initialize() ignored." << G4endl;
622 return;
623 }
624
625 stateManager->SetNewState(G4State_Init);
629 if (stateManager->GetCurrentState() != G4State_Idle) {
630 stateManager->SetNewState(G4State_Idle);
631 }
632}
@ G4State_Init
virtual void InitializePhysics()
virtual void InitializeGeometry()

Referenced by ConfirmBeamOnCondition(), G4MTRunManager::Initialize(), G4SubEvtRunManager::Initialize(), G4TaskRunManager::Initialize(), and G4MTRunManagerKernel::StartThread().

◆ InitializeEventLoop()

void G4RunManager::InitializeEventLoop ( G4int n_event,
const char * macroFile = nullptr,
G4int n_select = -1 )
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, and G4TaskRunManager.

Definition at line 390 of file G4RunManager.cc.

391{
392 if (verboseLevel > 0) {
393 timer->Start();
394 }
395
396 n_select_msg = n_select;
397 if (macroFile != nullptr) {
398 if (n_select_msg < 0) n_select_msg = n_event;
399 msgText = "/control/execute ";
400 msgText += macroFile;
401 selectMacro = macroFile;
402 }
403 else {
404 n_select_msg = -1;
405 selectMacro = "";
406 }
407}
G4String msgText

Referenced by DoEventLoop(), G4WorkerRunManager::DoEventLoop(), G4WorkerSubEvtRunManager::DoEventLoop(), and G4WorkerTaskRunManager::DoEventLoop().

◆ InitializeGeometry()

void G4RunManager::InitializeGeometry ( )
virtual

Reimplemented in G4WorkerRunManager.

Definition at line 635 of file G4RunManager.cc.

636{
637 if (userDetector == nullptr) {
638 G4Exception("G4RunManager::InitializeGeometry", "Run0033", FatalException,
639 "G4VUserDetectorConstruction is not defined!");
640 return;
641 }
642
643 if (verboseLevel > 1) G4cout << "userDetector->Construct() start." << G4endl;
644
645 G4StateManager* stateManager = G4StateManager::GetStateManager();
646 G4ApplicationState currentState = stateManager->GetCurrentState();
647 if (currentState == G4State_PreInit || currentState == G4State_Idle) {
648 stateManager->SetNewState(G4State_Init);
649 }
651 kernel->DefineWorldVolume(userDetector->Construct(), false);
652 userDetector->ConstructSDandField();
653 nParallelWorlds = userDetector->ConstructParallelGeometries();
654 userDetector->ConstructParallelSD();
655 kernel->SetNumberOfParallelWorld(nParallelWorlds);
656 }
657 // Notify the VisManager as well
659 G4VVisManager* pVVisManager = G4VVisManager::GetConcreteInstance();
660 if (pVVisManager != nullptr) pVVisManager->GeometryHasChanged();
661 }
662
664 geometryInitialized = true;
665 stateManager->SetNewState(currentState);
666}
static G4VVisManager * GetConcreteInstance()
virtual void GeometryHasChanged()=0
G4bool IsMasterThread()

Referenced by Initialize().

◆ InitializePhysics()

void G4RunManager::InitializePhysics ( )
virtual

Definition at line 669 of file G4RunManager.cc.

670{
671 G4StateManager* stateManager = G4StateManager::GetStateManager();
672 G4ApplicationState currentState = stateManager->GetCurrentState();
673 if (currentState == G4State_PreInit || currentState == G4State_Idle) {
674 stateManager->SetNewState(G4State_Init);
675 }
676 if (physicsList != nullptr) {
677 kernel->InitializePhysics();
678 }
679 else {
680 G4Exception("G4RunManager::InitializePhysics()", "Run0034", FatalException,
681 "G4VUserPhysicsList is not defined!");
682 }
683 physicsInitialized = true;
684 stateManager->SetNewState(currentState);
685}

Referenced by Initialize().

◆ MergeTrajectories()

virtual void G4RunManager::MergeTrajectories ( const G4SubEvent * ,
const G4Event *  )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 539 of file G4RunManager.hh.

540 {
541 G4Exception("G4RunManager::MergeTrajectories","RunSE1001",FatalException,
542 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
543 }

◆ operator=()

G4RunManager & G4RunManager::operator= ( const G4RunManager & )
delete

◆ PhysicsHasBeenModified()

void G4RunManager::PhysicsHasBeenModified ( )
inline

Definition at line 286 of file G4RunManager.hh.

286{ kernel->PhysicsHasBeenModified(); }

◆ ProcessOneEvent()

void G4RunManager::ProcessOneEvent ( G4int i_event)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4TaskRunManager, G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 410 of file G4RunManager.cc.

411{
412 currentEvent = GenerateEvent(i_event);
413 eventManager->ProcessOneEvent(currentEvent);
417}
void UpdateScoring(const G4Event *evt=nullptr)
virtual G4Event * GenerateEvent(G4int i_event)
virtual void AnalyzeEvent(G4Event *anEvent)

Referenced by DoEventLoop().

◆ RegisterSubEventType()

virtual void G4RunManager::RegisterSubEventType ( G4int ,
G4int  )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 534 of file G4RunManager.hh.

535 {
536 G4Exception("G4RunManager::RegisterSubEventType","RunSE1000",FatalException,
537 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
538 }

◆ ReinitializeGeometry()

void G4RunManager::ReinitializeGeometry ( G4bool destroyFirst = false,
G4bool prop = true )

Definition at line 1014 of file G4RunManager.cc.

1015{
1016 if (destroyFirst && G4Threading::IsMasterThread()) {
1017 if (verboseLevel > 0) {
1018 G4cout << "#### Assemblies, Volumes and Solids Stores are wiped out." << G4endl;
1019 }
1025
1026 // remove all logical volume pointers from regions
1027 // exception: world logical volume pointer must be kept
1028 G4RegionStore* regionStore = G4RegionStore::GetInstance();
1029 for (const auto& rItr : *regionStore) {
1030 if (rItr->GetName() == "DefaultRegionForTheWorld") continue;
1031 auto lvItr = rItr->GetRootLogicalVolumeIterator();
1032 for (std::size_t iRLV = 0; iRLV < rItr->GetNumberOfRootVolumes(); ++iRLV) {
1033 rItr->RemoveRootLogicalVolume(*lvItr, false);
1034 ++lvItr;
1035 }
1036 if (verboseLevel > 0) {
1037 G4cout << "#### Region <" << rItr->GetName() << "> is cleared." << G4endl;
1038 }
1039 }
1040
1041 // clear transportation manager
1044 }
1045 if (prop) {
1046 G4UImanager::GetUIpointer()->ApplyCommand("/run/reinitializeGeometry");
1047 }
1048 else {
1049 kernel->GeometryHasBeenModified();
1050 geometryInitialized = false;
1051 // Notify the VisManager as well
1053 G4VVisManager* pVVisManager = G4VVisManager::GetConcreteInstance();
1054 if (pVVisManager != nullptr) pVVisManager->GeometryHasChanged();
1055 }
1056 // Reinitialize field builder
1059 }
1060 }
1061}
static G4AssemblyStore * GetInstance()
static void Clean()
static G4bool IsInstance()
Return the information if an instance exists.
static G4FieldBuilder * Instance()
static G4GeometryManager * GetInstance()
void OpenGeometry(G4VPhysicalVolume *vol=nullptr)
static G4LogicalVolumeStore * GetInstance()
static G4PhysicalVolumeStore * GetInstance()
static G4RegionStore * GetInstance()
static void Clean()
static G4SolidStore * GetInstance()

Referenced by G4GDMLMessenger::SetNewValue().

◆ ReOptimize()

void G4RunManager::ReOptimize ( G4LogicalVolume * pLog)

Definition at line 904 of file G4RunManager.cc.

905{
906 G4Timer localtimer;
907 if (verboseLevel > 1) {
908 localtimer.Start();
909 }
910 G4SmartVoxelHeader* header = pLog->GetVoxelHeader();
911 delete header;
912 header = new G4SmartVoxelHeader(pLog);
913 pLog->SetVoxelHeader(header);
914 if (verboseLevel > 1) {
915 localtimer.Stop();
916 G4SmartVoxelStat stat(pLog, header, localtimer.GetSystemElapsed(), localtimer.GetUserElapsed());
917 G4cout << G4endl << "Voxelisation of logical volume <" << pLog->GetName() << ">" << G4endl;
918 G4cout << " heads : " << stat.GetNumberHeads() << " - nodes : " << stat.GetNumberNodes()
919 << " - pointers : " << stat.GetNumberPointers() << G4endl;
920 G4cout << " Memory used : " << (stat.GetMemoryUse() + 512) / 1024
921 << "k - total time : " << stat.GetTotalTime() << " - system time : " << stat.GetSysTime()
922 << G4endl;
923 }
924}
void SetVoxelHeader(G4SmartVoxelHeader *pVoxel)
const G4String & GetName() const
G4SmartVoxelHeader * GetVoxelHeader() const
void Stop()
G4double GetSystemElapsed() const
Definition G4Timer.cc:124
G4double GetUserElapsed() const
Definition G4Timer.cc:135
void Start()

Referenced by ReOptimizeMotherOf().

◆ ReOptimizeMotherOf()

void G4RunManager::ReOptimizeMotherOf ( G4VPhysicalVolume * pPhys)

Definition at line 897 of file G4RunManager.cc.

898{
899 G4LogicalVolume* pMotherL = pPhys->GetMotherLogical();
900 if (pMotherL != nullptr) ReOptimize(pMotherL);
901}
void ReOptimize(G4LogicalVolume *)
G4LogicalVolume * GetMotherLogical() const

◆ ReportEventDeletion()

void G4RunManager::ReportEventDeletion ( const G4Event * evt)
virtual

Definition at line 601 of file G4RunManager.cc.

602{
603 if(verboseLevel > 3) {
604 G4cout << "deleting G4Event(" << evt << ") eventID = " << evt->GetEventID()
605 << " -- grips = " << evt->GetNumberOfGrips()
606 << " keepFlag = " << evt->KeepTheEventFlag()
607 << " subEvt = " << evt->GetNumberOfRemainingSubEvents();
608 if(evt->GetNumberOfCompletedSubEvent()>0) {
609 G4cout << " -- contains " << evt->GetNumberOfCompletedSubEvent() << " completed sub-events";
610 }
611 G4cout << G4endl;
612 }
613}
G4int GetNumberOfCompletedSubEvent() const
Definition G4Event.hh:260
G4int GetEventID() const
Definition G4Event.hh:126
G4bool KeepTheEventFlag() const
Definition G4Event.hh:103
G4int GetNumberOfRemainingSubEvents() const
Definition G4Event.cc:277

Referenced by CleanUpPreviousEvents(), G4SubEvtRunManager::CleanUpPreviousEvents(), CleanUpUnnecessaryEvents(), G4SubEvtRunManager::CleanUpUnnecessaryEvents(), StackPreviousEvent(), G4SubEvtRunManager::StackPreviousEvent(), and G4Run::~G4Run().

◆ ResetNavigatorAtInitialization()

void G4RunManager::ResetNavigatorAtInitialization ( G4bool val = true)
inline

Definition at line 585 of file G4RunManager.hh.

586 { if(kernel!=nullptr) kernel->ResetNavigatorAtInitialization(val); }

◆ RestoreRandomNumberStatus()

void G4RunManager::RestoreRandomNumberStatus ( const G4String & fileN)
virtual

Definition at line 779 of file G4RunManager.cc.

780{
781 G4String fileNameWithDirectory;
782 if (fileN.find('/') == std::string::npos) {
783 fileNameWithDirectory = randomNumberStatusDir + fileN;
784 }
785 else {
786 fileNameWithDirectory = fileN;
787 }
788
789 G4Random::restoreEngineStatus(fileNameWithDirectory);
790 if (verboseLevel > 0)
791 G4cout << "RandomNumberEngineStatus restored from file: " << fileNameWithDirectory << G4endl;
792 G4Random::showEngineStatus();
793}

◆ RestoreRndmEachEvent()

virtual void G4RunManager::RestoreRndmEachEvent ( G4bool )
inlinevirtual

Reimplemented in G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 326 of file G4RunManager.hh.

327 { /* No effect in SEQ */
328 }

◆ rndmSaveThisEvent()

void G4RunManager::rndmSaveThisEvent ( )
virtual

Reimplemented in G4MTRunManager, and G4WorkerRunManager.

Definition at line 750 of file G4RunManager.cc.

751{
752 if (currentEvent == nullptr) {
753 G4cerr << "Warning from G4RunManager::rndmSaveThisEvent():"
754 << " there is no currentEvent available." << G4endl << "Command ignored." << G4endl;
755 return;
756 }
757
759 G4cerr << "Warning from G4RunManager::rndmSaveThisEvent():"
760 << " Random number engine status is not available." << G4endl
761 << "/random/setSavingFlag command must be issued "
762 << "prior to the start of the run. Command ignored." << G4endl;
763 return;
764 }
765
766 G4fs::path fileIn = randomNumberStatusDir + "currentEvent.rndm";
767
768 std::ostringstream os;
769 os << "run" << currentRun->GetRunID() << "evt" << currentEvent->GetEventID() << ".rndm" << '\0';
770 G4fs::path fileOut = randomNumberStatusDir + os.str();
771
772 if (G4CopyRandomState(fileIn, fileOut, "G4RunManager::rndmSaveThisEvent()") && verboseLevel > 0)
773 {
774 G4cout << fileIn << " is copied to " << fileOut << G4endl;
775 }
776}
G4bool G4CopyRandomState(const G4fs::path &source, const G4fs::path &dest, const G4String &callsite)

◆ rndmSaveThisRun()

void G4RunManager::rndmSaveThisRun ( )
virtual

Reimplemented in G4MTRunManager, and G4WorkerRunManager.

Definition at line 725 of file G4RunManager.cc.

726{
727 G4int runNumber = 0;
728 if (currentRun != nullptr) runNumber = currentRun->GetRunID();
730 G4cerr << "Warning from G4RunManager::rndmSaveThisRun():"
731 << " Random number status was not stored prior to this run." << G4endl
732 << "/random/setSavingFlag command must be issued. "
733 << "Command ignored." << G4endl;
734 return;
735 }
736
737 G4fs::path fileIn = randomNumberStatusDir + "currentRun.rndm";
738
739 std::ostringstream os;
740 os << "run" << runNumber << ".rndm" << '\0';
741 G4fs::path fileOut = randomNumberStatusDir + os.str();
742
743 if (G4CopyRandomState(fileIn, fileOut, "G4RunManager::rndmSaveThisRun()") && verboseLevel > 0)
744 {
745 G4cout << fileIn << " is copied to " << fileOut << G4endl;
746 }
747}

◆ RunInitialization()

void G4RunManager::RunInitialization ( )
virtual

Reimplemented in G4SubEvtRunManager, G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 302 of file G4RunManager.cc.

303{
304 if (!(kernel->RunInitialization(fakeRun))) return;
305
306 runAborted = false;
308
310 if (verboseLevel > 2 && currentRun!=nullptr) {
311 G4cout << "Deleting G4Run (id:" << currentRun->GetRunID() << ") ";
312 if(currentRun->GetEventVectorSize()>0) {
313 G4cout << " that has " << currentRun->GetEventVectorSize()
314 << " events kept in eventVector";
315 }
316 G4cout << G4endl;
317 }
318 delete currentRun;
319 currentRun = nullptr;
320
321 if (fakeRun) return;
322
324
325 if (userRunAction != nullptr) currentRun = userRunAction->GenerateRun();
326 if (currentRun == nullptr) currentRun = new G4Run();
327
328 currentRun->SetRunID(runIDCounter);
329 currentRun->SetNumberOfEventToBeProcessed(numberOfEventToBeProcessed);
330
331 currentRun->SetDCtable(DCtable);
332 G4SDManager* fSDM = G4SDManager::GetSDMpointerIfExist();
333 if (fSDM != nullptr) {
334 currentRun->SetHCtable(fSDM->GetHCtable());
335 }
336
337 if (G4VScoreNtupleWriter::Instance() != nullptr) {
338 auto hce = (fSDM != nullptr) ? fSDM->PrepareNewEvent() : nullptr;
340 delete hce;
341 }
342
343 std::ostringstream oss;
344 G4Random::saveFullState(oss);
346 currentRun->SetRandomNumberStatus(randomNumberStatusForThisRun);
347
348 for (G4int i_prev = 0; i_prev < n_perviousEventsToBeStored; ++i_prev) {
349 previousEvents->push_back(nullptr);
350 }
351
352 if (printModulo >= 0 || verboseLevel > 0) {
353 G4cout << "### Run " << currentRun->GetRunID() << " starts." << G4endl;
354 }
355 if (userRunAction != nullptr) userRunAction->BeginOfRunAction(currentRun);
356
359 }
360
362 G4String fileN = "currentRun";
364 std::ostringstream os;
365 os << "run" << currentRun->GetRunID();
366 fileN = os.str();
367 }
368 StoreRNGStatus(fileN);
369 }
370}
static G4ParallelWorldProcessStore * GetInstance()
G4bool isScoreNtupleWriter
G4DCtable * DCtable
G4HCofThisEvent * PrepareNewEvent()
static G4SDManager * GetSDMpointerIfExist()
G4HCtable * GetHCtable() const
virtual G4bool Book(G4HCofThisEvent *hce)=0
static G4VScoreNtupleWriter * Instance()
virtual void OpenFile()=0

Referenced by BeamOn(), and G4SubEvtRunManager::RunInitialization().

◆ RunTermination()

void G4RunManager::RunTermination ( )
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4TaskRunManager, G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 496 of file G4RunManager.cc.

497{
498 if (!fakeRun) {
500// if(G4int(previousEvents->size())>0) {
501// G4ExceptionDescription ed;
502// ed << "Run still has " << previousEvents->size() << " unfinished events!!";
503// G4Exception("G4RunManager::RunTermination()","RM09009",FatalException,ed);
504// }
505 // tasking occasionally will call this function even
506 // if there was not a current run
507 if (currentRun != nullptr) {
508 if (userRunAction != nullptr) userRunAction->EndOfRunAction(currentRun);
509 G4VPersistencyManager* fPersM = G4VPersistencyManager::GetPersistencyManager();
510 if (fPersM != nullptr) fPersM->Store(currentRun);
511 // write & close analysis output
514 }
515 }
516 ++runIDCounter;
517 }
518
519 kernel->RunTermination();
520}
virtual void CleanUpUnnecessaryEvents(G4int keepNEvents)
virtual void Write()=0

Referenced by BeamOn(), G4MTRunManager::RunTermination(), G4SubEvtRunManager::RunTermination(), G4TaskRunManager::RunTermination(), G4WorkerRunManager::RunTermination(), G4WorkerSubEvtRunManager::RunTermination(), and G4WorkerTaskRunManager::RunTermination().

◆ SetDCtable()

void G4RunManager::SetDCtable ( G4DCtable * DCtbl)
inline

Definition at line 519 of file G4RunManager.hh.

519{ DCtable = DCtbl; }

◆ SetDefaultClassification() [1/2]

void G4RunManager::SetDefaultClassification ( const G4ParticleDefinition * pd,
G4ClassificationOfNewTrack val,
G4ExceptionSeverity es = G4ExceptionSeverity::IgnoreTheIssue )
inline

Definition at line 403 of file G4RunManager.hh.

406 { eventManager->GetStackManager()->SetDefaultClassification(pd,val,es); }

◆ SetDefaultClassification() [2/2]

void G4RunManager::SetDefaultClassification ( G4TrackStatus ts,
G4ClassificationOfNewTrack val,
G4ExceptionSeverity es = G4ExceptionSeverity::IgnoreTheIssue )
inline

Definition at line 399 of file G4RunManager.hh.

402 { eventManager->GetStackManager()->SetDefaultClassification(ts,val,es); }

◆ SetGeometryToBeOptimized()

void G4RunManager::SetGeometryToBeOptimized ( G4bool vl)
inline

Definition at line 304 of file G4RunManager.hh.

305 {
306 if (geometryToBeOptimized != vl) {
308 kernel->GeometryHasBeenModified();
309 kernel->SetGeometryToBeOptimized(vl);
310 }
311 }

◆ SetNumberOfAdditionalWaitingStacks()

void G4RunManager::SetNumberOfAdditionalWaitingStacks ( G4int iAdd)
inline

Definition at line 390 of file G4RunManager.hh.

391 {
392 eventManager->GetStackManager()->SetNumberOfAdditionalWaitingStacks(iAdd);
393 }

◆ SetNumberOfEventsToBeProcessed()

void G4RunManager::SetNumberOfEventsToBeProcessed ( G4int val)
inline

Definition at line 515 of file G4RunManager.hh.

◆ SetNumberOfEventsToBeStored()

void G4RunManager::SetNumberOfEventsToBeStored ( G4int val)
inline

Definition at line 482 of file G4RunManager.hh.

◆ SetNumberOfThreads()

virtual void G4RunManager::SetNumberOfThreads ( G4int )
inlinevirtual

Reimplemented in G4MTRunManager, and G4TaskRunManager.

Definition at line 252 of file G4RunManager.hh.

252{}

◆ SetPrimaryTransformer()

void G4RunManager::SetPrimaryTransformer ( G4PrimaryTransformer * pt)
inline

Definition at line 411 of file G4RunManager.hh.

412 {
413 kernel->SetPrimaryTransformer(pt);
414 }

◆ SetPrintProgress()

void G4RunManager::SetPrintProgress ( G4int i)
inline

Definition at line 476 of file G4RunManager.hh.

476{ printModulo = i; }

◆ SetRandomNumberStore()

void G4RunManager::SetRandomNumberStore ( G4bool flag)
inline

Definition at line 432 of file G4RunManager.hh.

432{ storeRandomNumberStatus = flag; }

◆ SetRandomNumberStoreDir()

void G4RunManager::SetRandomNumberStoreDir ( const G4String & dir)
inline

Definition at line 434 of file G4RunManager.hh.

435 {
436 G4String dirStr = dir;
437 if (dirStr.back() != '/') dirStr += "/";
438#ifndef WIN32
439 G4String shellCmd = "mkdir -p ";
440#else
441 std::replace(dirStr.begin(), dirStr.end(), '/', '\\');
442 G4String shellCmd = "if not exist " + dirStr + " mkdir ";
443#endif
444 shellCmd += dirStr;
445 randomNumberStatusDir = std::move(dirStr);
446 G4int sysret = system(shellCmd);
447 if (sysret != 0) {
448 G4String errmsg = "\"" + shellCmd + "\" returns non-zero value. Directory creation failed.";
449 G4Exception("GrRunManager::SetRandomNumberStoreDir", "Run0071", JustWarning, errmsg);
450 G4cerr << " return value = " << sysret << G4endl;
451 }
452 }

◆ SetRandomNumberStorePerEvent()

void G4RunManager::SetRandomNumberStorePerEvent ( G4bool flag)
inline

Definition at line 466 of file G4RunManager.hh.

466{ rngStatusEventsFlag = flag; }

◆ SetRunIDCounter()

void G4RunManager::SetRunIDCounter ( G4int i)
inline

◆ SetSubEventType()

virtual void G4RunManager::SetSubEventType ( G4int )
inlinevirtual

Reimplemented in G4WorkerSubEvtRunManager.

Definition at line 567 of file G4RunManager.hh.

568 {
569 G4Exception("G4RunManager::SetSubEventType","RunSE1011",FatalException,
570 "Base class method is invoked for RunManager that is not a worker in sub-event parallel mode");
571 }

◆ SetUserAction() [1/6]

void G4RunManager::SetUserAction ( G4UserEventAction * userAction)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 975 of file G4RunManager.cc.

976{
977 eventManager->SetUserAction(userAction);
978 userEventAction = userAction;
979}

◆ SetUserAction() [2/6]

◆ SetUserAction() [3/6]

void G4RunManager::SetUserAction ( G4UserStackingAction * userAction)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 982 of file G4RunManager.cc.

983{
984 eventManager->SetUserAction(userAction);
985 userStackingAction = userAction;
986}

◆ SetUserAction() [4/6]

void G4RunManager::SetUserAction ( G4UserSteppingAction * userAction)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 996 of file G4RunManager.cc.

997{
998 eventManager->SetUserAction(userAction);
999 userSteppingAction = userAction;
1000}

◆ SetUserAction() [5/6]

void G4RunManager::SetUserAction ( G4UserTrackingAction * userAction)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 989 of file G4RunManager.cc.

990{
991 eventManager->SetUserAction(userAction);
992 userTrackingAction = userAction;
993}

◆ SetUserAction() [6/6]

void G4RunManager::SetUserAction ( G4VUserPrimaryGeneratorAction * userAction)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 969 of file G4RunManager.cc.

970{
971 userPrimaryGeneratorAction = userAction;
972}

◆ SetUserInitialization() [1/5]

void G4RunManager::SetUserInitialization ( G4UserWorkerInitialization * userInit)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 940 of file G4RunManager.cc.

941{
942 G4Exception("G4RunManager::SetUserInitialization()", "Run3001", FatalException,
943 "Base-class G4RunManager cannot take G4UserWorkerInitialization. Use "
944 "G4MTRunManager.");
945}

◆ SetUserInitialization() [2/5]

void G4RunManager::SetUserInitialization ( G4UserWorkerThreadInitialization * userInit)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 948 of file G4RunManager.cc.

949{
950 G4Exception("G4RunManager::SetUserThreadInitialization()", "Run3001", FatalException,
951 "Base-class G4RunManager cannot take G4UserWorkerThreadInitialization. "
952 "Use G4MTRunManager.");
953}

◆ SetUserInitialization() [3/5]

void G4RunManager::SetUserInitialization ( G4VUserActionInitialization * userInit)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 956 of file G4RunManager.cc.

957{
958 userActionInitialization = userInit;
960}

◆ SetUserInitialization() [4/5]

◆ SetUserInitialization() [5/5]

void G4RunManager::SetUserInitialization ( G4VUserPhysicsList * userInit)
virtual

Reimplemented in G4MTRunManager, G4SubEvtRunManager, G4WorkerRunManager, and G4WorkerSubEvtRunManager.

Definition at line 933 of file G4RunManager.cc.

934{
935 physicsList = userInit;
936 kernel->SetPhysics(userInit);
937}

◆ SetVerboseLevel()

void G4RunManager::SetVerboseLevel ( G4int vl)
inline

Definition at line 469 of file G4RunManager.hh.

470 {
471 verboseLevel = vl;
472 kernel->SetVerboseLevel(vl);
473 }

◆ StackPreviousEvent()

void G4RunManager::StackPreviousEvent ( G4Event * anEvent)
protectedvirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 578 of file G4RunManager.cc.

579{
580 if (anEvent->ToBeKept()) currentRun->StoreEvent(anEvent);
581
583 if (anEvent->GetNumberOfGrips() == 0) {
584 if (!(anEvent->ToBeKept())) {
585 ReportEventDeletion(anEvent);
586 delete anEvent;
587 }
588 }
589 else {
590 previousEvents->push_back(anEvent);
591 }
592 }
593 else {
594 previousEvents->push_back(anEvent);
595 }
596
598}

Referenced by TerminateOneEvent().

◆ StoreRandomNumberStatusToG4Event()

void G4RunManager::StoreRandomNumberStatusToG4Event ( G4int vl)
inline

Definition at line 421 of file G4RunManager.hh.

422 {
424 eventManager->StoreRandomNumberStatusToG4Event(vl);
425 }

◆ StoreRNGStatus()

void G4RunManager::StoreRNGStatus ( const G4String & filenamePrefix)
protectedvirtual

Reimplemented in G4MTRunManager, G4TaskRunManager, G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 481 of file G4RunManager.cc.

482{
483 G4String fileN = randomNumberStatusDir + fnpref + ".rndm";
484 G4Random::saveEngineStatus(fileN);
485}

Referenced by GenerateEvent(), and RunInitialization().

◆ SubEventFinished()

virtual void G4RunManager::SubEventFinished ( const G4SubEvent * ,
const G4Event *  )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 556 of file G4RunManager.hh.

557 {
558 G4Exception("G4RunManager::SubEventFinished","RunSE1003",FatalException,
559 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
560 }

◆ TerminateEventLoop()

void G4RunManager::TerminateEventLoop ( )
virtual

Reimplemented in G4WorkerRunManager, G4WorkerSubEvtRunManager, and G4WorkerTaskRunManager.

Definition at line 428 of file G4RunManager.cc.

429{
430 if (verboseLevel > 0 && !fakeRun) {
431 timer->Stop();
432 G4cout << " Run terminated." << G4endl;
433 G4cout << "Run Summary" << G4endl;
434 if (runAborted) {
435 G4cout << " Run Aborted after " << numberOfEventProcessed << " events processed." << G4endl;
436 }
437 else {
438 G4cout << " Number of events processed : " << numberOfEventProcessed << G4endl;
439 }
440 G4cout << " " << *timer << G4endl;
441 }
443}

Referenced by DoEventLoop(), G4MTRunManager::RunTermination(), G4SubEvtRunManager::RunTermination(), and G4TaskRunManager::RunTermination().

◆ TerminateOneEvent()

void G4RunManager::TerminateOneEvent ( )
virtual

◆ TrajectoriesToBeMerged()

virtual void G4RunManager::TrajectoriesToBeMerged ( G4bool )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 574 of file G4RunManager.hh.

575 {
576 G4Exception("G4RunManager::TrajectoriesToBeMerged","RunSE1001",FatalException,
577 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
578 }

◆ UpdateScoring()

void G4RunManager::UpdateScoring ( const G4Event * evt = nullptr)
protected

Definition at line 863 of file G4RunManager.cc.

864{
865 if(evt==nullptr) evt = currentEvent;
866
867//MAMAMAMA need revisiting
868 if(evt->ScoresAlreadyRecorded()) return;
869//MAMAMAMA need revisiting
870
873 }
874
875 if(evt->ScoresAlreadyRecorded()) {
876 G4Exception("G4RunManager::UpdateScoring()","RMSubEvt001",FatalException,
877 "Double-counting!!!");
878 }
879
880 evt->ScoresRecorded();
881
882 G4ScoringManager* ScM = G4ScoringManager::GetScoringManagerIfExist();
883 if (ScM == nullptr) return;
884 auto nPar = (G4int)ScM->GetNumberOfMesh();
885 if (nPar < 1) return;
886
887 G4HCofThisEvent* HCE = evt->GetHCofThisEvent();
888 if (HCE == nullptr) return;
889 auto nColl = (G4int)HCE->GetCapacity();
890 for (G4int i = 0; i < nColl; ++i) {
891 G4VHitsCollection* HC = HCE->GetHC(i);
892 if (HC != nullptr) ScM->Accumulate(HC);
893 }
894}
G4HCofThisEvent * GetHCofThisEvent() const
Definition G4Event.hh:164
G4bool ScoresAlreadyRecorded() const
Definition G4Event.hh:302
void ScoresRecorded() const
Definition G4Event.hh:301
std::size_t GetCapacity()
G4VHitsCollection * GetHC(G4int i)
void Accumulate(G4VHitsCollection *map)
virtual void Fill(G4HCofThisEvent *hce, G4int eventNumber)=0

Referenced by G4SubEvtRunManager::CleanUpUnnecessaryEvents(), ProcessOneEvent(), G4WorkerRunManager::ProcessOneEvent(), G4WorkerSubEvtRunManager::ProcessOneEvent(), G4WorkerTaskRunManager::ProcessOneEvent(), and G4SubEvtRunManager::StackPreviousEvent().

◆ UpdateScoringForSubEvent()

virtual void G4RunManager::UpdateScoringForSubEvent ( const G4SubEvent * ,
const G4Event *  )
inlinevirtual

Reimplemented in G4SubEvtRunManager.

Definition at line 544 of file G4RunManager.hh.

545 {
546 G4Exception("G4RunManager::UpdateScoringForSubEvent","RunSE1001",FatalException,
547 "Base class method is invoked for a RunManager that is not sub-event parallel mode");
548 }

Friends And Related Symbol Documentation

◆ G4RunManagerFactory

friend class G4RunManagerFactory
friend

Definition at line 139 of file G4RunManager.hh.

Referenced by G4RunManagerFactory.

Member Data Documentation

◆ currentEvent

◆ currentRun

◆ currentWorld

G4VPhysicalVolume* G4RunManager::currentWorld = nullptr
protected

Definition at line 653 of file G4RunManager.hh.

◆ DCtable

◆ eventManager

◆ fakeRun

◆ fGeometryHasBeenDestroyed

◆ geometryDirectlyUpdated

G4bool G4RunManager::geometryDirectlyUpdated = false
protected

Definition at line 664 of file G4RunManager.hh.

Referenced by GeometryDirectlyUpdated(), and InitializeGeometry().

◆ geometryInitialized

G4bool G4RunManager::geometryInitialized = false
protected

◆ geometryToBeOptimized

G4bool G4RunManager::geometryToBeOptimized = true
protected

Definition at line 632 of file G4RunManager.hh.

Referenced by GetGeometryToBeOptimized(), and SetGeometryToBeOptimized().

◆ initializedAtLeastOnce

G4bool G4RunManager::initializedAtLeastOnce = false
protected

Definition at line 631 of file G4RunManager.hh.

Referenced by ConfirmBeamOnCondition(), and Initialize().

◆ isScoreNtupleWriter

◆ kernel

◆ msgText

◆ n_perviousEventsToBeStored

◆ n_select_msg

◆ nParallelWorlds

G4int G4RunManager::nParallelWorlds = 0
protected

Definition at line 655 of file G4RunManager.hh.

Referenced by GetNumberOfParallelWorld(), and InitializeGeometry().

◆ numberOfEventProcessed

◆ numberOfEventToBeProcessed

◆ physicsInitialized

G4bool G4RunManager::physicsInitialized = false
protected

Definition at line 629 of file G4RunManager.hh.

Referenced by ConfirmBeamOnCondition(), Initialize(), and InitializePhysics().

◆ physicsList

◆ previousEvents

◆ printModulo

◆ randomNumberStatusDir

◆ randomNumberStatusForThisEvent

◆ randomNumberStatusForThisRun

◆ rngStatusEventsFlag

◆ runAborted

◆ runIDCounter

◆ runManagerType

◆ selectMacro

◆ storeRandomNumberStatus

◆ storeRandomNumberStatusToG4Event

◆ timer

◆ userActionInitialization

◆ userDetector

◆ userEventAction

◆ userPrimaryGeneratorAction

◆ userRunAction

◆ userStackingAction

G4UserStackingAction* G4RunManager::userStackingAction = nullptr
protected

Definition at line 624 of file G4RunManager.hh.

Referenced by GetUserStackingAction(), and SetUserAction().

◆ userSteppingAction

G4UserSteppingAction* G4RunManager::userSteppingAction = nullptr
protected

Definition at line 626 of file G4RunManager.hh.

Referenced by GetUserSteppingAction(), and SetUserAction().

◆ userTrackingAction

G4UserTrackingAction* G4RunManager::userTrackingAction = nullptr
protected

Definition at line 625 of file G4RunManager.hh.

Referenced by GetUserTrackingAction(), and SetUserAction().

◆ userWorkerInitialization

◆ userWorkerThreadInitialization

◆ verboseLevel


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