47 const G4double fAlpha = 0.5*CLHEP::fine_structure_const*CLHEP::hbarc;
48 const G4double fInvep = 1.0/CLHEP::eplus;
56 if(
A == 1) { R = 0.895*CLHEP::fermi; }
57 else if(
A == 2) { R = 2.13*CLHEP::fermi; }
58 else if(Z == 1 &&
A == 3) { R = 1.80*CLHEP::fermi; }
59 else if(Z == 2 &&
A == 3) { R = 1.96*CLHEP::fermi; }
60 else if(Z == 2 &&
A == 4) { R = 1.68*CLHEP::fermi; }
61 else if(Z == 3) { R = 2.40*CLHEP::fermi; }
62 else if(Z == 4) { R = 2.51*CLHEP::fermi; }
73 if(
A <= 15) { y = 1.26; }
74 else if(
A <= 20) { y = 1.19; }
75 else if(
A <= 30) { y = 1.12; }
90 R = 1.24*
fG4pow->powZ(
A, 0.28)*CLHEP::fermi;
112 const G4double c[3]={0.77329745, 1.38206072, 30.28295235};
127 return R*CLHEP::fermi;
143 return 1.3*CLHEP::fermi*
fG4pow->Z13(
A);
153 if (
A <= 3.) { R *= 0.8; }
163 G4int z = std::min(Z, 92);
173 if(pdg == 2112 || pdg == 2212) { R *= 0.895; }
174 else if(pdg == 211) { R *= 0.663; }
175 else if(pdg == 321) { R *= 0.340; }
189 G4double tZ = nucleon->GetPDGCharge()*fInvep;
192 G4double tM = nucleon->GetPDGMass();
195 G4double totTcm = std::sqrt(pM*pM + tM*tM + 2.*pElab*tM) - pM -tM;
197 G4double bC = fAlpha*pZ*tZ/(pR + tR);
198 return (totTcm > bC) ? 1. - bC/totTcm : 0.0;
215 G4double totTcm = std::sqrt(pM*pM + tM*tM + 2.*pElab*tM) - pM -tM;
217 G4double bC = fAlpha*pZ*Z/(pR + tR);
218 return (totTcm > bC) ? 1. - bC/totTcm : 0.0;
224 G4double A = (Z < 100) ? aeff[Z] : aeff[100];
230 G4double p7 = 3.0 - (
A - 70.)*(
A - 200.)/11000.;
235 return (1. + p3*firstexp/(1. + firstexp))/(1. + secondexp);
241 G4double A = (Z < 100) ? aeff[Z] : aeff[100];
246 G4double res = (1.0 + ff3*(1.0 - (1.0/(1+
G4Exp(-ff1*(elog + ff2))))));
247 ff1 = 8. - 8./
A - 0.008*
A;
248 ff2 = 2.34 - 5.4/
A - 0.0028*
A;
249 res /= (1.0 +
G4Exp(-ff1*(elog + ff2)));
255 1.3, 1.3, 1.3, 1.3,1.17,1.54,1.65,1.71, 1.7,1.75,
256 1.7,1.57,1.53, 1.4, 1.3,1.30,1.44, 1.4, 1.4, 1.4,
257 1.4, 1.4,1.46, 1.4, 1.4,1.46,1.55, 1.5,1.38,1.48,
258 1.4, 1.4, 1.4,1.46, 1.4, 1.4, 1.4, 1.4, 1.4,1.45,
259 1.4, 1.4, 1.4, 1.4, 1.4, 1.4,1.45,1.48, 1.4,1.52,
2601.46, 1.4, 1.4, 1.4, 1.4, 1.4, 1.4, 1.4, 1.4, 1.5,
261 1.4, 1.4, 1.4, 1.3, 1.3, 1.3, 1.3, 1.3, 1.3, 1.4,
262 1.3, 1.3, 1.3, 1.3, 1.3, 1.3, 1.3, 1.3,1.33,1.43,
263 1.3,1.32,1.34, 1.3, 1.3, 1.3, 1.3, 1.3, 1.3, 1.3,
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
G4double G4Log(G4double x)
static G4double Radius(G4int Z, G4int A)
static G4double ExplicitRadius(G4int Z, G4int A)
static const G4double r0[93]
static G4double RadiusND(G4int A)
static G4double CoulombFactor(const G4ParticleDefinition *theParticle, const G4ParticleDefinition *nucleon, G4double ekin)
static G4double RadiusNNGG(G4int Z, G4int A)
static G4double RadiusCB(G4int Z, G4int A)
static G4double RadiusHNGG(G4int A)
static G4double NeutronInelasticShape(G4int Z, G4double ekin)
static G4double RadiusKNGG(G4int A)
static G4double RadiusRMS(G4int Z, G4int A)
static G4double RadiusECS(G4int Z, G4int A)
static G4double ProtonInelasticShape(G4int Z, G4double ekin)
static G4double ParticleRadius(const G4ParticleDefinition *)
static G4double GetNuclearMass(const G4double A, const G4double Z)
G4double GetPDGMass() const
G4int GetPDGEncoding() const
G4double GetPDGCharge() const
static G4Pow * GetInstance()