132 {
134 if ( MTnumber == 2 ) {
136 } else if ( MTnumber == 102 ) {
138 } else if ( MTnumber == 18 ) {
140 }
141 }
143 if ( kineticEnergy < Emin || kineticEnergy >
Emax ) {
144
147 for (
G4int j = 0; j < (
G4int)
ele->GetNumberOfIsotopes(); j++ ) {
148 if (
A == (
G4int)
ele->GetIsotope(j)->GetN() ) {
149 isotopeJ = j;
150 break;
151 }
152 }
153 G4double frac =
ele->GetRelativeAbundanceVector()[isotopeJ];
159 } else {
162 }
167 } else {
171 } else {
174 }
175 }
176 } else if ( lssf_flag == 0 ) {
178 std::vector< G4double >* theProbability1 =
theProbabilities->at(indexE - 1);
185 for ( indexP1 = 0; indexP1 < tableOrder; indexP1++ ) {
186 if ( rand <= theProbability1->at(indexP1) ) break;
187 }
188 for ( indexP2 = 0; indexP2 < tableOrder; indexP2++ ) {
189 if ( rand <= theProbability2->at(indexP2) ) break;
190 }
195 xsela_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, ela1, ela2 ) * barn;
196 xscap_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, cap1, cap2 ) * barn;
199 } else {
202 xsfiss_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, fiss1, fiss2 ) * barn;
203 }
204 } else if ( lssf_flag == 1 ) {
206 std::vector< G4double >* theProbability1 =
theProbabilities->at(indexE - 1);
213 for ( indexP1 = 0; indexP1 < tableOrder; indexP1++ ) {
214 if ( rand <= theProbability1->at(indexP1) ) break;
215 }
216 for ( indexP2 = 0; indexP2 < tableOrder; indexP2++ ) {
217 if ( rand <= theProbability2->at(indexP2) ) break;
218 }
221 for (
G4int j = 0; j < (
G4int)
ele->GetNumberOfIsotopes(); j++ ) {
222 if (
A == (
G4int)
ele->GetIsotope(j)->GetN() ) {
223 isotopeJ = j;
224 break;
225 }
226 }
227 G4double frac =
ele->GetRelativeAbundanceVector()[isotopeJ];
233 } else {
236 }
241 G4double elasticXS = weightedelasticXS / frac;
242 G4double captureXS = weightedcaptureXS / frac;
243 xsela_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, ela1, ela2 ) * elasticXS;
244 xscap_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, cap1, cap2 ) * captureXS;
247 } else {
250 G4double fissionXS = weightedfissionXS / frac;
253 xsfiss_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, fiss1, fiss2 ) * fissionXS;
254 } else {
256 G4double fissionXS = weightedfissionXS / frac;
259 xsfiss_cache[id] = theInt.Lin( kineticEnergy, ene1, ene2, fiss1, fiss2 ) * fissionXS;
260 }
261 }
262 }
263 if ( MTnumber == 2 ) {
265 } else if ( MTnumber == 102 ) {
267 } else if ( MTnumber == 18 ) {
269 } else {
270 G4cout <<
"Reaction was not found, returns 0." <<
G4endl;
271 return 0;
272 }
273}
G4GLOB_DLL std::ostream G4cout
G4ParticleHPVector * theEnergies
std::map< std::thread::id, G4double > xsela_cache
std::map< std::thread::id, G4double > xscap_cache
std::map< std::thread::id, G4double > energy_cache
G4double GetDopplerBroadenedFissionXS(const G4DynamicParticle *, G4int, G4int)
std::vector< std::vector< G4double > * > * theElasticData
std::vector< std::vector< G4double > * > * theFissionData
std::map< std::thread::id, G4double > xsfiss_cache
std::vector< std::vector< G4double > * > * theCaptureData
G4double GetDopplerBroadenedCaptureXS(const G4DynamicParticle *, G4int, G4int)
G4double GetDopplerBroadenedElasticXS(const G4DynamicParticle *, G4int, G4int)
std::vector< std::vector< G4double > * > * theProbabilities
std::vector< G4ParticleHPChannel * > * GetFissionFinalStates() const
std::vector< G4ParticleHPChannel * > * GetElasticFinalStates() const
std::vector< G4ParticleHPChannel * > * GetCaptureFinalStates() const
static G4ParticleHPManager * GetInstance()