50#ifndef G4PairProductionRelModel_h
51#define G4PairProductionRelModel_h 1
67 const G4String& nam =
"BetheHeitlerLPM");
218 screenVal = 21.12 - 4.184*std::log(delta+0.952);
220 screenVal = 20.868 - delta*(3.242 - 0.625*delta);
232 screenVal = 21.12 - 4.184*std::log(delta+0.952);
234 screenVal = 20.209 - delta*(1.930 + 0.086*delta);
246 if (ScreenVariable > 1.)
247 screenVal = 42.24 - 8.368*std::log(ScreenVariable+0.952);
249 screenVal = 42.392 - ScreenVariable*(7.796 - 1.961*ScreenVariable);
263 if (ScreenVariable > 1.)
264 screenVal = 42.24 - 8.368*std::log(ScreenVariable+0.952);
266 screenVal = 41.405 - ScreenVariable*(5.828 - 0.8945*ScreenVariable);
278 return std::exp( (42.24-FZ)/8.368 ) + 0.952;
283 return 4.*136./
z13*(CLHEP::electron_mass_c2/k);
G4double GetfCoulomb() const
G4double GetZ13(G4double Z)
G4double GetLOGZ(G4int Z)
void SetLPMconstant(G4double val)
static const G4double facFinel
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
G4ParticleDefinition * thePositron
static const G4double Finel_light[5]
G4double DeltaMax() const
static const G4double wgi[8]
void SetCurrentElement(G4double)
G4double LPMconstant() const
G4double ScreenFunction2(G4double ScreenVariable)
virtual void SetupForMaterial(const G4ParticleDefinition *, const G4Material *, G4double)
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0., G4double cut=0., G4double emax=DBL_MAX)
G4double ComputeRelDXSectionPerAtom(G4double eplusEnergy, G4double totalEnergy, G4double Z)
static const G4double preS1
G4ParticleDefinition * theElectron
static const G4double Fel_light[5]
static const G4double xgi[8]
G4PairProductionRelModel & operator=(const G4PairProductionRelModel &right)
G4PairProductionRelModel(const G4PairProductionRelModel &)
virtual ~G4PairProductionRelModel()
G4ParticleDefinition * theGamma
void CalcLPMFunctions(G4double k, G4double eplus)
G4double ComputeXSectionPerAtom(G4double totalEnergy, G4double Z)
G4bool use_completescreening
G4double ScreenFunction1(G4double ScreenVariable)
G4double ComputeDXSectionPerAtom(G4double eplusEnergy, G4double totalEnergy, G4double Z)
static const G4double logTwo
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4double Phi2(G4double delta) const
G4ParticleChangeForGamma * fParticleChange
G4double DeltaMin(G4double) const
G4double Phi1(G4double delta) const
static const G4double facFel
const G4Element * GetCurrentElement() const