116{
117
118
121 G4int Z = std::min(ZZ, 92);
122
123 if(1 == Z) {
125 } else if(ekin < fLowEnergy) {
126 cross = (isPiplus) ? theLowEPiPlus[Z]*CoulombFactorPiPlus(ekin, Z)
127 : theLowEPiMinus[Z]*FactorPiMinus(ekin);
128 } else if(ekin > fGlauberEnergy) {
129 cross = (isPiplus) ? theGlauberFacPiPlus[Z] : theGlauberFacPiMinus[Z];
130 cross *= fGlauber->GetInelasticGlauberGribov(dp, Z, theA[Z]);
131 } else {
132 cross = fPion->GetInelasticCrossSection(dp, Z, theA[Z]);
133 }
134#ifdef G4VERBOSE
136 G4cout <<
"G4BGGPionInelasticXS::GetCrossSection for "
139 << " in nucleus Z= " << Z << " A= " << theA[Z]
140 << " XS(b)= " << cross/barn
142 }
143#endif
144 return cross;
145}
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