41 #ifndef G4MULTITHREADED
43 msg<<
"Geant4 code is compiled without multi-threading support (-DG4MULTITHREADED is set to off).";
44 msg<<
" This type of RunManager can only be used in mult-threaded applications.";
59 msg<<
"G4MTRunManagerKernel is to be deleted while "
61 G4Exception(
"G4RunManagerKernel::~G4RunManagerKernel()",
143 G4Exception(
"G4MTRunManagerKernel::StarThread",
"Run0035",
JustWarning,
"Cannot set thread affinity, affinity parameter larger than number of cores");
147 G4Exception(
"G4MTRunManagerKernel::StarThread",
"Run0035",
JustWarning,
"Affinity parameter==0, using 1 instead.");
156 cpuindex = myidx + (myidx>=offset);
160 #if defined(G4MULTITHREADED)
203 wrm->G4RunManager::SetUserInitialization(const_cast<G4VUserDetectorConstruction*>(detector));
226 if(skipInitialization)
229 skipInitialization =
false;
240 std::vector<G4String>::const_iterator it = cmds.begin();
241 for(;it!=cmds.end();it++)
247 if ( macroFile ==
"" || macroFile ==
" " )
253 wrm->
BeamOn(numevents,macroFile,numSelect);
259 d<<
"Cannot continue, this worker has been requested an unknwon action: "
276 std::vector<G4WorkerRunManager*>::iterator itrWrm =
workerRMvector->begin();
290 return static_cast<void*
>(0);
383 for(
G4int i=0;i<nCh;i++)
392 std::vector<G4WorkerRunManager*>::iterator itr =
workerRMvector->begin();
394 { (*itr)->AbortRun(softAbort); }
static void * StartThread(void *context)
G4bool G4SetPinAffinity(G4int idx, G4Thread &at)
std::vector< G4String > GetCommandStack()
virtual void SetupShadowProcess() const
void SetMultithreadedApplication(G4bool value)
void SetUpDecayChannels()
void SetUpForAThread(G4int tId)
std::ostringstream G4ExceptionDescription
virtual void SetupRNGEngine(const CLHEP::HepRandomEngine *aRNGEngine) const
static void UpdateGeometryAndPhysicsVectorFromMaster()
virtual void WorkerInitialize() const
G4String GetSelectMacro() const
const G4VUserDetectorConstruction * GetUserDetectorConstruction() const
static std::vector< G4WorkerRunManager * > * workerRMvector
virtual void WorkerStart() const
G4ParticleDefinition * GetDaughter(G4int anIndex)
static void BuildGeometryAndPhysicsVector()
void G4SetThreadId(G4int aNewValue)
virtual void BeamOn(G4int n_event, const char *macroFile=0, G4int n_select=-1)
G4VDecayChannel * GetDecayChannel(G4int index) const
const G4UserWorkerInitialization * GetUserWorkerInitialization() const
virtual G4WorkerRunManager * CreateWorkerRunManager() const
virtual void SetUserInitialization(G4VUserPhysicsList *userInit)
virtual ~G4MTRunManagerKernel()
#define G4MUTEX_INITIALIZER
static G4UImanager * GetUIpointer()
void SetupShadowProcess() const
G4GLOB_DLL std::ostream G4cout
void reset(G4bool ifSkipIon=true)
static G4WorkerThread * GetWorkerThread()
static G4MTRunManager * GetMasterRunManager()
G4int G4GetNumberOfCores()
virtual WorkerActionRequest ThisWorkerWaitForNextAction()
#define G4THREADSELF(nothing)
virtual void Build() const =0
G4int GetPinAffinity() const
G4int GetThreadId() const
G4int GetNumberOfEventsToBeProcessed() const
const G4VUserActionInitialization * GetUserActionInitialization() const
static G4ThreadLocal G4WorkerThread * wThreadContext
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
G4int GetNumberOfSelectEvents() const
void SetWorkerThread(G4WorkerThread *wc)
Sets the worker context.
const G4UserWorkerThreadInitialization * GetUserWorkerThreadInitialization() const
static void SetInstance(G4VSteppingVerbose *Instance)
static G4ParticleTable * GetParticleTable()
virtual void WorkerStop() const
G4VUserActionInitialization * GetNonConstUserActionInitialization() const
const CLHEP::HepRandomEngine * getMasterRandomEngine() const
virtual G4VSteppingVerbose * InitializeSteppingVerbose() const
static void DestroyGeometryAndPhysicsVector()
virtual void Initialize()
const G4VUserPhysicsList * GetUserPhysicsList() const
void BroadcastAbortRun(G4bool softAbort)
G4PTblDicIterator * GetIterator() const
G4int ApplyCommand(const char *aCommand)