267 for (
G4int i = 0; i < 50; ++i) {
276 G4cout <<
"G4ParticleHPInelasticCompFS::CompositeApply A=" <<
theBaseA <<
" Z="
302 boosted.
Lorentz(incidReactionProduct, theTarget);
324 if (
fManager->GetUseNRESP71Model() && eKinetic < 20 * CLHEP::MeV) {
328 if (use_nresp71_model(aDefinition, it, theTarget, boosted))
return;
340 + (targetMass - residualMass);
342 if (availableEnergy < 0) {
345 G4int nothingWasKnownOnHadron = 0;
359 G4double p = (p2 > 0.0) ? std::sqrt(p2) : 0.0;
379 if (
QI[it] < 0 || 849 <
QI[it])
385 G4int icounter_max = 1024;
389 if (icounter > icounter_max) {
390 G4cout <<
"Loop-counter exceeded the threshold value at " << __LINE__ <<
"th line of "
391 << __FILE__ <<
"." <<
G4endl;
395 }
while (eSecN > MaxEne);
398 eGamm = eKinetic - eSecN;
399 for (iLevel = imaxEx; iLevel >= 0; --iLevel) {
400 if (
theGammas.GetLevelEnergy(iLevel) < eGamm)
break;
402 if (iLevel < imaxEx && iLevel >= 0) {
410 for (iLevel = imaxEx; iLevel >= 0; --iLevel) {
411 if (
theGammas.GetLevelEnergy(iLevel) < eKinetic)
break;
417 if (dqi < 0 || 849 < dqi) useQI =
true;
420 eExcitation = std::max(0.,
QI[0] -
QI[it]);
425 const G4double level_tolerance = 1.0 * CLHEP::keV;
429 for (iLevel = 1; iLevel <= imaxEx; ++iLevel) {
431 if (std::abs(eExcitation - elevel) < level_tolerance) {
435 if (eExcitation < elevel) {
437 iLevel = std::max(iLevel - 1, 0);
443 if (!find) iLevel = imaxEx;
447 if (
fManager->GetDEBUG() && eKinetic - eExcitation < 0) {
450 "SEVERE: InelasticCompFS: Consistency of data not good enough, please file report");
452 if (eKinetic - eExcitation < 0) eExcitation = 0;
458 thePhotons =
theGammas.GetDecayGammas(iLevel);
459 eGamm -=
theGammas.GetLevelEnergy(iLevel);
467 if (theParticles !=
nullptr) {
472 for (
G4int j = 0; j != (
G4int)theParticles->size(); ++j) {
473 auto ptr = theParticles->at(j);
474 G4int barnum = ptr->GetDefinition()->GetBaryonNumber();
480 sumZ +=
G4lrint(ptr->GetDefinition()->GetPDGCharge()/CLHEP::eplus);
485 if (dA < 0 || dZ < 0) {
486 G4int newA = theParticles->at(jAtMaxA)->GetDefinition()->GetBaryonNumber() + dA;
488 G4lrint(theParticles->at(jAtMaxA)->GetDefinition()->GetPDGCharge()/CLHEP::eplus) + dZ;
490 theParticles->at(jAtMaxA)->SetDefinition(pd);
496 nothingWasKnownOnHadron = 1;
503 boosted_tmp.
Lorentz(incidReactionProduct, theTarget);
508 if (thePhotons !=
nullptr && !thePhotons->empty()) {
509 aBaseEnergy -= (*thePhotons)[0]->GetTotalEnergy();
512 while (aBaseEnergy > 0.01 * CLHEP::keV)
515 G4bool foundMatchingLevel =
false;
518 for (
G4int j = 1; j < it; ++j) {
525 G4double deltaE = std::abs(testEnergy - aBaseEnergy);
526 if (deltaE < 0.1 * CLHEP::keV) {
528 if (thePhotons !=
nullptr) thePhotons->push_back(theNext->operator[](0));
529 aBaseEnergy = testEnergy - theNext->operator[](0)->GetTotalEnergy();
531 foundMatchingLevel =
true;
539 if (!foundMatchingLevel) {
541 if (thePhotons !=
nullptr) thePhotons->push_back(theNext->operator[](0));
542 aBaseEnergy = aBaseEnergy - theNext->operator[](0)->GetTotalEnergy();
549 if (thePhotons !=
nullptr) {
550 for (
auto const & p : *thePhotons) {
552 p->Lorentz(*p, -1. * theTarget);
555 if (nothingWasKnownOnHadron != 0) {
565 two_body_reaction(&incidReactionProduct, &theTarget, &aHadron, eExcitation);
566 if (thePhotons ==
nullptr && eExcitation > 0) {
567 for (iLevel = imaxEx; iLevel >= 0; --iLevel) {
568 if (
theGammas.GetLevelEnergy(iLevel) < eExcitation + 5 * keV)
break;
570 thePhotons =
theGammas.GetDecayGammas(iLevel);
582 G4bool needsSeparateRecoil =
false;
583 G4int totalBaryonNumber = 0;
584 G4int totalCharge = 0;
586 if (theParticles !=
nullptr) {
588 for (std::size_t ii0 = 0; ii0 < theParticles->size(); ++ii0) {
589 aDef = (*theParticles)[ii0]->GetDefinition();
592 totalMomentum += (*theParticles)[ii0]->GetMomentum();
594 if (totalBaryonNumber
597 needsSeparateRecoil =
true;
605 std::size_t nPhotons = 0;
606 if (thePhotons !=
nullptr) {
607 nPhotons = thePhotons->size();
612 if (theParticles ==
nullptr) {
619 G4cout <<
" G4ParticleHPInelasticCompFS::BaseApply add secondary1 "
625 aHadron.
Lorentz(aHadron, theTarget);
636 theResidual.
Lorentz(theResidual, -1. * theTarget);
638 if (thePhotons !=
nullptr) {
639 for (std::size_t i = 0; i < nPhotons; ++i) {
640 totalPhotonMomentum += (*thePhotons)[i]->GetMomentum();
649 G4cout <<
this <<
" G4ParticleHPInelasticCompFS::BaseApply add secondary2 "
656 for (std::size_t i0 = 0; i0 < theParticles->size(); ++i0) {
659 theSec->
SetMomentum((*theParticles)[i0]->GetMomentum());
663 G4cout <<
" G4ParticleHPInelasticCompFS::BaseApply add secondary3 "
668 delete (*theParticles)[i0];
671 if (needsSeparateRecoil && residualZ != 0) {
675 resiualKineticEnergy += totalMomentum * totalMomentum;
676 resiualKineticEnergy = std::sqrt(resiualKineticEnergy) - theResidual.
GetMass();
693 G4cout <<
" G4ParticleHPInelasticCompFS::BaseApply add secondary4 "
700 if (thePhotons !=
nullptr) {
701 for (std::size_t i = 0; i < nPhotons; ++i) {
707 theSec->
SetMomentum((*thePhotons)[i]->GetMomentum());
711 G4cout <<
" G4ParticleHPInelasticCompFS::BaseApply add secondary5 "
717 delete thePhotons->operator[](i);
void Init(G4double A, G4double Z, G4int M, const G4String &dirName, const G4String &aSFType, G4ParticleDefinition *) override