70 G4int numberOfIsos(0);
71 for (ii = 0; ii < nChannels; ++ii) {
72 numberOfIsos = theChannels[ii]->GetNiso();
73 if (numberOfIsos != 0)
break;
75 auto running =
new G4double[numberOfIsos];
77 for (i = 0; i < numberOfIsos; i++) {
78 if (i != 0) running[i] = running[i - 1];
79 for (ii = 0; ii < nChannels; ii++) {
80 if (theChannels[ii]->HasAnyData(i)) {
81 running[i] += theChannels[ii]->GetWeightedXsec(
82 aThermalE.
GetThermalEnergy(aTrack, theChannels[ii]->GetN(i), theChannels[ii]->GetZ(i),
87 G4int isotope = nChannels - 1;
89 for (i = 0; i < numberOfIsos; ++i) {
91 if (running[numberOfIsos - 1] != 0)
92 if (random < running[i] / running[numberOfIsos - 1])
break;
101 for (i = 0; i < nChannels; i++) {
102 if (i != 0) running[i] = running[i - 1];
103 if (theChannels[i]->HasAnyData(isotope)) {
104 targA = (
G4int)theChannels[i]->GetN(isotope);
105 targZ = (
G4int)theChannels[i]->GetZ(isotope);
106 running[i] += theChannels[i]->GetFSCrossSection(
109 targA = (
G4int)theChannels[i]->GetN(isotope);
110 targZ = (
G4int)theChannels[i]->GetZ(isotope);
117 if (running[nChannels - 1] == 0) {
119 if (targA == -1 && targZ == -1) {
122 "ParticleHP model encounter lethal discrepancy with cross section data");
126 G4cout <<
"Warning from NeutronHP: could not find proper reaction channel. This may cause by "
127 "inconsistency between cross section and model. Unchanged final states are returned."
136 unChanged.AddSecondary(targ_dp);
147 for (i = 0; i < nChannels; i++) {
149 if (running[nChannels - 1] != 0)
150 if (random < running[i] / running[nChannels - 1])
break;
155 G4cout <<
" G4ParticleHPChannelList SELECTED ISOTOPE " << isotope <<
" SELECTED CHANNEL "
158 return theChannels[lChan]->ApplyYourself(aTrack, isotope);
173 for ( i = 0; i < nChannels; i++ ) {
174 if ( i != 0 ) running[i] = running[i-1];
175 if ( theChannels[i]->HasAnyData( isotope ) ) {
176 targA = (
G4int) theChannels[i]->GetN( isotope );
177 targZ = (
G4int) theChannels[i]->GetZ( isotope );
178 running[i] += theChannels[i]->GetFSCrossSection( energy, isotope );
181 if ( running[nChannels-1] == 0 ) {
183 if ( targA == -1 && targZ == -1 ) {
184 throw G4HadronicException( __FILE__, __LINE__,
"ParticleHP model encounter lethal discrepancy with cross section data" );
186 G4cout <<
"Warning from NeutronHP: could not find proper reaction channel. "
187 <<
"This may be caused by inconsistency between cross section and model. "
188 <<
"Unchanged final states are returned." <<
G4endl;
195 unChanged.AddSecondary( targ_dp );
203 for ( i = 0; i < nChannels; i++ ) {
205 if ( running[nChannels-1] != 0 )
if ( random < running[i]/running[nChannels-1] )
break;
209 if (
G4FindDataDir(
"G4ParticleHPDebug" ) !=
nullptr )
G4cout <<
" G4ParticleHPChannelList SELECTED ISOTOPE " << isotope
210 <<
" SELECTED CHANNEL " << lChan <<
G4endl;
212 return theChannels[lChan]->ApplyYourself( aTrack, isotope );
~G4ParticleHPChannelList()
G4ParticleHPChannelList(G4int n=0, G4ParticleDefinition *p=nullptr)
G4HadFinalState * ApplyYourself(const G4Element *theElement, const G4HadProjectile &aTrack)
G4bool HasDataInAnyFinalState()
void Register(G4ParticleHPFinalState *theFS, const G4String &aName)
static G4ParticleHPManager * GetInstance()
G4ParticleHPReactionWhiteBoard * GetReactionWhiteBoard()
G4double GetThermalEnergy(const G4HadProjectile &aP, const G4Element *anE, G4double aT)