44#ifndef G4SteppingManager_hh
45#define G4SteppingManager_hh 1
170 void DefinePhysicalStepLength();
174 void InvokeAtRestDoItProcs();
175 void InvokeAlongStepDoItProcs();
176 void InvokePostStepDoItProcs();
177 void InvokePSDIP(
size_t);
178 G4int ProcessSecondariesFromParticleChange();
184 static const size_t SizeOfSelectedDoItVector = 100;
186 G4bool KillVerbose =
false;
195 G4bool PreStepPointIsGeom =
false;
227 std::size_t MAXofAtRestLoops = 0;
228 std::size_t MAXofAlongStepLoops = 0;
229 std::size_t MAXofPostStepLoops = 0;
231 std::size_t fAtRestDoItProcTriggered = 0;
232 std::size_t fAlongStepDoItProcTriggered = 0;
233 std::size_t fPostStepDoItProcTriggered = 0;
235 G4int fN2ndariesAtRestDoIt = 0;
236 G4int fN2ndariesAlongStepDoIt = 0;
237 G4int fN2ndariesPostStepDoIt = 0;
243 G4int verboseLevel = 0;
289 return GeometricalStep;
294 return CorrectedStep;
299 return PreStepPointIsGeom;
314 return TempInitVelocity;
329 return sumEnergyChange;
334 return fParticleChange;
354 return fPreStepPoint;
359 return fPostStepPoint;
364 return fCurrentVolume;
374 return fCurrentProcess;
379 return fAtRestDoItVector;
384 return fAlongStepDoItVector;
389 return fPostStepDoItVector;
394 return fAtRestGetPhysIntVector;
399 return fAlongStepGetPhysIntVector;
404 return fPostStepGetPhysIntVector;
409 return MAXofAtRestLoops;
414 return MAXofAlongStepLoops;
419 return MAXofPostStepLoops;
424 return fAtRestDoItProcTriggered;
429 return fAtRestDoItProcTriggered;
434 return fPostStepDoItProcTriggered;
439 return fN2ndariesAtRestDoIt;
444 return fN2ndariesAlongStepDoIt;
449 return fN2ndariesPostStepDoIt;
465 return fSelectedAtRestDoItVector;
471 return fSelectedAlongStepDoItVector;
477 return fSelectedPostStepDoItVector;
482 return fPreviousStepSize;
487 return fTouchableHandle;
492 return StepControlFlag;
497 return physIntLength;
507 return fGPILSelection;
522 fUserSteppingAction = apAction;
527 return fUserSteppingAction;
537 verboseLevel = vLevel;
542 fVerbose = yourVerbose;
550 inline G4double G4SteppingManager::CalculateSafety()
552 return std::max( endpointSafety -
553 (endpointSafOrigin - fPostStepPoint->
GetPosition()).mag(),
@ NotCandidateForSelection
class std::vector< int, std::allocator< int > > G4SelectedPostStepDoItVector
class std::vector< int, std::allocator< int > > G4SelectedAtRestDoItVector
class std::vector< int, std::allocator< int > > G4SelectedAlongStepDoItVector
std::vector< G4int > G4SelectedPostStepDoItVector
std::vector< G4int > G4SelectedAtRestDoItVector
std::vector< G4int > G4SelectedAlongStepDoItVector
std::vector< G4Track * > G4TrackVector
const G4ThreeVector & GetPosition() const
G4TrackVector * GetfSecondary()
G4ProfilerConfig< G4ProfileType::Step > ProfilerConfig
const G4TrackVector * GetSecondary() const
G4ProcessVector * GetfPostStepDoItVector()
std::size_t GetfAtRestDoItProcTriggered()
std::size_t GetMAXofAtRestLoops()
G4TrackVector * GetfSecondary()
void SetVerbose(G4VSteppingVerbose *)
std::size_t GetMAXofAlongStepLoops()
G4SteppingControl GetStepControlFlag()
std::size_t GetMAXofPostStepLoops()
G4SelectedPostStepDoItVector * GetfSelectedPostStepDoItVector()
G4Navigator * GetfNavigator()
G4Track * GetTrack() const
G4VPhysicalVolume * GetfCurrentVolume()
G4StepPoint * GetfPreStepPoint()
G4double GetPhysicalStep()
G4int GetfN2ndariesPostStepDoIt()
G4ProcessVector * GetfAlongStepDoItVector()
G4VParticleChange * GetfParticleChange()
std::size_t GetfPostStepDoItProcTriggered()
void SetNavigator(G4Navigator *value)
std::size_t GetfAlongStepDoItProcTriggered()
void SetVerboseLevel(G4int vLevel)
G4double GetfPreviousStepSize()
G4SelectedAlongStepDoItVector * GetfSelectedAlongStepDoItVector()
G4ForceCondition GetfCondition()
G4ProcessVector * GetfAlongStepGetPhysIntVector()
G4double GetCorrectedStep()
void SetInitialStep(G4Track *valueTrack)
G4double GetsumEnergyChange()
G4double GetTempInitVelocity()
G4VSensitiveDetector * GetfSensitive()
G4int GetfN2ndariesAtRestDoIt()
G4ProcessVector * GetfAtRestDoItVector()
G4StepStatus GetfStepStatus()
G4SelectedAtRestDoItVector * GetfSelectedAtRestDoItVector()
G4int GetfN2ndariesAlongStepDoIt()
G4double GetnumberOfInteractionLengthLeft()
G4GPILSelection GetfGPILSelection()
G4ProcessVector * GetfAtRestGetPhysIntVector()
G4double GetTempVelocity()
G4bool GetPreStepPointIsGeom()
G4double GetphysIntLength()
G4double GetcurrentMinimumStep()
G4ProcessVector * GetfPostStepGetPhysIntVector()
G4StepPoint * GetfPostStepPoint()
G4UserSteppingAction * GetUserAction()
void SetUserAction(G4UserSteppingAction *apAction)
G4VProcess * GetfCurrentProcess()
const G4TouchableHandle & GetTouchableHandle()
G4double GetGeometricalStep()
const G4TrackVector * GetSecondary() const