37#ifndef G4ILawCommonTruncatedExp_hh
38#define G4ILawCommonTruncatedExp_hh 1
52 {
return fExpInteractionLaw.IsSingular(); }
54 {
return fExpInteractionLaw.IsEffectiveCrossSectionInfinite(); }
60 { fExpInteractionLaw.SetForceCrossSection( xs ); }
62 { fSelectedProcessXSfraction = fXS; }
64 {
return fSelectedProcessXSfraction; }
66 { fExpInteractionLaw.SetMaximumDistance(d); }
68 {
return fExpInteractionLaw.GetMaximumDistance(); }
70 {
return fExpInteractionLaw.GetInteractionDistance(); }
75 virtual G4double SampleInteractionLength();
84 G4double fSelectedProcessXSfraction = 0.0;
void SetForceCrossSection(G4double xs)
virtual ~G4ILawCommonTruncatedExp()
virtual G4double ComputeEffectiveCrossSectionAt(G4double length) const
G4double GetInteractionDistance() const
virtual G4double ComputeNonInteractionProbabilityAt(G4double length) const
G4double GetMaximumDistance() const
G4double SetSelectedProcessXSfraction() const
G4ILawCommonTruncatedExp(const G4String &name="expSharedForceInteractionLaw")
virtual G4bool IsEffectiveCrossSectionInfinite() const
void SetMaximumDistance(G4double d)
virtual G4bool IsSingular() const
void SetSelectedProcessXSfraction(G4double fXS)
G4VBiasingInteractionLaw(const G4String &name)