141 G4cout <<
G4endl <<
"XWrapperContinuousDiscreteProcess::";
142 G4cout <<
"ERROR - no ExExChParticleUserInfo object Detected";
168 vDensityPreviousStep =
174 G4cout <<
G4endl <<
"XWrapperContinuousDiscreteProcess::";
175 G4cout <<
"ERROR - no ExExChParticleUserInfo";
179 return vDensityPreviousStep;
229 }
else if ( previousStepSize > 0.0) {
232 * vDensityPreviousStep);
239 previousStepSize * vDensityPreviousStep,
248 currentInteractionLength /= vDensity;
263 previousStepSize * vDensityPreviousStep,
278 const_cast<G4Step&
>(aStep).SetStepLength(vStepLengthSaved);
291 const_cast<G4Step&
>(aStep).SetStepLength(vStepLengthSaved);
virtual ~XWrapperContinuousDiscreteProcess()
virtual G4double GetMeanFreePath(const G4Track &, G4double, G4ForceCondition *)
G4double condition(const G4ErrorSymMatrix &m)
virtual void StartTracking(G4Track *aTrack)
void RegisterProcess(G4VContinuousDiscreteProcess *)
G4double GetStepLength() const
G4VContinuousDiscreteProcess * fRegisteredProcess
virtual G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &)
G4double theNumberOfInteractionLengthLeft
G4double GetDensityPreviousStep(const G4Track &)
G4double GetNucleiDensity()
virtual G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double previousStepSize, G4double currentMinimumStep, G4double ¤tSafety, G4GPILSelection *selection)
G4VUserTrackInformation * GetUserInformation() const
virtual void StartTracking(G4Track *)
G4double GetDensity(const G4Track &)
G4double GetNumberOfInteractionLengthLeft() const
G4GLOB_DLL std::ostream G4cout
virtual G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &)
G4double currentInteractionLength
virtual void ResetNumberOfInteractionLengthLeft()
XWrapperContinuousDiscreteProcess(const G4String &processName="XWrapperContinuousDiscreteProcess")
virtual G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition)
virtual G4double GetContinuousStepLimit(const G4Track &, G4double, G4double, G4double &)
const G4String & GetProcessName() const
G4double GetNucleiDensityPreviousStep()
G4int GetNucleiOrElectronFlag()
virtual G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &)
virtual G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double, G4double, G4double &, G4GPILSelection *)
G4VParticleChange * pParticleChange
virtual G4double PostStepGetPhysicalInteractionLength(const G4Track &, G4double, G4ForceCondition *)
virtual G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &)
void SubtractNumberOfInteractionLengthLeft(G4double previousStepSize)
G4int bNucleiOrElectronFlag
G4double theInitialNumberOfInteractionLength
G4double GetElectronDensityPreviousStep()
void SetNucleiOrElectronFlag(G4int)
G4double GetElectronDensity()