178 G4double totprob, prob, oldprob = 0.0;
180 std::size_t maxchannel, i;
184 G4cout <<
"### G4Evaporation::BreakItUp loop" <<
G4endl;
190 for(
G4int ia=0; ia<Amax; ++ia) {
195 if(
A <= 1) {
break; }
199 if(
theFBU->IsApplicable(Z,
A, Eex)) {
break; }
202 G4double abun = nist->GetIsotopeAbundance(Z,
A);
204 if(Eex <= minExcitation &&
205 (abun > 0.0 || (
A == 3 && (Z == 1 || Z == 2)))) {
break; }
208 maxchannel = nChannels;
210 G4cout <<
"Evaporation# " << ia <<
" Z= " << Z <<
" A= " <<
A
212 <<
" aban= " << abun <<
G4endl;
215 for(i=0; i<nChannels; ++i) {
216 prob = (*theChannels)[i]->GetEmissionProbability(theResidualNucleus);
217 if(fVerbose > 1 && prob > 0.0) {
218 G4cout <<
" Channel# " << i <<
" prob= " << prob <<
G4endl;
221 probabilities[i] = totprob;
225 if (prob <= totprob*limFact && oldprob <= totprob*limFact) {
235 if(0.0 < totprob && probabilities[0] == totprob) {
237 G4cout <<
"$$$ Start chain of gamma evaporation" <<
G4endl;
239 (*theChannels)[0]->BreakUpChain(theResult, theResidualNucleus);
248 if(
theFBU->IsApplicable(Z,
A, Eex)) {
break; }
255 if(0.0 == totprob &&
A < 30) {
261 if(unstableBreakUp->BreakUpChain(theResult, theResidualNucleus)) {
269 totprob *= rndm->
flat();
272 for (i=0; i<maxchannel; ++i) {
273 if (probabilities[i] >= totprob) {
break; }
276 if(fVerbose > 1) {
G4cout <<
"$$$ Channel # " << i <<
G4endl; }
277 G4Fragment* frag = (*theChannels)[i]->EmittedFragment(theResidualNucleus);
278 if(fVerbose > 2 && frag) {
G4cout <<
" " << *frag <<
G4endl; }
281 if(
nullptr != frag) { theResult->push_back(frag); }
G4IonTable * GetIonTable() const
static G4ParticleTable * GetParticleTable()