75 {
77 G4cout <<
" >>> G4NonEquilibriumEvaporator::deExcite" <<
G4endl;
78 }
79
81
82 const G4int a_cut = 5;
83 const G4int z_cut = 3;
84
86
88 const G4int itry_max = 1000;
91
94
95 G4ExitonConfiguration
config(target);
100
101 G4int QP = QPP + QNP;
102 G4int QH = QPH + QNH;
104
105 G4InuclElementaryParticle dummy(small_ekin, 1);
106 G4LorentzConvertor toTheExitonSystemRestFrame;
107
108 toTheExitonSystemRestFrame.
setBullet(dummy);
109
112
117 G4bool try_again = (NEX > 0);
118
119
120 std::pair<G4double, G4double> parms;
121
122 while (try_again) {
123 if (
A >= a_cut &&
Z >= z_cut &&
EEXS > eexs_cut) {
124
126 PEX.setVectM(
PEX.vect(), nuc_mass);
129
131 G4cout <<
" A " <<
A <<
" Z " <<
Z <<
" mass " << nuc_mass
133 }
134
140
141 if (QEX < std::sqrt(2.0 * EG)) {
143 G4cout <<
" QEX " << QEX <<
" < sqrt(2*EG) " << std::sqrt(2.*EG)
144 <<
" NEX " << NEX <<
G4endl;
145
146 theParaMaker.getTruncated(
Z, parms);
148 const G4double& CPA1 = parms.second;
149
158
160 G4cout <<
" AK1 " << AK1 <<
" CPA1 " <<
" VP " << VP
161 << "\n bind(A,Z) " << DM1 << " dBind(N) " << BN
162 << " dBind(P) " << BP
163 <<
"\n EMN " << EMN <<
" EMP " << EMP <<
G4endl;
164 }
165
166 if (EMN > eexs_cut) {
168
169 if (NEX > 1) {
170 G4double APH = 0.25 * (QP * QP + QH * QH + QP - 3 * QH);
171 G4double APH1 = APH + 0.5 * (QP + QH);
174
176 G4cout <<
" APH " << APH <<
" APH1 " << APH1 <<
" ESP " << ESP
178
179 if (ESP > 15.0) {
180 MELE *= std::sqrt(15.0 / ESP);
181 } else if(ESP < 7.0) {
182 MELE *= std::sqrt(ESP / 7.0);
183 if (ESP < 2.0) MELE *= std::sqrt(ESP / 2.0);
184 };
185
188
190 G4cout <<
" MELE " << MELE <<
" F1 " << F1 <<
" F2 " << F2
192
193 if (F1 > 0.0 && F2 > 0.0) {
197 D[0] = M1 * F2 * F2 * theG4Pow->powN(F, NEX-1) / (QEX+1);
199 G4cout <<
" D[0] " <<
D[0] <<
" with F " << F
200 << " powN(F,NEX-1) " << theG4Pow->powN(F, NEX-1)
202 }
203
205
206 if (NEX >= 2) {
208
209 if (EMP > eexs_cut)
210 D[2] =
D[1] * theG4Pow->powN(EMP/
EEXS, NEX) * (1.0 + CPA1);
212
214 G4cout <<
" D[1] " <<
D[1] <<
" with powN(EMN/EEXS, NEX) "
216 <<
" D[2] " <<
D[2] <<
" with powN(EMP/EEXS, NEX) "
218 }
219
220 if (QNP < 1)
D[1] = 0.0;
221 if (QPP < 1)
D[2] = 0.0;
222
223 try_again = NEX > 1 && (
D[1] > width_cut *
D[0] ||
224 D[2] > width_cut *
D[0]);
225
226 if (try_again) {
230
233
234 for (
G4int i = 0; i < 3; i++) {
236 if (SL <= S1) {
237 icase = i;
238 break;
239 }
240 }
241
244 }
245 }
246 } else try_again = false;
247 } else try_again = false;
248 }
249
250 if (try_again) {
251 if (icase > 0) {
254
258
259 if (
A < 3.0) try_again =
false;
260
261 if (try_again) {
262
263 if (icase == 1) {
266
267 if (QNP < 1) icase = 0;
268 else {
270 V = 0.0;
271 ptype = 2;
272 };
273 } else {
276
277 if (QPP < 1) icase = 0;
278 else {
280 V = VP;
281 ptype = 1;
282
283 if (
Z-1 < 1) try_again =
false;
284 };
285 };
286
287 if (try_again && icase != 0) {
289 G4cout <<
" ptype " << ptype <<
" B " <<
B <<
" V " << V
291
294
295 if (E < 0.0) icase = 0;
296 else {
302
303
304 while (itry1 < itry_max && icase > 0 && bad) {
305 itry1++;
307
308
309 while (EEXS_new < 0.0 && itry < itry_max) {
310 itry++;
313
314 if (NEX == 2) {
315 X = 1.0 - std::sqrt(R);
316
317 } else {
320 X = theG4Pow->powA(0.5*R, QEX2);
322 G4cout <<
" R " << R <<
" QEX2 " << QEX2
323 <<
" powA(R, QEX2) " << X <<
G4endl;
324 }
325
326 for (
G4int i = 0; i < 1000; i++) {
328 (1.0 + QEX2 * X * (1.0 - R / theG4Pow->powN(X, NEX)) / (1.0 - X));
330 G4cout <<
" NEX " << NEX <<
" powN(X, NEX) "
331 << theG4Pow->powN(X, NEX) <<
G4endl;
332 }
333
334 X -= DX;
335
336 if (std::fabs(DX / X) < 0.01) break;
337
338 };
339 };
340 EPART = EB - X * E1;
341 EEXS_new = EB - EPART *
A / (
A-1);
342 }
343
344 if (itry == itry_max || EEXS_new < 0.0) {
345 icase = 0;
346 continue;
347 }
348
350 G4cout <<
" particle " << ptype <<
" escape " <<
G4endl;
351
352 EPART /= GeV;
353
354 G4InuclElementaryParticle particle(ptype);
356
357
359 G4double pmod = std::sqrt(EPART * (2.0 * mass + EPART));
361
362
364
365
368
371
372 if (ptype == 1) {
373 QPP_new--;
374 Z_new--;
375 };
376
377 if (ptype == 2) QNP_new--;
378
380 G4cout <<
" nucleus px " <<
PEX.px() <<
" py " <<
PEX.py()
382 <<
" evaporate px " << mom.
px() <<
" py " << mom.
py()
383 <<
" pz " << mom.
pz() <<
" E " << mom.
e() <<
G4endl;
384 }
385
386
388
389 EEXS_new = ((
PEX-mom).m() - mass_new)*GeV;
390 if (EEXS_new < 0.) continue;
391
394
397
400
401 NEX--;
402 QEX--;
403 QP--;
404 QPP = QPP_new;
405 QNP = QNP_new;
406
407 particle.setMomentum(mom);
409 ppout += mom;
412 <<
" ppout px " << ppout.
px() <<
" py " << ppout.
py()
413 <<
" pz " << ppout.
pz() <<
" E " << ppout.
e() <<
G4endl;
414 }
415
416 bad = false;
417 }
418
419 if (itry1 == itry_max) icase = 0;
420 }
421 }
422 }
423 }
424
425 if (icase == 0 && try_again) {
427
430 G4double XNUN = 1.0 / (1.6 + ESP / EFN);
431 G4double XNUP = 1.0 / (1.6 + ESP / EFP);
436 G4double PP = (QPP * SNN1 + QNP * SPN1) * ZR;
437 G4double PN = (QPP * SPN2 + QNP * SNN2) * (AR - ZR);
439 NEX += 2;
440 QEX += 2;
441 QP++;
442 QH++;
443 AR--;
444
445 if (AR > 1) {
447
448 if (SL > PP) {
449 QNP++;
450 QNH++;
451 } else {
452 QPP++;
453 QPH++;
454 ZR--;
455 if (ZR < 2) try_again = false;
456 }
457 } else try_again = false;
458 }
459 }
460 } else try_again = false;
461 } else try_again = false;
462 } else try_again = false;
463 }
464
465
466
469 } else {
472
475 }
476
478 return;
479}
G4double B(G4double temperature)
G4double D(G4double temp)
CLHEP::HepLorentzVector G4LorentzVector
G4GLOB_DLL std::ostream G4cout
void getTargetData(const G4Fragment &target)
const G4Fragment & makeFragment(G4LorentzVector mom, G4int A, G4int Z, G4double EX=0.)
virtual G4bool validateOutput(const G4Fragment &target, G4CollisionOutput &output)
G4int numberOfOutgoingParticles() const
void addRecoilFragment(const G4Fragment *aFragment)
void addOutgoingParticle(const G4InuclElementaryParticle &particle)
const G4Fragment & getRecoilFragment(G4int index=0) const
G4double getNucleiMass() const
void toTheTargetRestFrame()
void setBullet(const G4InuclParticle *bullet)
G4LorentzVector backToTheLab(const G4LorentzVector &mom) const
void setTarget(const G4InuclParticle *target)
G4double bindingEnergy(G4int A, G4int Z)
G4LorentzVector generateWithRandomAngles(G4double p, G4double mass=0.)
G4double csNN(G4double e)
G4double FermiEnergy(G4int A, G4int Z, G4int ntype)
G4double csPN(G4double e)
G4double G4cbrt(G4double x)