49#ifndef G4UrbanMscModel96_h
50#define G4UrbanMscModel96_h 1
109 inline void UpdateCache();
158 G4int currentMaterialIndex;
163 G4double coeffc1,coeffc2,coeffc3,coeffc4;
182 ChargeSquare = charge*charge;
189void G4UrbanMscModel96::UpdateCache()
191 lnZ = std::log(Zeff);
195 coeffc1 = 2.3785 - Z13*(4.1981e-1 - Z13*6.3100e-2);
196 coeffc2 = 4.7526e-1 + Z13*(1.7694 - Z13*3.3885e-1);
197 coeffc3 = 2.3683e-1 - Z13*(1.8111 - Z13*3.2774e-1);
198 coeffc4 = 1.7888e-2 + Z13*(1.9659e-2 - Z13*2.6664e-3);
204 scr2 = scr2ini*Z2*ChargeSquare;
G4double GetPDGMass() const
G4double GetPDGCharge() const
G4double ComputeGeomPathLength(G4double truePathLength)
G4ThreeVector & SampleScattering(const G4DynamicParticle *, G4double safety)
G4double ComputeTrueStepLength(G4double geomStepLength)
G4double ComputeTruePathLengthLimit(const G4Track &track, G4double ¤tMinimalStep)
void Initialise(const G4ParticleDefinition *, const G4DataVector &)
virtual ~G4UrbanMscModel96()
G4double ComputeTheta0(G4double truePathLength, G4double KineticEnergy)
G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *particle, G4double KineticEnergy, G4double AtomicNumber, G4double AtomicWeight=0., G4double cut=0., G4double emax=DBL_MAX)
void StartTracking(G4Track *)