127 using namespace G4InuclParticleNames;
139 const G4int G4CascadeInterface::maximumTries = 20;
159 delete collider; collider=0;
160 delete balance; balance=0;
161 delete output; output=0;
166 outFile <<
"The Bertini-style cascade implements the inelastic scattering\n"
167 <<
"of hadrons by nuclei. Nucleons, pions, kaons and hyperons\n"
168 <<
"from 0 to 15 GeV may be used as projectiles in this model.\n"
169 <<
"Final state hadrons are produced by a classical cascade\n"
170 <<
"consisting of individual hadron-nucleon scatterings which use\n"
171 <<
"free-space partial cross sections, corrected for various\n"
172 <<
"nuclear medium effects. The target nucleus is modeled as a\n"
173 <<
"set of 1, 3 or 6 spherical shells, in which scattered hadrons\n"
174 <<
"travel in straight lines until they are reflected from or\n"
175 <<
"transmitted through shell boundaries.\n";
233 G4cout <<
" >>> G4CascadeInterface::ApplyYourself" <<
G4endl;
236 G4cerr <<
" >>> G4CascadeInterface got negative-energy track: "
241 #ifdef G4CASCADE_DEBUG_INTERFACE
242 static G4int counter(0);
244 G4cerr <<
"Reaction number "<< counter <<
" "
249 if (!randomFile.empty()) {
251 G4cout <<
" Saving random engine state to " << randomFile <<
G4endl;
281 G4cout <<
" Generating cascade attempt " << numberOfTries <<
G4endl;
291 if (numberOfTries >= maximumTries) {
293 G4cout <<
" Cascade aborted after trials " << numberOfTries <<
G4endl;
298 if (!balance->
okay()) {
305 G4cout <<
" Cascade output after trials " << numberOfTries <<
G4endl;
327 #ifdef G4CASCADE_DEBUG_INTERFACE
331 <<
"\n " << theSecondaries->size() <<
" secondaries:" <<
G4endl;
332 for (
size_t i=0; i<theSecondaries->size(); i++) {
341 if (!randomFile.empty()) {
343 G4cout <<
" Saving random engine state to " << randomFile <<
G4endl;
365 G4cout <<
" Generating rescatter attempt " << numberOfTries <<
G4endl;
368 collider->
rescatter(bullet, theSecondaries, theNucleus, *output);
376 if (numberOfTries >= maximumTries && !balance->
okay()) {
382 G4cout <<
" Cascade rescatter after trials " << numberOfTries <<
G4endl;
401 G4cout <<
" >>> G4CascadeInterface::NoInteraction" <<
G4endl;
418 G4int bulletType = 0;
419 G4int bulletA = 0, bulletZ = 0;
428 if (0 == bulletType && 0 == bulletA*bulletZ) {
431 <<
" not usable as bullet." <<
G4endl;
442 bulletInLabFrame.
rotateZ(-projectileMomentum.
phi());
444 bulletInLabFrame.
invert();
447 projectileMomentum.
e());
449 if (bulletType > 0) {
450 hadronBullet.
fill(momentumBullet, bulletType);
451 bullet = &hadronBullet;
453 nucleusBullet.
fill(momentumBullet, bulletA, bulletZ);
454 bullet = &nucleusBullet;
475 nucleusTarget.
fill(A, Z);
495 G4cerr <<
" ERROR: G4CascadeInterface incompatible particle type "
496 << outgoingType <<
G4endl;
531 G4cout <<
" >>> G4CascadeInterface::copyOutputToHadronicResult" <<
G4endl;
540 if (!particles.empty()) {
542 for (; ipart != particles.end(); ipart++) {
548 if (!outgoingNuclei.empty()) {
550 for (; ifrag != outgoingNuclei.end(); ifrag++) {
558 G4cout <<
" >>> G4CascadeInterface::copyOutputToReactionProducts" <<
G4endl;
569 if (!particles.empty()) {
571 for (; ipart != particles.end(); ipart++) {
575 propResult->push_back(rp);
581 if (!fragments.empty()) {
583 for (; ifrag != fragments.end(); ifrag++) {
587 propResult->push_back(rp);
603 G4cerr <<
"ERROR: no baryon number conservation, sum of baryons = "
608 G4cerr <<
"ERROR: no charge conservation, sum of charges = "
612 if (std::abs(balance->
deltaKE()) > 0.01 ) {
613 G4cerr <<
"Kinetic energy conservation violated by "
620 G4cout <<
"Initial energy " << eInit <<
" final energy " << eFinal
621 <<
"\nTotal energy conservation at level "
624 if (balance->
deltaKE() > 5.0e-5 ) {
625 G4cerr <<
"FATAL ERROR: kinetic energy created "
639 const std::vector<G4InuclElementaryParticle>&
p =
644 violated |= (
ipart->getKineticEnergy() < coulumbBarrier);
654 const std::vector<G4InuclElementaryParticle>& out =
657 #ifdef G4CASCADE_DEBUG_INTERFACE
659 G4cout <<
" retryInelasticProton: number of Tries "
660 << ((numberOfTries < maximumTries) ?
"RETRY (t)" :
"EXIT (f)")
661 <<
"\n retryInelasticProton: AND collision type ";
664 G4cout << (out.size() == 2 ?
"ELASTIC (t)" :
"INELASTIC (f)")
665 <<
"\n retryInelasticProton: AND Leading particles bullet "
666 << (out.size() >= 2 &&
669 ?
"YES (t)" :
"NO (f)")
674 return ( (numberOfTries < maximumTries) &&
693 #ifdef G4CASCADE_DEBUG_INTERFACE
695 G4cout <<
" retryInelasticNucleus: numberOfTries "
696 << ((numberOfTries < maximumTries) ?
"RETRY (t)" :
"EXIT (f)")
697 <<
"\n retryInelasticNucleus: AND outputParticles "
698 << ((npart != 0) ?
"NON-ZERO (t)" :
"EMPTY (f)")
699 #ifdef G4CASCADE_COULOMB_DEV
700 <<
"\n retryInelasticNucleus: AND coulombBarrier (COULOMB_DEV) "
702 <<
"\n retryInelasticNucleus: AND collision type (COULOMB_DEV) "
703 << ((npart+nfrag > 2) ?
"INELASTIC (t)" :
"ELASTIC (f)")
705 <<
"\n retryInelasticNucleus: AND collsion type "
706 << ((npart+nfrag < 3) ?
"ELASTIC (t)" :
"INELASTIC (f)")
707 <<
"\n retryInelasticNucleus: AND Leading particle bullet "
708 << ((firstOut == bullet->
getDefinition()) ?
"YES (t)" :
"NO (f)")
710 <<
"\n retryInelasticNucleus: OR conservation "
711 << (!balance->
okay() ?
"FAILED (t)" :
"PASSED (f)")
715 return ( ((numberOfTries < maximumTries) &&
717 #ifdef G4CASCADE_COULOMB_DEV
720 (npart+nfrag < 3 && firstOut == bullet->getDefinition())
723 #ifndef G4CASCADE_SKIP_ECONS
724 || (!balance->
okay())
736 std::ostream& errInfo =
G4cerr;
738 errInfo <<
" >>> G4CascadeInterface has non-conserving"
739 <<
" cascade after " << numberOfTries <<
" attempts." <<
G4endl;
741 G4String throwMsg =
"G4CascadeInterface - ";
743 throwMsg +=
"Energy";
744 errInfo <<
" Energy conservation violated by " << balance->
deltaE()
749 throwMsg +=
"Momentum";
750 errInfo <<
" Momentum conservation violated by " << balance->
deltaP()
755 throwMsg +=
"Baryon number";
756 errInfo <<
" Baryon number violated by " << balance->
deltaB() <<
G4endl;
760 throwMsg +=
"Charge";
761 errInfo <<
" Charge conservation violated by " << balance->
deltaQ()
765 errInfo <<
" Final event output, for debugging:\n"
766 <<
" Bullet: \n" << *bullet << G4endl
770 throwMsg +=
" non-conservation. More info in output.";