107{
108
109
111 G4int Z = std::min(ZZ, 92);
113 if(1 == Z) {
115 } else {
116 if(ekin <= fLowEnergy) {
117 cross = (isProton) ? theCoulombFacP[Z] : theCoulombFacN[Z];
118 cross *= CoulombFactor(ekin, Z);
119 } else if(ekin > fGlauberEnergy) {
120 cross = (isProton) ? theGlauberFacP[Z] : theGlauberFacN[Z];
121 cross *= fGlauber->GetElasticGlauberGribov(dp, Z, theA[Z]);
122 } else {
123 cross = fNucleon->GetElasticCrossSection(dp, Z);
124 }
125 }
126#ifdef G4VERBOSE
128 G4cout <<
"G4BGGNucleonElasticXS::GetElementCrossSection for "
131 << " in nucleus Z= " << Z << " A= " << theA[Z]
132 << " XS(b)= " << cross/barn
134 }
135#endif
136 return cross;
137}
G4GLOB_DLL std::ostream G4cout
G4double GetIsoCrossSection(const G4DynamicParticle *, G4int Z, G4int A, const G4Isotope *iso=nullptr, const G4Element *elm=nullptr, const G4Material *mat=nullptr) final
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const