118{
119
122 G4int Z = std::min(ZZ, 92);
123 if(1 == Z) {
125 } else {
126 if(ekin <= fLowEnergy) {
127 cross = (isPiplus) ? theCoulombFacPiPlus[Z]*CoulombFactorPiPlus(ekin, Z)
128 : theCoulombFacPiMinus[Z]*FactorPiMinus(ekin);
129 } else if(ekin > fGlauberEnergy) {
130 cross = (isPiplus) ? theGlauberFacPiPlus[Z] : theGlauberFacPiMinus[Z];
131 cross *= fGlauber->GetElasticGlauberGribov(dp, Z, theA[Z]);
132 } else {
133 cross = fPion->GetElasticCrossSection(dp, Z, theA[Z]);
134 }
135 }
136#ifdef G4VERBOSE
138 G4cout <<
"G4BGGPionElasticXS::GetElementCrossSection for "
141 << " in nucleus Z= " << Z << " A= " << theA[Z]
142 << " XS(b)= " << cross/barn
144 }
145#endif
146 return cross;
147}
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