84#ifdef theParticleIterator
85# undef theParticleIterator
93 return fRunManagerKernel;
100 InvalidOperationDetection();
105 if (_signals.empty()) {
114 if (allocList !=
nullptr) numberOfStaticAllocators = (
G4int)allocList->
Size();
119 if (fRunManagerKernel !=
nullptr) {
121 "More than one G4RunManagerKernel is constructed.");
123 fRunManagerKernel =
this;
126 if (particleTable->
entries() > 0) {
129 ED <<
"!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" <<
G4endl;
130 ED <<
" G4RunManagerKernel fatal exception" <<
G4endl;
131 ED <<
" -- Following particles have already been registered" <<
G4endl;
132 ED <<
" before G4RunManagerKernel is instantiated." <<
G4endl;
136 ED <<
"!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" <<
G4endl;
145 new G4Region(
"DefaultRegionForParallelWorld");
157 vs = vs.substr(1, vs.size() - 2);
158 versionString =
" Geant4 version ";
160 versionString +=
" ";
161 versionString += G4Date;
162 G4cout <<
G4endl <<
"**************************************************************" <<
G4endl
163 << versionString <<
G4endl <<
" Copyright : Geant4 Collaboration"
164 <<
G4endl <<
" References : NIM A 506 (2003), 250-303" <<
G4endl
165 <<
" : IEEE-TNS 53 (2006), 270-278" <<
G4endl
166 <<
" : NIM A 835 (2016), 186-225" <<
G4endl
167 <<
" WWW : http://geant4.org/" <<
G4endl
168 <<
"**************************************************************" <<
G4endl <<
G4endl;
175#ifndef G4MULTITHREADED
177 msg <<
"Geant4 code is compiled without multi-threading support "
178 "(-DG4MULTITHREADED is set to off).";
179 msg <<
" This type of RunManagerKernel can only be used in mult-threaded "
186 InvalidOperationDetection();
192 if (_signals.empty()) {
204 if (fRunManagerKernel !=
nullptr) {
206 "More than one G4RunManagerKernel is constructed.");
208 fRunManagerKernel =
this;
217 new G4Region(
"DefaultRegionForParallelWorld");
233 msgx <<
" This type of RunManagerKernel can only be used in mult-threaded "
245 vs = vs.substr(1, vs.size() - 2);
248 versionString =
" Geant4 version ";
250 versionString +=
" ";
251 versionString += G4Date;
252 G4cout <<
G4endl <<
"**************************************************************" <<
G4endl
253 << versionString <<
G4endl <<
" << in Multi-threaded mode >> " <<
G4endl
254 <<
" Copyright : Geant4 Collaboration" <<
G4endl
255 <<
" References : NIM A 506 (2003), 250-303" <<
G4endl
256 <<
" : IEEE-TNS 53 (2006), 270-278" <<
G4endl
257 <<
" : NIM A 835 (2016), 186-225" <<
G4endl
258 <<
" WWW : http://geant4.org/" <<
G4endl
259 <<
"**************************************************************" <<
G4endl
263 if (verboseLevel != 0) {
264 versionString =
" Local thread RunManagerKernel version ";
267 <<
"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^"
270 <<
"^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^"
276#ifdef G4MULTITHREADED
290 "Default world region should have a unique logical volume.");
294 if (verboseLevel > 1)
295 G4cout <<
"Obsolete world logical volume is removed from the default region." <<
G4endl;
305 if (verboseLevel > 1)
G4cout <<
"G4 kernel has come to Quit state." <<
G4endl;
315 if (verboseLevel > 1)
G4cout <<
"G4SDManager deleted." <<
G4endl;
317 if (verboseLevel > 1)
G4cout <<
"EventManager deleted." <<
G4endl;
320 if (verboseLevel > 1)
G4cout <<
"Units table cleared." <<
G4endl;
328 if (verboseLevel > 1)
G4cout <<
"TransportationManager deleted." <<
G4endl;
337 if (verboseLevel > 1)
G4cout <<
"G4RNGHelper object is deleted." <<
G4endl;
342 if (allocList !=
nullptr) {
343 allocList->
Destroy(numberOfStaticAllocators, verboseLevel);
345 if (verboseLevel > 1)
G4cout <<
"G4Allocator objects are deleted." <<
G4endl;
350 G4cout <<
"Thread-local UImanager is to be deleted." <<
G4endl
351 <<
"There should not be any thread-local G4cout/G4cerr hereafter." <<
G4endl;
354 if (verboseLevel > 1)
G4cout <<
"UImanager deleted." <<
G4endl;
356 delete pStateManager;
357 if (verboseLevel > 1)
G4cout <<
"StateManager deleted." <<
G4endl;
358 delete defaultExceptionHandler;
359 if (verboseLevel > 1)
G4cout <<
"RunManagerKernel is deleted. Good bye :)" <<
G4endl;
360 fRunManagerKernel =
nullptr;
369 for (
const auto& masterWorld : masterWorlds) {
373 if (pWorld ==
nullptr) {
389 G4Exception(
"G4RunManagerKernel::DefineWorldVolume",
"DefineWorldVolumeAtIncorrectState",
390 FatalException,
"Geant4 kernel is not Init state : Method ignored.");
397 currentWorld = worldVol;
401 for (
const auto& masterWorld : masterWorlds) {
402 if (masterWorld.first == 0) {
403 if (masterWorld.second != currentWorld) {
405 "Mass world is inconsistent");
422 geometryInitialized =
true;
424 if (physicsInitialized && currentState !=
G4State_Idle) {
439 G4Exception(
"G4RunManagerKernel::DefineWorldVolume",
"DefineWorldVolumeAtIncorrectState",
440 FatalException,
"Geant4 kernel is not Init state : Method ignored.");
451 ED <<
"The world volume has a user-defined region <"
453 ED <<
"World would have a default region assigned by RunManagerKernel." <<
G4endl;
461 currentWorld = worldVol;
468 if (verboseLevel > 1)
481 geometryInitialized =
true;
483 if (physicsInitialized && currentState !=
G4State_Idle) {
497 if (verboseLevel > 1) {
498 G4cout <<
"List of instantiated particles "
499 "============================================"
502 for (
G4int i = 0; i < nPtcl; ++i) {
516 physicsList->ConstructParticle();
521 if (gion !=
nullptr) {
533 if (gion !=
nullptr) {
541#ifdef G4MULTITHREADED
561 G4Exception(
"G4RunManagerKernel::InitializePhysics",
"InitializePhysicsIncorrectState",
562 FatalException,
"Geant4 kernel is not Init state : Method ignored.");
566 G4cout <<
"Warning : Geant4 kernel is not Init state : Assuming Init state." <<
G4endl;
570 if (physicsList ==
nullptr) {
572 "G4VUserPhysicsList is not defined");
576 if (verboseLevel > 1)
G4cout <<
"physicsList->Construct() start." <<
G4endl;
577 if (numberOfParallelWorld > 0) physicsList->UseCoupledTransportation();
578 physicsList->Construct();
580 if (verboseLevel > 1)
G4cout <<
"physicsList->CheckParticleList() start." <<
G4endl;
581 physicsList->CheckParticleList();
587 if (verboseLevel > 1)
G4cout <<
"physicsList->setCut() start." <<
G4endl;
588 physicsList->SetCuts();
593 physicsInitialized =
true;
595#ifdef G4MULTITHREADED
600 if (geometryInitialized && currentState !=
G4State_Idle) {
611 if (!geometryInitialized) {
613 "Geometry has not yet initialized : method ignored.");
617 if (!physicsInitialized) {
619 "Physics has not yet initialized : method ignored.");
625 "Geant4 kernel not in Idle state : method ignored.");
649#ifdef G4MULTITHREADED
662 if (gion !=
nullptr) {
701 if (verboseLevel > 1)
G4cout <<
"Start closing geometry." <<
G4endl;
704 geomManager->
CloseGeometry(geometryToBeOptimized, verboseLevel > 1);
716 "Geant4 kernel not in Init state : method ignored.");
733#ifdef G4MULTITHREADED
740 physicsList->BuildPhysicsTable();
741 physicsNeedsToBeReBuilt =
false;
744 if (!fakeRun && verboseLevel > 1)
DumpRegion();
745 if (!fakeRun && verboseLevel > 0) physicsList->DumpCutValuesTable();
746 if (!fakeRun) physicsList->DumpCutValuesTableIfRequested();
754 std::vector<G4VPhysicalVolume*>::iterator wItr;
760 region->SetWorld(
nullptr);
761 region->UsedInMassGeometry(
false);
762 region->UsedInParallelGeometry(
false);
764 for (std::size_t iw = 0; iw < nWorlds; ++iw) {
765 if (region->BelongsTo(*wItr)) {
766 if (*wItr == currentWorld) {
767 region->UsedInMassGeometry(
true);
770 region->UsedInParallelGeometry(
true);
773 region->SetWorld(*wItr);
778 if (cuts ==
nullptr) {
779 if (region->IsInMassGeometry() && verboseLevel > 0) {
780 G4cout <<
"Warning : Region <" << region->GetName()
781 <<
"> does not have specific production cuts," <<
G4endl
782 <<
"even though it appears in the current tracking world." <<
G4endl;
783 G4cout <<
"Default cuts are used for this region." <<
G4endl;
786 if (region->IsInMassGeometry() || region->IsInParallelGeometry()) {
787 region->SetProductionCuts(
798 for (std::size_t iw = 0; iw < nWorlds; ++iw) {
799 if (*wItr != currentWorld) {
820 if (region ==
nullptr) {
833 G4cout <<
" -- is not associated to any world.";
837 G4cout <<
" This region is in the mass world." <<
G4endl;
840 G4cout <<
" This region is in the parallel world." <<
G4endl;
843 G4cout <<
" Root logical volume(s) : ";
846 for (std::size_t j = 0; j < nRootLV; ++j) {
847 G4cout << (*lvItr)->GetName() <<
" ";
853 <<
"], G4UserLimits[" << region->
GetUserLimits() <<
"], G4FastSimulationManager["
857 G4cout <<
" Materials : ";
860 for (std::size_t iMate = 0; iMate < nMaterial; ++iMate) {
861 G4cout << (*mItr)->GetName() <<
" ";
868 <<
"> does not have specific production cuts." <<
G4endl;
869 G4cerr <<
"Default cuts are used for this region." <<
G4endl;
873 else if (cuts !=
nullptr) {
874 G4cout <<
" Production cuts : "
884void G4RunManagerKernel::CheckRegularGeometry()
887 for (
const auto& pos : *store) {
888 if ((pos !=
nullptr) && (pos->GetNoDaughters() == 1)) {
889 if (pos->GetDaughter(0)->IsRegularStructure()) {
898G4bool G4RunManagerKernel::ConfirmCoupledTransportation()
908 G4VProcess* p = (*pv)[0];
916void G4RunManagerKernel::SetScoreSplitter()
918 auto pSplitter =
new G4ScoreSplittingProcess();
931 if (pmanager !=
nullptr) {
936 if (verboseLevel > 0) {
937 G4cout <<
"G4RunManagerKernel -- G4ScoreSplittingProcess is appended to all "
957 const G4VProcess* masterP = procs[idx]->GetMasterProcess();
958 if (masterP ==
nullptr) {
961 procs[idx]->SetMasterProcess(
const_cast<G4VProcess*
>(procs[idx]));
G4TemplateAutoLock< G4Mutex > G4AutoLock
_Tp G4GetEnv(const std::string &env_id, _Tp _default=_Tp())
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
#define G4MUTEX_INITIALIZER
#define theParticleIterator
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
static G4AllocatorList * GetAllocatorListIfExist()
void Destroy(G4int nStat=0, G4int verboseLevel=0)
static G4int Enable(const std::string &)
static G4FieldManagerStore * GetInstanceIfExist()
static G4Geantino * GeantinoDefinition()
static G4GeometryManager * GetInstance()
G4bool CloseGeometry(G4bool pOptimise=true, G4bool verbose=false, G4VPhysicalVolume *vol=nullptr)
G4bool IsParallelOptimisationConfigured()
void OpenGeometry(G4VPhysicalVolume *vol=nullptr)
void UndertakeOptimisation()
static G4GeometryManager * GetInstanceIfExist()
G4bool IsParallelOptimisationFinished()
static void ConstructParticle()
void InitializeLightIons()
static G4LogicalVolumeStore * GetInstance()
void SetRegion(G4Region *reg)
G4Region * GetRegion() const
const G4String & GetName() const
static G4MTRunManager * GetMasterRunManager()
std::map< G4int, G4VPhysicalVolume * > masterWorlds_t
static masterWorlds_t & GetMasterWorlds()
static G4NavigationHistoryPool * GetInstance()
static G4ParallelWorldProcessStore * GetInstanceIfExist()
G4ProcessManager * GetProcessManager() const
G4bool IsGeneralIon() const
void SetParticleDefinitionID(G4int id=-1)
G4int GetParticleDefinitionID() const
const G4String & GetParticleName() const
void reset(G4bool ifSkipIon=true)
G4IonTable * GetIonTable() const
G4ParticleDefinition * GetParticle(G4int index) const
G4PTblDicIterator * GetIterator() const
static G4ParticleTable * GetParticleTable()
void SetReadiness(G4bool val=true)
G4ParticleDefinition * GetGenericIon() const
void DumpTable(const G4String &particle_name="ALL")
static G4PathFinder * GetInstanceIfExist()
G4int AddDiscreteProcess(G4VProcess *aProcess, G4int ord=ordDefault)
G4ProcessVector * GetAlongStepProcessVector(G4ProcessVectorTypeIndex typ=typeGPIL) const
G4ProcessVector * GetProcessList() const
void UpdateCoupleTable(G4VPhysicalVolume *currentWorld)
void PhysicsTableUpdated()
static G4ProductionCutsTable * GetProductionCutsTable()
G4double GetProductionCut(G4int index) const
const std::vector< G4double > & GetProductionCuts() const
static G4RegionStore * GetInstance()
void UpdateMaterialList(G4VPhysicalVolume *currentWorld=nullptr)
G4Region * GetRegion(const G4String &name, G4bool verbose=true) const
std::size_t GetNumberOfRootVolumes() const
std::size_t GetNumberOfMaterials() const
G4FastSimulationManager * GetFastSimulationManager() const
G4VUserRegionInformation * GetUserInformation() const
G4bool IsInParallelGeometry() const
G4ProductionCuts * GetProductionCuts() const
G4VPhysicalVolume * GetWorldPhysical() const
void SetProductionCuts(G4ProductionCuts *cut)
G4UserLimits * GetUserLimits() const
const G4String & GetName() const
G4bool IsInMassGeometry() const
G4UserSteppingAction * GetRegionalSteppingAction() const
std::vector< G4Material * >::const_iterator GetMaterialIterator() const
std::vector< G4LogicalVolume * >::iterator GetRootLogicalVolumeIterator()
void SetupDefaultRegion()
G4PrimaryTransformer * GetPrimaryTransformer() const
G4Region * defaultRegionForParallelWorld
static G4RunManagerKernel * GetRunManagerKernel()
void SetPhysics(G4VUserPhysicsList *uPhys)
RMKType runManagerKernelType
void WorkerUpdateWorldVolume()
void DefineWorldVolume(G4VPhysicalVolume *worldVol, G4bool topologyIsChanged=true)
void PropagateGenericIonID()
G4bool RunInitialization(G4bool fakeRun=false)
void WorkerDefineWorldVolume(G4VPhysicalVolume *worldVol, G4bool topologyIsChanged=true)
virtual void SetupShadowProcess() const
virtual ~G4RunManagerKernel()
void DumpRegion(const G4String &rname) const
G4bool geometryNeedsToBeClosed
void BuildPhysicsTables(G4bool fakeRun)
static G4SDManager * GetSDMpointerIfExist()
const G4ApplicationState & GetCurrentState() const
G4String GetStateString(const G4ApplicationState &aState) const
static G4StateManager * GetStateManager()
G4bool SetNewState(const G4ApplicationState &requestedState)
static G4TemplateRNGHelper< G4long > * GetInstanceIfExist()
G4bool RegisterWorld(G4VPhysicalVolume *aWorld)
static G4TransportationManager * GetTransportationManager()
static G4TransportationManager * GetInstanceIfExist()
G4VPhysicalVolume * IsWorldExisting(const G4String &worldName)
void SetWorldForTracking(G4VPhysicalVolume *theWorld)
std::vector< G4VPhysicalVolume * >::iterator GetWorldsIterator()
std::size_t GetNoWorlds() const
G4int ApplyCommand(const char *aCommand)
static G4UImanager * GetUIpointer()
static void ClearUnitsTable()
static G4UnitsTable & GetUnitsTable()
G4LogicalVolume * GetLogicalVolume() const
const G4String & GetName() const
const G4String & GetProcessName() const
static G4VVisManager * GetConcreteInstance()
virtual void GeometryHasChanged()=0