81{
82
83
84
85
86
87
88
89
90 if (averageLoss <
minLoss) {
return averageLoss; }
93
94
95 CLHEP::HepRandomEngine* rndmEngineF = G4Random::getTheEngine();
96
97 InitialiseLocal(dp);
102
104
105 const G4Material* material = couple->
GetMaterial();
106
107
108
109
110
113
114 siga = std::sqrt((tmax/beta2 - 0.5*tcut)*CLHEP::twopi_mc2_rcl2*
117
118
119 if (sn >= 2.0) {
120
122 do {
123 loss = G4RandGauss::shoot(rndmEngineF,
meanLoss, siga);
124
125 } while (0.0 > loss || twomeanLoss < loss);
126
127
128 } else {
129
131 loss =
meanLoss*G4RandGamma::shoot(rndmEngineF, neff, 1.0)/neff;
132 }
133
134 return loss;
135 }
136
138 e0 = ioni->GetEnergy0fluct();
139
140
142
143 ipotFluct = ioni->GetMeanExcitationEnergy();
145
146
147 const G4double scaling = std::min(1.+0.5*CLHEP::keV/tcut, 1.50);
149
151 G4Log(2.*CLHEP::electron_mass_c2*beta2*gam2) - beta2 : 0.0;
152 return SampleGlandz(rndmEngineF, material, tcut)*scaling;
153}
G4double G4Log(G4double x)
G4double GetKineticEnergy() const
const G4Material * GetMaterial() const
G4IonisParamMat * GetIonisation() const
G4double minNumberInteractionsBohr
virtual G4double SampleGlandz(CLHEP::HepRandomEngine *rndm, const G4Material *, const G4double tcut)
G4double m_Inv_particleMass