198 /CLHEP::neutron_mass_c2;
209 if(0.0 < x) { targetMass = x/CLHEP::neutron_mass_c2; }
213 if(0.0 < x) { targetMass = x/CLHEP::neutron_mass_c2; }
223 incidReactionProduct.
GetMomentum() / CLHEP::neutron_mass_c2;
232 boosted.
Lorentz(incidReactionProduct, theTarget);
243 for (ii = 0; ii < nDef; ++ii) {
248 if (std::abs(
Qvalue) < CLHEP::keV) {
254 for (ii = 0; ii < nDef; ++ii) {
259 if (ResidualA > 0 && ResidualZ > 0) {
265 if (std::abs(
Qvalue) > 400 * CLHEP::MeV) {
267 Qvalue = 1.1 * CLHEP::keV;
272 thePhaseSpaceDistribution.
Init(aPhaseMass, nDef);
274 thePhaseSpaceDistribution.
SetTarget(&theTarget);
277 for (ii = 0; ii < nDef; ++ii) {
278 G4double massCode = 1000. * std::abs(theDefs[ii]->GetPDGCharge());
282 aSec->
Lorentz(*aSec, -1. * theTarget);
290 G4cout <<
this <<
" G4ParticleHPInelasticBaseFS::BaseApply NoFSData add secondary "
291 << aPart->GetParticleDefinition()->GetParticleName()
292 <<
" E= " << aPart->GetKineticEnergy() <<
" NSECO "
326 G4int projA = hproj->GetBaryonNumber();
327 G4int projZ =
G4lrint(hproj->GetPDGCharge()/CLHEP::eplus);
329 if (!
fManager->GetDoNotAdjustFinalState()) {
331 if (tmpHadrons !=
nullptr) {
336 for (
G4int j = 0; j != (
G4int)tmpHadrons->size(); ++j) {
337 auto had = ((*tmpHadrons)[j])->GetDefinition();
338 if (had->GetBaryonNumber() > maxA) {
339 maxA = had->GetBaryonNumber();
342 sumA += had->GetBaryonNumber();
343 sumZ +=
G4lrint(had->GetPDGCharge()/CLHEP::eplus);
347 if (dA < 0 || dZ < 0) {
348 auto p = ((*tmpHadrons)[jAtMaxA])->GetDefinition();
349 G4int newA = p->GetBaryonNumber() + dA;
350 G4int newZ =
G4lrint(p->GetPDGCharge()/CLHEP::eplus) + dZ;
351 if (newA > newZ && newZ > 0) {
353 ((*tmpHadrons)[jAtMaxA])->SetDefinition(pd);
361 auto Done =
new G4bool[nDef];
363 for (i0 = 0; i0 < nDef; ++i0)
370 for (i0 = 0; i0 < nDef; ++i0) {
377 else if (nDef == 1) {
381 else if (nDef == 2) {
388 "No energy distribution to sample from in InelasticBaseFS::BaseApply");
397 G4lrint((theDefs[0]->GetPDGCharge() + theDefs[1]->GetPDGCharge())/CLHEP::eplus);
400 G4double availableEnergy = eKinetic + massn + localMass - mass1 - mass2
403 G4double emin = availableEnergy + mass1 + mass2
404 - std::sqrt((mass1 + mass2) * (mass1 + mass2) + orgMomentum * orgMomentum);
405 G4double p1 = std::sqrt(2. * mass2 * emin);
411 <<
" " << a1 <<
" " <<
theBaseA <<
" " << availableEnergy
417 bufferedDirection = -bufferedDirection;
423 aHadron->
Lorentz(*aHadron, -1. * (theTarget + incidReactionProduct));
428 <<
" bufDir^2=" << bufferedDirection.
mag2()
433 tmpHadrons->push_back(aHadron);
436 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply FSData add secondary "
452 boosted_tmp.
Lorentz(incidReactionProduct, theTarget);
455 if (thePhotons !=
nullptr) {
456 for (i = 0; i < thePhotons->size(); ++i) {
458 thePhotons->operator[](i)->Lorentz(*(thePhotons->operator[](i)), -1. * theTarget);
464 G4bool bAdjustPhotons{
true};
466 bAdjustPhotons =
true;
468 if (
fManager->GetDoNotAdjustFinalState()) bAdjustPhotons =
false;
471 if (bAdjustPhotons) {
474 theGammaEnergy = anEnergy - theGammaEnergy;
484 for (
auto const & had : *tmpHadrons) {
486 eBindProducts += eBindN;
489 eBindProducts += eBindP;
492 eBindProducts += eBindD;
495 eBindProducts += eBindT;
497 else if (had->GetDefinition() ==
G4He3::He3()) {
498 eBindProducts += eBindHe3;
501 eBindProducts += eBindA;
505 theGammaEnergy += eBindProducts;
509 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply gamma Energy " << theGammaEnergy
510 <<
" eBindProducts " << eBindProducts <<
G4endl;
520 theGammaEnergy -= (2 * eBindA);
524 if (theGammaEnergy > 0.0) {
525 for (
G4int iLevel =
theGammas.GetNumberOfLevels() - 1; iLevel > 0; --iLevel) {
527 if (e < theGammaEnergy) {
528 thePhotons =
theGammas.GetDecayGammas(iLevel);
537 std::size_t nSecondaries = tmpHadrons->size();
538 std::size_t nPhotons = 0;
539 if (thePhotons !=
nullptr) {
540 nPhotons = thePhotons->size();
542 nSecondaries += nPhotons;
547 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply N hadrons " << nSecondaries - nPhotons
551 for (i = 0; i < nSecondaries - nPhotons; ++i) {
553 theSec->
SetDefinition(tmpHadrons->operator[](i)->GetDefinition());
554 theSec->
SetMomentum(tmpHadrons->operator[](i)->GetMomentum());
558 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply add secondary2 "
563 delete (*tmpHadrons)[i];
567 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply N photons " << nPhotons <<
G4endl;
569 if (thePhotons !=
nullptr) {
570 for (i = 0; i < nPhotons; ++i) {
573 theSec->
SetMomentum((*thePhotons)[i]->GetMomentum());
577 G4cout <<
" G4ParticleHPInelasticBaseFS::BaseApply add secondary3 "
582 delete thePhotons->operator[](i);
void SetDefinition(const G4ParticleDefinition *aParticleDefinition)
const G4ParticleDefinition * GetParticleDefinition() const
void SetA_Z(G4double anA, G4double aZ, G4int aM=0)
void BaseApply(const G4HadProjectile &theTrack, G4ParticleDefinition **theDefs, G4int nDef)
void Init(G4double A, G4double Z, G4int M, const G4String &dirName, const G4String &bit, G4ParticleDefinition *) override
G4ReactionProduct * Sample(G4double anEnergy, G4double massCode, G4double mass) override