46G4double G4ComponentBarNucleonNucleusXsc::A75[93] = {0.0};
47G4int G4ComponentBarNucleonNucleusXsc::theZ[] =
48{2,4,6,7,8,11,13,14,20,26,29,42,48,50,74,82,92};
49std::vector<G4PiData*>* G4ComponentBarNucleonNucleusXsc::thePData =
nullptr;
50std::vector<G4PiData*>* G4ComponentBarNucleonNucleusXsc::theNData =
nullptr;
57 if (
nullptr == thePData) {
127 G4int Z = std::min(ZZ, 92);
129 for(; it<NZ; ++it) {
if(Z <= theZ[it]) {
break; } }
130 if( it >= NZ ) { it = NZ-1; }
132 std::vector<G4PiData*>* theData = (aParticle == theNeutron) ? theNData : thePData;
134 if( theZ[it] == Z ) {
135 fInelasticXsc = (*theData)[it]->ReactionXSection(kineticEnergy);
136 fTotalXsc = (*theData)[it]->TotalXSection(kineticEnergy);
138 if(0 == it) { it = 1; }
139 G4double x1 = (*theData)[it-1]->ReactionXSection(kineticEnergy);
140 G4double xt1 = (*theData)[it-1]->TotalXSection(kineticEnergy);
141 G4double x2 = (*theData)[it]->ReactionXSection(kineticEnergy);
142 G4double xt2 = (*theData)[it]->TotalXSection(kineticEnergy);
143 G4int Z1 = theZ[it-1];
146 fInelasticXsc = Interpolate(Z1, Z2, Z, x1, x2);
147 fTotalXsc = Interpolate(Z1, Z2, Z, xt1, xt2);
150 fElasticXsc = std::max(fTotalXsc - fInelasticXsc, 0.0);
155G4double G4ComponentBarNucleonNucleusXsc::
161 G4double alp1 = (aeff[Z] - aeff[Z1]);
162 G4double alp2 = (aeff[Z2] - aeff[Z]);
163 G4double result = (r1*alp2 + r2*alp1)/(alp1 + alp2);
173 outFile <<
"G4ComponentBarNucleonNucleusXsc is a variant of the Barashenkov\n"
174 <<
"cross section parameterization to be used of protons and\n"
175 <<
"neutrons on targets heavier than hydrogen. It is intended for\n"
176 <<
"use as a cross section component and is currently used by\n"
177 <<
"G4BGGNucleonInelasticXS. It is valid for incident energies up\n"
183void G4ComponentBarNucleonNucleusXsc::LoadData()
185 theNData =
new std::vector<G4PiData*>;
186 thePData =
new std::vector<G4PiData*>;
187 theNData->resize(NZ,
nullptr);
188 thePData->resize(NZ,
nullptr);
190 ptr->AddPiData(theNData);
191 ptr->AddPiData(thePData);
194 (*theNData)[0] =
new G4PiData(he_m_t, he_m_in, e1, 44);
195 (*thePData)[0] =
new G4PiData(he_m_t, he_p_in, e1, 44);
197 (*theNData)[1] =
new G4PiData(be_m_t, be_m_in, e1, 44);
198 (*thePData)[1] =
new G4PiData(be_m_t, be_p_in, e1, 44);
200 (*theNData)[2] =
new G4PiData(c_m_t, c_m_in, e1, 44);
201 (*thePData)[2] =
new G4PiData(c_m_t, c_p_in, e1, 44);
204 (*theNData)[3] =
new G4PiData(n_m_t, n_m_in, e2, 44);
205 (*thePData)[3] =
new G4PiData(n_m_t, n_p_in, e2, 44);
207 (*theNData)[4] =
new G4PiData(o_m_t, o_m_in, e2, 44);
208 (*thePData)[4] =
new G4PiData(o_m_t, o_p_in, e2, 44);
210 (*theNData)[5] =
new G4PiData(na_m_t, na_m_in, e2, 44);
211 (*thePData)[5] =
new G4PiData(na_m_t, na_p_in, e2, 44);
214 (*theNData)[6] =
new G4PiData(al_m_t, al_m_in, e3, 45);
215 (*thePData)[6] =
new G4PiData(al_m_t, al_p_in, e3, 45);
217 (*theNData)[7] =
new G4PiData(si_m_t, si_m_in, e3, 45);
218 (*thePData)[7] =
new G4PiData(si_m_t, si_p_in, e3, 45);
220 (*theNData)[8] =
new G4PiData(ca_m_t, ca_m_in, e3, 45);
221 (*thePData)[8] =
new G4PiData(ca_m_t, ca_p_in, e3, 45);
224 (*theNData)[9] =
new G4PiData(fe_m_t, fe_m_in, e4, 47);
225 (*thePData)[9] =
new G4PiData(fe_m_t, fe_p_in, e4, 47);
227 (*theNData)[10] =
new G4PiData(cu_m_t, cu_m_in, e4, 47);
228 (*thePData)[10] =
new G4PiData(cu_m_t, cu_p_in, e4, 47);
230 (*theNData)[11] =
new G4PiData(mo_m_t, mo_m_in, e4, 47);
231 (*thePData)[11] =
new G4PiData(mo_m_t, mo_p_in, e4, 47);
234 (*theNData)[12] =
new G4PiData(cd_m_t, cd_m_in, e5, 48);
235 (*thePData)[12] =
new G4PiData(cd_m_t, cd_p_in, e5, 48);
237 (*theNData)[13] =
new G4PiData(sn_m_t, sn_m_in, e5, 48);
238 (*thePData)[13] =
new G4PiData(sn_m_t, sn_p_in, e5, 48);
240 (*theNData)[14] =
new G4PiData(w_m_t, w_m_in, e5, 48);
241 (*thePData)[14] =
new G4PiData(w_m_t, w_p_in, e5, 48);
244 (*theNData)[15] =
new G4PiData(pb_m_t, pb_m_in, e6, 46);
245 (*thePData)[15] =
new G4PiData(pb_m_t, pb_p_in, e6, 46);
247 (*theNData)[16] =
new G4PiData(u_m_t, u_m_in, e6, 46);
248 (*thePData)[16] =
new G4PiData(u_m_t, u_p_in, e6, 46);
252 for(
G4int i=1; i<93; ++i) {
253 A75[i] = g4pow->
A23(aeff[i]);
G4double GetTotalIsotopeCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int) final
G4double GetInelasticIsotopeCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int) final
G4double GetInelasticElementCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double) final
G4double GetTotalElementCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double) final
G4double GetElasticIsotopeCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int) final
G4double GetElasticElementCrossSection(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double) final
void Description(std::ostream &) const final
void ComputeCrossSections(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z)
G4ComponentBarNucleonNucleusXsc()
static G4HadronXSDataTable * Instance()
static G4Neutron * Neutron()
static G4Pow * GetInstance()
G4double A23(G4double A) const
static G4Proton * Proton()
G4VComponentCrossSection(const G4String &nam="")