102 #define _CheckChargeAndBaryonNumber_(val) CheckChargeAndBaryonNumber(val)
105 #define _CheckChargeAndBaryonNumber_(val)
109 #define _DebugEpConservation(val) DebugEpConservation(val)
112 #define _DebugEpConservation(val)
115G4int G4BinaryCascade::theBIC_ID = -1;
129 theImR.push_back(theDecay);
132 theImR.push_back(aAb);
135 theImR.push_back(aSc);
141 theCutOnPAbsorb= 0*MeV;
155 thePrimaryEscape =
true;
164 projectileA=projectileZ=0;
165 currentInitialEnergy=initial_nuclear_mass=0.;
174 ClearAndDestroy(&theTargetList);
175 ClearAndDestroy(&theSecondaryList);
176 ClearAndDestroy(&theCapturedList);
177 delete thePropagator;
178 delete theCollisionMgr;
179 for(
auto & ptr : theImR) {
delete ptr; }
181 delete theLateParticle;
182 delete theH1Scatterer;
187 outFile <<
"G4BinaryCascade is an intra-nuclear cascade model in which\n"
188 <<
"an incident hadron collides with a nucleon, forming two\n"
189 <<
"final-state particles, one or both of which may be resonances.\n"
190 <<
"The resonances then decay hadronically and the decay products\n"
191 <<
"are then propagated through the nuclear potential along curved\n"
192 <<
"trajectories until they re-interact or leave the nucleus.\n"
193 <<
"This model is valid for incident pions up to 1.5 GeV and\n"
194 <<
"nucleons up to 10 GeV.\n"
195 <<
"The remaining excited nucleus is handed on to ";
201 else if (theExcitationHandler)
203 outFile <<
"G4ExcitationHandler";
204 theExcitationHandler->ModelDescription(outFile);
208 outFile <<
"void.\n";
214 outFile <<
"G4BinaryCascade propagtes secondaries produced by a high\n"
215 <<
"energy model through the wounded nucleus.\n"
216 <<
"Secondaries are followed after the formation time and if\n"
217 <<
"within the nucleus are propagated through the nuclear\n"
218 <<
"potential along curved trajectories until they interact\n"
219 <<
"with a nucleon, decay, or leave the nucleus.\n"
220 <<
"An interaction of a secondary with a nucleon produces two\n"
221 <<
"final-state particles, one or both of which may be resonances.\n"
222 <<
"Resonances decay hadronically and the decay products\n"
223 <<
"are in turn propagated through the nuclear potential along curved\n"
224 <<
"trajectories until they re-interact or leave the nucleus.\n"
225 <<
"This model is valid for pions up to 1.5 GeV and\n"
226 <<
"nucleons up to about 3.5 GeV.\n"
227 <<
"The remaining excited nucleus is handed on to ";
233 else if (theExcitationHandler)
235 outFile <<
"G4ExcitationHandler";
236 theExcitationHandler->ModelDescription(outFile);
240 outFile <<
"void.\n";
257 if(fBCDEBUG)
G4cerr <<
" ######### Binary Cascade Reaction starts ######### "<<
G4endl;
262 if(initial4Momentum.
e()-initial4Momentum.
m()<theBCminP &&
284 G4cerr <<
"G4BinaryCascade should not be used for projectiles other than nucleons or pions."<<
G4endl;
285 G4cerr <<
"If you want to continue, please switch on the developer environment: "<<
G4endl;
287 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade - used for unvalid particle type - Fatal");
292 thePrimaryType = definition;
293 thePrimaryEscape =
false;
299 G4int interactionCounter = 0,collisionLoopMaxCount;
303 theCollisionMgr->ClearAndDestroy();
305 if(products !=
nullptr)
307 ClearAndDestroy(products);
315 collisionLoopMaxCount = 200;
320 initialPosition=GetSpherePoint(1.1*radius, initial4Momentum);
321 kt =
new G4KineticTrack(definition, 0., initialPosition, initial4Momentum);
325 secondaries->push_back(kt);
333 }
while(! products && --collisionLoopMaxCount>0);
335 if(++interactionCounter>99)
break;
337 }
while(products && products->size() == 0);
339 if(products && products->size()>0)
345 G4ReactionProductVector::iterator iter;
347 for(iter = products->begin(); iter != products->end(); ++iter)
351 (*iter)->GetTotalEnergy(),
352 (*iter)->GetMomentum());
354 G4double time=(*iter)->GetFormationTime();
355 if(time < 0.0) { time = 0.0; }
356 aNew.
SetTime(timePrimary + time);
367 if(fBCDEBUG)
G4cerr <<
" ######### Binary Cascade Reaction void, return initial state ######### "<<
G4endl;
375 ClearAndDestroy(products);
382 if(fBCDEBUG)
G4cerr <<
" ######### Binary Cascade Reaction ends ######### "<<
G4endl;
391 G4ping debug(
"debug_G4BinaryCascade");
392#ifdef debug_BIC_Propagate
393 G4cout <<
"G4BinaryCascade Propagate starting -------------------------------------------------------" <<
G4endl;
403 ClearAndDestroy(&theCapturedList);
404 ClearAndDestroy(&theSecondaryList);
405 theSecondaryList.clear();
406 ClearAndDestroy(&theFinalState);
407 std::vector<G4KineticTrack *>::iterator iter;
408 theCollisionMgr->ClearAndDestroy();
418#ifdef debug_BIC_GetExcitationEnergy
419 G4cout <<
"ExcitationEnergy0 " << GetExcitationEnergy() <<
G4endl;
424 G4bool success = BuildLateParticleCollisions(secondaries);
427 products=HighEnergyModelFSProducts(products, secondaries);
428 ClearAndDestroy(secondaries);
431#ifdef debug_G4BinaryCascade
432 G4cout <<
"G4BinaryCascade::Propagate: warning - high energy model failed energy conservation, returning unchanged high energy final state" <<
G4endl;
443 FindCollisions(&theSecondaryList);
446 if(theCollisionMgr->Entries() == 0 )
450#ifdef debug_BIC_return
460 G4bool haveProducts =
false;
461#ifdef debug_BIC_Propagate_Collisions
462 G4int collisionCount=0;
464 G4int collisionLoopMaxCount=1000000;
465 while(theCollisionMgr->Entries() > 0 && currentZ && --collisionLoopMaxCount>0)
476 if(theCollisionMgr->Entries() > 0)
479 nextCollision = theCollisionMgr->GetNextCollision();
480#ifdef debug_BIC_Propagate_Collisions
481 G4cout <<
" NextCollision * , Time, curtime = " << nextCollision <<
" "
488 if (theCollisionMgr->GetNextCollision() != nextCollision )
490 nextCollision =
nullptr;
497 if (ApplyCollision(nextCollision))
501#ifdef debug_BIC_Propagate_Collisions
507 theCollisionMgr->RemoveCollision(nextCollision);
516 for(iter = theTargetList.begin(); iter != theTargetList.end(); ++iter)
520 if ( ! theTargetList.size() || ! nProtons ){
522 products = FillVoidNucleusProducts(products);
523#ifdef debug_BIC_return
524 G4cout <<
"return @ Z=0 after collision loop "<<
G4endl;
525 PrintKTVector(&theSecondaryList,std::string(
" theSecondaryList"));
526 G4cout <<
"theTargetList size: " << theTargetList.size() <<
G4endl;
527 PrintKTVector(&theTargetList,std::string(
" theTargetList"));
528 PrintKTVector(&theCapturedList,std::string(
" theCapturedList"));
530 G4cout <<
" ExcitE be4 Correct : " <<GetExcitationEnergy() <<
G4endl;
531 G4cout <<
" Mom Transfered to nucleus : " << theMomentumTransfer <<
" " << theMomentumTransfer.mag() <<
G4endl;
532 PrintKTVector(&theFinalState,std::string(
" FinalState uncorrected"));
533 G4cout <<
"returned products: " << products->size() <<
G4endl;
554#ifdef debug_BIC_return
561#ifdef debug_BIC_Propagate
562 G4cout <<
" Momentum transfer to Nucleus " << theMomentumTransfer <<
" " << theMomentumTransfer.mag() <<
G4endl;
570 if ( theSecondaryList.size() > 0 )
572#ifdef debug_G4BinaryCascade
573 G4cerr <<
"G4BinaryCascade: Warning, have active particles at end" <<
G4endl;
574 PrintKTVector(&theSecondaryList,
"active particles @ end added to theFinalState");
577 for ( iter =theSecondaryList.begin(); iter != theSecondaryList.end(); ++iter)
579 theFinalState.push_back(*iter);
581 theSecondaryList.clear();
584 while ( theCollisionMgr->Entries() > 0 )
586#ifdef debug_G4BinaryCascade
587 G4cerr <<
" Warning: remove left over collision(s) " <<
G4endl;
589 theCollisionMgr->RemoveCollision(theCollisionMgr->GetNextCollision());
592#ifdef debug_BIC_Propagate_Excitation
594 PrintKTVector(&theSecondaryList,std::string(
" theSecondaryList"));
595 G4cout <<
"theTargetList size: " << theTargetList.size() <<
G4endl;
597 PrintKTVector(&theCapturedList,std::string(
" theCapturedList"));
599 G4cout <<
" ExcitE be4 Correct : " <<GetExcitationEnergy() <<
G4endl;
600 G4cout <<
" Mom Transfered to nucleus : " << theMomentumTransfer <<
" " << theMomentumTransfer.mag() <<
G4endl;
601 PrintKTVector(&theFinalState,std::string(
" FinalState uncorrected"));
607 G4double ExcitationEnergy=GetExcitationEnergy();
609#ifdef debug_BIC_Propagate_finals
610 PrintKTVector(&theFinalState,std::string(
" FinalState be4 corr"));
611 G4cout <<
" Excitation Energy prefinal, #collisions:, out, captured "
612 << ExcitationEnergy <<
" "
613 << collisionCount <<
" "
614 << theFinalState.size() <<
" "
615 << theCapturedList.size()<<
G4endl;
618 if (ExcitationEnergy < 0 )
620 G4int maxtry=5, ntry=0;
623 ExcitationEnergy=GetExcitationEnergy();
624 }
while ( ++ntry < maxtry && ExcitationEnergy < 0 );
628#ifdef debug_BIC_Propagate_finals
629 PrintKTVector(&theFinalState,std::string(
" FinalState corrected"));
630 G4cout <<
" Excitation Energy final, #collisions:, out, captured "
631 << ExcitationEnergy <<
" "
632 << collisionCount <<
" "
633 << theFinalState.size() <<
" "
634 << theCapturedList.size()<<
G4endl;
638 if ( ExcitationEnergy < 0. )
640 #ifdef debug_G4BinaryCascade
641 G4cerr <<
"G4BinaryCascade-Warning: negative excitation energy ";
643 PrintKTVector(&theFinalState,std::string(
"FinalState"));
644 PrintKTVector(&theCapturedList,std::string(
"captured"));
645 G4cout <<
"negative ExE:Final 4Momentum .mag: " << GetFinal4Momentum()
646 <<
" "<< GetFinal4Momentum().mag()<<
G4endl
647 <<
"negative ExE:FinalNucleusMom .mag: " << GetFinalNucleusMomentum()
648 <<
" "<< GetFinalNucleusMomentum().mag()<<
G4endl;
650 #ifdef debug_BIC_return
651 G4cout <<
" negative Excitation E return empty products " << products <<
G4endl;
655 ClearAndDestroy(products);
665 products= ProductsAddFinalState(products, theFinalState);
667 products= ProductsAddPrecompound(products, precompoundProducts);
672 thePrimaryEscape =
true;
674 #ifdef debug_BIC_return
683G4double G4BinaryCascade::GetExcitationEnergy()
688#if defined(debug_G4BinaryCascade) || defined(debug_BIC_GetExcitationEnergy)
689 G4int finalA = theTargetList.size()+theCapturedList.size();
690 G4int finalZ = GetTotalCharge(theTargetList)+GetTotalCharge(theCapturedList);
691 if ( (currentA - finalA) != 0 || (currentZ - finalZ) != 0 )
693 G4cerr <<
"G4BIC:GetExcitationEnergy(): Nucleon counting error current/final{A,Z} "
694 <<
"("<< currentA <<
"," << finalA <<
") ("<< currentZ <<
"," << finalZ <<
")" <<
G4endl;
703 nucleusMass = GetIonMass(currentZ,currentA);
705 else if (currentZ==0 )
708 else {nucleusMass = GetFinalNucleusMomentum().mag() - 3.*MeV*currentA;}
712#ifdef debug_G4BinaryCascade
713 G4cout <<
"G4BinaryCascade::GetExcitationEnergy(): Warning - invalid nucleus (A,Z)=("
714 << currentA <<
"," << currentZ <<
")" <<
G4endl;
719#ifdef debug_BIC_GetExcitationEnergy
720 G4ping debug(
"debug_ExcitationEnergy");
721 debug.push_back(
"====> current A, Z");
722 debug.push_back(currentZ);
723 debug.push_back(currentA);
724 debug.push_back(
"====> final A, Z");
725 debug.push_back(finalZ);
726 debug.push_back(finalA);
727 debug.push_back(nucleusMass);
728 debug.push_back(GetFinalNucleusMomentum().mag());
734 excitationE = GetFinalNucleusMomentum().mag() - nucleusMass;
740#ifdef debug_BIC_GetExcitationEnergy
742 if ( excitationE < 0 )
744 G4cout <<
"negative ExE final Ion mass " <<nucleusMass<<
G4endl;
746 if(finalZ>.5)
G4cout <<
" Final nuclmom/mass " << Nucl_mom <<
" " << Nucl_mom.
mag()
747 <<
" (A,Z)=("<< finalA <<
","<<finalZ <<
")"
748 <<
" mass " << nucleusMass <<
" "
749 <<
" excitE " << excitationE <<
G4endl;
757 initialExc = theInitial4Mom.mag()- GetIonMass(Z,
A);
758 G4cout <<
"GetExcitationEnergy: Initial nucleus A Z " <<
A <<
" " << Z <<
" " << initialExc <<
G4endl;
775void G4BinaryCascade::BuildTargetList()
786 ClearAndDestroy(&theTargetList);
789 const G4ParticleDefinition * definition;
795 initial_nuclear_mass=GetIonMass(initialZ,initialA);
799 while((nucleon =
the3DNucleus->GetNextNucleon()) !=
nullptr)
804 definition =
nucleon->GetDefinition();
811 G4KineticTrack * kt =
new G4KineticTrack(definition, 0., pos, mom);
814 theTargetList.push_back(kt);
819#ifdef debug_BIC_BuildTargetList
826 massInNucleus = GetIonMass(currentZ,currentA);
827 }
else if (currentZ==0 && currentA>=1 )
832 G4cerr <<
"G4BinaryCascade::BuildTargetList(): Fatal Error - invalid nucleus (A,Z)=("
833 << currentA <<
"," << currentZ <<
")" <<
G4endl;
834 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCasacde::BuildTargetList()");
836 currentInitialEnergy= theInitial4Mom.e() + theProjectile4Momentum.e();
838#ifdef debug_BIC_BuildTargetList
839 G4cout <<
"G4BinaryCascade::BuildTargetList(): nucleus (A,Z)=("
840 << currentA <<
"," << currentZ <<
") mass: " << massInNucleus <<
841 ", theInitial4Mom " << theInitial4Mom <<
842 ", currentInitialEnergy " << currentInitialEnergy <<
G4endl;
852 std::vector<G4KineticTrack *>::iterator iter;
855 projectileA=projectileZ=0;
858 for(iter = secondaries->begin(); iter != secondaries->end(); ++iter)
860 if((*iter)->GetFormationTime() < StartingTime)
861 StartingTime = (*iter)->GetFormationTime();
866 for(iter = secondaries->begin(); iter != secondaries->end(); ++iter)
870 G4double FormTime = (*iter)->GetFormationTime() - StartingTime;
871 (*iter)->SetFormationTime(FormTime);
874 FindLateParticleCollision(*iter);
875 lateParticles4Momentum += (*iter)->GetTrackingMomentum();
876 lateA += (*iter)->GetDefinition()->GetBaryonNumber();
877 lateZ +=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
881 theSecondaryList.push_back(*iter);
883 theProjectile4Momentum += (*iter)->GetTrackingMomentum();
884 projectileA += (*iter)->GetDefinition()->GetBaryonNumber();
885 projectileZ +=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
886#ifdef debug_BIC_Propagate
887 G4cout <<
" Adding initial secondary " << *iter
888 <<
" time" << (*iter)->GetFormationTime()
889 <<
", state " << (*iter)->GetState() <<
G4endl;
898 theProjectile4Momentum += mom;
902 G4double excitation= theProjectile4Momentum.e() + initial_nuclear_mass - lateParticles4Momentum.e() - massInNucleus;
903#ifdef debug_BIC_GetExcitationEnergy
904 G4cout <<
"BIC: Proj.e, nucl initial, nucl final, lateParticles"
905 << theProjectile4Momentum <<
", "
906 << initial_nuclear_mass<<
", " << massInNucleus <<
", "
907 << lateParticles4Momentum <<
G4endl;
908 G4cout <<
"BIC: Proj.e / initial excitation: " << theProjectile4Momentum.e() <<
" / " << excitation <<
G4endl;
910 success = excitation > 0;
911#ifdef debug_G4BinaryCascade
913 G4cout <<
"G4BinaryCascade::BuildLateParticleCollisions(): Proj.e / initial excitation: " << theProjectile4Momentum.e() <<
" / " << excitation <<
G4endl;
923 secondaries->clear();
934 G4Fragment * fragment =
nullptr;
940 fragment = FindFragments();
952 else if (theExcitationHandler)
954 precompoundProducts=theExcitationHandler->BreakItUp(*fragment);
959 if (theTargetList.size() + theCapturedList.size() > 1 ) {
960 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCasacde:: Invalid Fragment");
963 std::vector<G4KineticTrack *>::iterator i;
964 if ( theTargetList.size() == 1 ) {i=theTargetList.begin();}
965 if ( theCapturedList.size() == 1 ) {i=theCapturedList.begin();}
966 G4ReactionProduct * aNew =
new G4ReactionProduct((*i)->GetDefinition());
973 precompoundProducts->push_back(aNew);
981 precompoundProducts = DecayVoidNucleus();
983 #ifdef debug_BIC_DeexcitationProducts
987 if ( precompoundProducts )
989 std::vector<G4ReactionProduct *>::iterator j;
990 for(j = precompoundProducts->begin(); j != precompoundProducts->end(); ++j)
993 Preco_momentum += pProduct;
996 G4cout <<
"finalNuclMom / sum preco products" << fragment_momentum <<
" / " << Preco_momentum
997 <<
" delta E "<< fragment_momentum.
e() - Preco_momentum.
e() <<
G4endl;
1001 return precompoundProducts;
1009 if ( (theTargetList.size()+theCapturedList.size()) > 0 )
1012 std::vector<G4KineticTrack *>::iterator aNuc;
1014 std::vector<G4double> masses;
1017 if ( theTargetList.size() != 0)
1019 for ( aNuc=theTargetList.begin(); aNuc != theTargetList.end(); aNuc++)
1021 G4double mass=(*aNuc)->GetDefinition()->GetPDGMass();
1022 masses.push_back(mass);
1027 if ( theCapturedList.size() != 0)
1029 for(aNuc = theCapturedList.begin(); aNuc != theCapturedList.end(); aNuc++)
1031 G4double mass=(*aNuc)->GetDefinition()->GetPDGMass();
1032 masses.push_back(mass);
1038 G4FermiPhaseSpaceDecay
decay;
1043 if ( eCMS < sumMass )
1045 eCMS=sumMass + 2*MeV*masses.size();
1049 precompoundLorentzboost.set(finalP.
boostVector());
1050 std::vector<G4LorentzVector*> * momenta=
decay.Decay(eCMS,masses);
1051 std::vector<G4LorentzVector*>::iterator aMom=momenta->begin();
1054 if ( theTargetList.size() != 0)
1056 for ( aNuc=theTargetList.begin();
1057 (aNuc != theTargetList.end()) && (aMom!=momenta->end());
1060 G4ReactionProduct * aNew =
new G4ReactionProduct((*aNuc)->GetDefinition());
1066 result->push_back(aNew);
1071 if ( theCapturedList.size() != 0)
1073 for ( aNuc=theCapturedList.begin();
1074 (aNuc != theCapturedList.end()) && (aMom!=momenta->end());
1077 G4ReactionProduct * aNew =
new G4ReactionProduct((*aNuc)->GetDefinition());
1083 result->push_back(aNew);
1099#ifdef debug_BIC_Propagate_finals
1102 for(i = 0; i< fs.size(); i++)
1104 G4KineticTrack * kt = fs[i];
1105 G4ReactionProduct * aNew =
new G4ReactionProduct(kt->
GetDefinition());
1112 products->push_back(aNew);
1114#ifdef debug_BIC_Propagate_finals
1124#ifdef debug_BIC_Propagate_finals
1125 G4cout <<
" Final state momentum " << mom_fs <<
G4endl;
1136 if ( precompoundProducts )
1138 for(
auto j = precompoundProducts->cbegin(); j != precompoundProducts->cend(); ++j)
1143#ifdef debug_BIC_Propagate_finals
1144 G4cout <<
"BIC: pProduct be4 boost " <<pProduct <<
G4endl;
1146 pProduct *= precompoundLorentzboost;
1147#ifdef debug_BIC_Propagate_finals
1148 G4cout <<
"BIC: pProduct aft boost " <<pProduct <<
G4endl;
1150 pSumPreco += pProduct;
1151 (*j)->SetTotalEnergy(pProduct.e());
1152 (*j)->SetMomentum(pProduct.vect());
1153 (*j)->SetNewlyAdded(
true);
1154 products->push_back(*j);
1158 precompoundProducts->clear();
1159 delete precompoundProducts;
1167 for(
auto i=secondaries->cbegin(); i!=secondaries->cend(); ++i)
1169 for(
auto j=theImR.cbegin(); j!=theImR.cend(); ++j)
1172 const std::vector<G4CollisionInitialState *> & aCandList
1173 = (*j)->GetCollisions(*i, theTargetList, theCurrentTime);
1174 for(std::size_t count=0; count<aCandList.size(); ++count)
1176 theCollisionMgr->AddCollision(aCandList[count]);
1186void G4BinaryCascade::FindDecayCollision(
G4KineticTrack * secondary)
1189 const auto& aCandList = theDecay->GetCollisions(secondary, theTargetList, theCurrentTime);
1190 for(std::size_t count=0; count<aCandList.size(); ++count)
1192 theCollisionMgr->AddCollision(aCandList[count]);
1197void G4BinaryCascade::FindLateParticleCollision(
G4KineticTrack * secondary)
1202 if (((G4RKPropagation*)thePropagator)->GetSphereIntersectionTimes(secondary,tin,tout))
1207 }
else if ( tout > 0 )
1220#ifdef debug_BIC_FindCollision
1221 G4cout <<
"FindLateP Particle, 4-mom, times newState "
1224 <<
" times " << tin <<
" " << tout <<
" "
1228 const auto& aCandList = theLateParticle->GetCollisions(secondary, theTargetList, theCurrentTime);
1229 for(std::size_t count=0; count<aCandList.size(); ++count)
1231#ifdef debug_BIC_FindCollision
1232 G4cout <<
" Adding a late Col : " << aCandList[count] <<
G4endl;
1234 theCollisionMgr->AddCollision(aCandList[count]);
1243 G4KineticTrack * primary = collision->
GetPrimary();
1245#ifdef debug_BIC_ApplyCollision
1246 G4cerr <<
"G4BinaryCascade::ApplyCollision start"<<
G4endl;
1247 theCollisionMgr->Print();
1252 G4bool haveTarget=target_collection.size()>0;
1255#ifdef debug_G4BinaryCascade
1256 G4cout <<
"G4BinaryCasacde::ApplyCollision(): StateError " << primary <<
G4endl;
1257 PrintKTVector(primary,std::string(
"primay- ..."));
1258 PrintKTVector(&target_collection,std::string(
"... targets"));
1261 theCollisionMgr->Print();
1278 G4int initialBaryon(0);
1279 G4int initialCharge(0);
1287 G4double initial_Efermi=CorrectShortlivedPrimaryForFermi(primary,std::move(target_collection));
1291 G4KineticTrackVector * products = collision->
GetFinalState();
1293#ifdef debug_BIC_ApplyCollision
1294 DebugApplyCollisionFail(collision, products);
1300 G4bool lateParticleCollision= (!haveTarget) && products && products->size() == 1;
1301 G4bool decayCollision= (!haveTarget) && products && products->size() > 1;
1305#ifdef debug_G4BinaryCascade
1306 G4int lateBaryon(0), lateCharge(0);
1309 if ( lateParticleCollision )
1313#ifdef debug_G4BinaryCascade
1314 lateBaryon = initialBaryon;
1315 lateCharge = initialCharge;
1317 initialBaryon=initialCharge=0;
1324 if (!lateParticleCollision)
1326 if( !products || products->size()==0 || !CheckPauliPrinciple(products) )
1328#ifdef debug_BIC_ApplyCollision
1329 if (products)
G4cout <<
" ======Failed Pauli =====" <<
G4endl;
1330 G4cerr <<
"G4BinaryCascade::ApplyCollision blocked"<<
G4endl;
1338 if (! CorrectShortlivedFinalsForFermi(products, initial_Efermi)){
1344#ifdef debug_BIC_ApplyCollision
1345 DebugApplyCollision(collision, products);
1349 if (products) ClearAndDestroy(products);
1350 if ( decayCollision ) FindDecayCollision(primary);
1356 G4int finalBaryon(0);
1357 G4int finalCharge(0);
1358 G4KineticTrackVector toFinalState;
1359 for(
auto i=products->cbegin(); i!=products->cend(); ++i)
1361 if ( ! lateParticleCollision )
1363 (*i)->SetState(primary->
GetState());
1365 finalBaryon+=(*i)->GetDefinition()->GetBaryonNumber();
1366 finalCharge+=
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus);
1369 if (((G4RKPropagation*)thePropagator)->GetSphereIntersectionTimes((*i),tin,tout) &&
1370 tin < 0 && tout > 0 )
1372 PrintKTVector((*i),
"particle inside marked not-inside");
1373 G4cout <<
"tin tout: " << tin <<
" " << tout <<
G4endl;
1378 if (((G4RKPropagation*)thePropagator)->GetSphereIntersectionTimes((*i),tin,tout))
1385 else if ( tout > 0 )
1388 finalBaryon+=(*i)->GetDefinition()->GetBaryonNumber();
1389 finalCharge+=
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus);
1394 toFinalState.push_back((*i));
1400 toFinalState.push_back((*i));
1405 if(!toFinalState.empty())
1407 theFinalState.insert(theFinalState.cend(),
1408 toFinalState.cbegin(),toFinalState.cend());
1409 std::vector<G4KineticTrack *>::iterator iter2;
1410 for(
auto iter1=toFinalState.cbegin(); iter1!=toFinalState.cend(); ++iter1)
1412 iter2 = std::find(products->begin(), products->end(), *iter1);
1413 if ( iter2 != products->cend() ) products->erase(iter2);
1415 theCollisionMgr->RemoveTracksCollisions(&toFinalState);
1419 currentA += finalBaryon-initialBaryon;
1420 currentZ += finalCharge-initialCharge;
1423 G4KineticTrackVector oldSecondaries;
1424 oldSecondaries.push_back(primary);
1427#ifdef debug_G4BinaryCascade
1428 if ( (finalBaryon-initialBaryon-lateBaryon) != 0 || (finalCharge-initialCharge-lateCharge) != 0 )
1430 G4cout <<
"G4BinaryCascade: Error in Balancing: " <<
G4endl;
1431 G4cout <<
"initial/final baryon number, initial/final Charge "
1432 << initialBaryon <<
" "<< finalBaryon <<
" "
1433 << initialCharge <<
" "<< finalCharge <<
" "
1434 <<
" in Collision type: "<<
typeid(*collision->
GetGenerator()).name()
1435 <<
", with number of products: "<< products->size() <<
G4endl;
1449 for(std::size_t ii=0; ii< oldTarget.size(); ++ii)
1451 oldTarget[ii]->Hit();
1454 UpdateTracksAndCollisions(&oldSecondaries, &oldTarget, products);
1455 std::for_each(oldSecondaries.cbegin(), oldSecondaries.cend(), Delete<G4KineticTrack>());
1456 std::for_each(oldTarget.cbegin(), oldTarget.cend(), Delete<G4KineticTrack>());
1464G4bool G4BinaryCascade::Absorb()
1468 G4Absorber absorber(theCutOnPAbsorb);
1471 G4KineticTrackVector absorbList;
1472 std::vector<G4KineticTrack *>::const_iterator iter;
1474 for(iter = theSecondaryList.cbegin();
1475 iter != theSecondaryList.cend(); ++iter)
1477 G4KineticTrack * kt = *iter;
1480 if(absorber.WillBeAbsorbed(*kt))
1482 absorbList.push_back(kt);
1487 if(absorbList.empty())
1490 G4KineticTrackVector toDelete;
1491 for(iter = absorbList.cbegin(); iter != absorbList.cend(); ++iter)
1493 G4KineticTrack * kt = *iter;
1494 if(!absorber.FindAbsorbers(*kt, theTargetList))
1495 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::Absorb(): Cannot absorb a particle.");
1497 if(!absorber.FindProducts(*kt))
1498 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::Absorb(): Cannot absorb a particle.");
1500 G4KineticTrackVector * products = absorber.GetProducts();
1501 G4int maxLoopCount = 1000;
1502 while(!CheckPauliPrinciple(products) && --maxLoopCount>0)
1504 ClearAndDestroy(products);
1505 if(!absorber.FindProducts(*kt))
1506 throw G4HadronicException(__FILE__, __LINE__,
1507 "G4BinaryCascade::Absorb(): Cannot absorb a particle.");
1509 if ( --maxLoopCount < 0 )
throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::Absorb(): Cannot absorb a particle.");
1513 G4KineticTrackVector toRemove;
1514 toRemove.push_back(kt);
1515 toDelete.push_back(kt);
1516 G4KineticTrackVector * absorbers = absorber.GetAbsorbers();
1517 UpdateTracksAndCollisions(&toRemove, absorbers, products);
1518 ClearAndDestroy(absorbers);
1520 ClearAndDestroy(&toDelete);
1531 G4KineticTrackVector captured;
1533 std::vector<G4KineticTrack *>::const_iterator i;
1535 G4RKPropagation * RKprop=(G4RKPropagation *)thePropagator;
1538 G4int particlesAboveCut=0;
1539 G4int particlesBelowCut=0;
1540 if ( verbose )
G4cout <<
" Capture: secondaries " << theSecondaryList.size() <<
G4endl;
1541 for(i = theSecondaryList.cbegin(); i != theSecondaryList.cend(); ++i)
1543 G4KineticTrack * kt = *i;
1558 ++particlesBelowCut;
1566 if (verbose)
G4cout <<
"Capture particlesAboveCut,particlesBelowCut, capturedEnergy,capturedEnergy/particlesBelowCut <? 0.2*theCutOnP "
1567 << particlesAboveCut <<
" " << particlesBelowCut <<
" " << capturedEnergy
1571 if(particlesBelowCut>0 && capturedEnergy/particlesBelowCut<0.2*theCutOnP)
1574 for(i = theSecondaryList.cbegin(); i != theSecondaryList.cend(); ++i)
1576 G4KineticTrack * kt = *i;
1582 captured.push_back(kt);
1584 theCapturedList.push_back(kt);
1588 UpdateTracksAndCollisions(&captured,
nullptr,
nullptr);
1602 G4FermiMomentum fermiMom;
1603 fermiMom.
Init(
A, Z);
1605 const G4VNuclearDensity * density=
the3DNucleus->GetNuclearDensity();
1607 G4KineticTrackVector::const_iterator i;
1608 const G4ParticleDefinition * definition;
1614 for(i = products->cbegin(); i != products->cend(); ++i)
1616 definition = (*i)->GetDefinition();
1642 if(mom.
e() < eFermi )
1651#ifdef debug_BIC_CheckPauli
1654 for(i = products->cbegin(); i != products->cend(); ++i)
1656 definition = (*i)->GetDefinition();
1665 if ( mom.
e()-mom.
mag()+field > 160*MeV )
1667 G4cout <<
"momentum problem pFermi=" << pFermi
1668 <<
" mom, mom.m " << mom <<
" " << mom.
mag()
1669 <<
" field " << field <<
G4endl;
1680void G4BinaryCascade::StepParticlesOut()
1687 while( theSecondaryList.size() > 0 )
1692 for(
auto i = theSecondaryList.cbegin(); i != theSecondaryList.cend(); ++i)
1694 G4KineticTrack * kt = *i;
1699 ((G4RKPropagation*)thePropagator)->GetSphereIntersectionTimes(kt,tdummy,tStep);
1700#ifdef debug_BIC_StepParticlesOut
1701 G4cout <<
" minTimeStep, tStep Particle " <<minTimeStep <<
" " <<tStep
1706 PrintKTVector(&theSecondaryList, std::string(
" state ERROR....."));
1707 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::StepParticlesOut() particle not in nucleus");
1710 if(intersect && tStep<minTimeStep && tStep> 0 )
1712 minTimeStep = tStep;
1715 PrintKTVector(&theSecondaryList, std::string(
" state ERROR....."));
1716 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::StepParticlesOut() particle not in nucleus");
1721 G4CollisionInitialState * nextCollision=
nullptr;
1722 if(theCollisionMgr->Entries() > 0)
1724 nextCollision = theCollisionMgr->GetNextCollision();
1728 if ( timeToCollision > minTimeStep )
1730 DoTimeStep(minTimeStep);
1734 if (!DoTimeStep(timeToCollision) )
1737 if (theCollisionMgr->GetNextCollision() != nextCollision )
1739 nextCollision =
nullptr;
1746 if ( ApplyCollision(nextCollision))
1751 theCollisionMgr->RemoveCollision(nextCollision);
1758#ifdef debug_G4BinaryCascade
1759 G4cerr <<
"G4BinaryCascade.cc: Warning - aborting looping particle(s)" <<
G4endl;
1760 PrintKTVector(&theSecondaryList,
" looping particles added to theFinalState");
1764 for (
auto iter=theSecondaryList.cbegin(); iter!=theSecondaryList.cend(); ++iter)
1766 theFinalState.push_back(*iter);
1768 theSecondaryList.clear();
1782#ifdef debug_BIC_StepParticlesOut
1786 if ( counter > 100 && theCollisionMgr->Entries() == 0)
1788#ifdef debug_BIC_StepParticlesOut
1789 PrintKTVector(&theSecondaryList,std::string(
"stepping 100 steps"));
1791 FindCollisions(&theSecondaryList);
1799 #ifdef debug_BIC_return
1800 G4cout <<
"return @ Z=0 after collision loop "<<
G4endl;
1801 PrintKTVector(&theSecondaryList,std::string(
" theSecondaryList"));
1802 G4cout <<
"theTargetList size: " << theTargetList.size() <<
G4endl;
1803 PrintKTVector(&theTargetList,std::string(
" theTargetList"));
1804 PrintKTVector(&theCapturedList,std::string(
" theCapturedList"));
1806 G4cout <<
" ExcitE be4 Correct : " <<GetExcitationEnergy() <<
G4endl;
1807 G4cout <<
" Mom Transfered to nucleus : " << theMomentumTransfer <<
" " << theMomentumTransfer.mag() <<
G4endl;
1808 PrintKTVector(&theFinalState,std::string(
" FinalState uncorrected"));
1822G4double G4BinaryCascade::CorrectShortlivedPrimaryForFermi(
1829 Efermi=((G4RKPropagation *)thePropagator)->GetField(PDGcode,primary->
GetPosition());
1831 if ( std::abs(PDGcode) > 1000 && PDGcode != 2112 && PDGcode != 2212 )
1838 for (
auto titer=target_collection.cbegin() ; titer!=target_collection.cend(); ++titer)
1840 const G4ParticleDefinition * aDef=(*titer)->GetDefinition();
1843 Efermi+= ((G4RKPropagation *)thePropagator)->GetField(aCode, aPos);
1855 G4KineticTrackVector resonances;
1856 for (
auto i =products->cbegin(); i != products->cend(); ++i)
1858 G4int PDGcode=(*i)->GetDefinition()->GetPDGEncoding();
1860 final_Efermi+=((G4RKPropagation *)thePropagator)->GetField(PDGcode,(*i)->GetPosition());
1861 if ( std::abs(PDGcode) > 1000 && PDGcode != 2112 && PDGcode != 2212 )
1863 resonances.push_back(*i);
1866 if ( resonances.size() > 0 )
1868 G4double delta_Fermi= (initial_Efermi-final_Efermi)/resonances.size();
1869 for (
auto res=resonances.cbegin(); res != resonances.cend(); ++res)
1873 G4double newEnergy=mom.
e() + delta_Fermi;
1874 G4double newEnergy2= newEnergy*newEnergy;
1876 if ( newEnergy2 < mass2 )
1890void G4BinaryCascade::CorrectFinalPandE()
1898#ifdef debug_BIC_CorrectFinalPandE
1902 if ( theFinalState.size() == 0 )
return;
1904 G4KineticTrackVector::const_iterator i;
1906 if ( pNucleus.
e() == 0 )
return;
1907#ifdef debug_BIC_CorrectFinalPandE
1911 for(i = theFinalState.cbegin(); i != theFinalState.cend(); ++i)
1913 pFinals += (*i)->Get4Momentum();
1914#ifdef debug_BIC_CorrectFinalPandE
1915 G4cout <<
"CorrectFinalPandE a final " << (*i)->GetDefinition()->GetParticleName()
1916 <<
" 4mom " << (*i)->Get4Momentum()<<
G4endl;
1919#ifdef debug_BIC_CorrectFinalPandE
1920 G4cout <<
"CorrectFinalPandE pN pF: " <<pNucleus <<
" " <<pFinals <<
G4endl;
1926#ifdef debug_BIC_CorrectFinalPandE
1927 G4cout <<
"CorrectFinalPandE pCM, CMS pCM " << pCM <<
" " <<toCMS*pCM<<
G4endl;
1928 G4cout <<
"CorrectFinal CMS pN pF " <<toCMS*pNucleus <<
" "
1930 <<
" nucleus initial mass : " <<GetFinal4Momentum().
mag()
1931 <<
" massInNucleus m(nucleus) m(finals) std::sqrt(s): " << massInNucleus <<
" " <<pNucleus.
mag()<<
" "
1932 << pFinals.mag() <<
" " << pCM.
mag() <<
G4endl;
1938 G4double m10 = GetIonMass(currentZ,currentA);
1940 if( s0-(m10+m20)*(m10+m20) < 0 )
1942#ifdef debug_BIC_CorrectFinalPandE
1943 G4cout <<
"G4BinaryCascade::CorrectFinalPandE() : error! " <<
G4endl;
1945 G4cout <<
"not enough mass to correct: mass^2, A,Z, mass(nucl), mass(finals) "
1946 << (
s0-(m10+m20)*(m10+m20)) <<
" "
1947 << currentA <<
" " << currentZ <<
" "
1948 << m10 <<
" " << m20
1952 PrintKTVector(&theFinalState,
" mass problem");
1958 G4double pInCM = std::sqrt((s0-(m10+m20)*(m10+m20))*(s0-(m10-m20)*(m10-m20))/(4.*s0));
1959#ifdef debug_BIC_CorrectFinalPandE
1960 G4cout <<
" CorrectFinalPandE pInCM new, CURRENT, ratio : " << pInCM
1961 <<
" " << (pFinals).vect().mag()<<
" " << pInCM/(pFinals).vect().mag() <<
G4endl;
1963 if ( pFinals.vect().mag() > pInCM )
1967 G4double factor=std::max(0.98,pInCM/pFinals.vect().mag());
1969 for(i = theFinalState.cbegin(); i != theFinalState.cend(); ++i)
1972 G4ThreeVector p3(factor*(toCMS*(*i)->Get4Momentum()).vect());
1973 G4LorentzVector p(p3,std::sqrt((*i)->Get4Momentum().mag2() + p3.mag2()));
1976#ifdef debug_BIC_CorrectFinalPandE
1979 (*i)->Set4Momentum(p);
1981#ifdef debug_BIC_CorrectFinalPandE
1982 G4cout <<
"CorrectFinalPandE nucleus corrected mass : " << GetFinal4Momentum() <<
" "
1983 <<GetFinal4Momentum().mag() <<
G4endl
1984 <<
" CMS pFinals , mag, 3.mag : " << qFinals <<
" " << qFinals.mag() <<
" " << qFinals.vect().mag()<<
G4endl;
1985 G4cerr <<
" -CorrectFinalPandE 5 " << factor <<
G4endl;
1988#ifdef debug_BIC_CorrectFinalPandE
1989 else {
G4cerr <<
" -CorrectFinalPandE 6 - no correction done" <<
G4endl; }
1995void G4BinaryCascade::UpdateTracksAndCollisions(
2001 std::vector<G4KineticTrack *>::const_iterator iter2;
2006 if(!oldSecondaries->empty())
2008 for(
auto iter1=oldSecondaries->cbegin(); iter1!=oldSecondaries->cend(); ++iter1)
2010 iter2 = std::find(theSecondaryList.begin(), theSecondaryList.end(), *iter1);
2011 if ( iter2 != theSecondaryList.cend() ) theSecondaryList.erase(iter2);
2013 theCollisionMgr->RemoveTracksCollisions(oldSecondaries);
2021 if(oldTarget->size()!=0)
2025 for(
auto iter1 = oldTarget->cbegin(); iter1 != oldTarget->cend(); ++iter1)
2027 iter2 = std::find(theTargetList.begin(), theTargetList.end(), *iter1);
2028 theTargetList.erase(iter2);
2030 theCollisionMgr->RemoveTracksCollisions(oldTarget);
2036 if(!newSecondaries->empty())
2039 for(
auto iter1 = newSecondaries->cbegin(); iter1 != newSecondaries->cend(); ++iter1)
2041 theSecondaryList.push_back(*iter1);
2044 PrintKTVector(*iter1,
"undefined in FindCollisions");
2050 FindCollisions(newSecondaries);
2065 ktv(out), wanted_state(astate)
2069 if ( (kt)->GetState() == wanted_state ) ktv->push_back(kt);
2080#ifdef debug_BIC_DoTimeStep
2081 G4ping debug(
"debug_G4BinaryCascade");
2082 debug.push_back(
"======> DoTimeStep 1"); debug.dump();
2083 G4cerr <<
"G4BinaryCascade::DoTimeStep: enter step="<< theTimeStep
2084 <<
" , time="<<theCurrentTime <<
G4endl;
2085 PrintKTVector(&theSecondaryList, std::string(
"DoTimeStep - theSecondaryList"));
2090 std::vector<G4KineticTrack *>::const_iterator iter;
2092 G4KineticTrackVector * kt_outside =
new G4KineticTrackVector;
2093 std::for_each( theSecondaryList.begin(),theSecondaryList.end(),
2097 G4KineticTrackVector * kt_inside =
new G4KineticTrackVector;
2098 std::for_each( theSecondaryList.begin(),theSecondaryList.end(),
2102 G4KineticTrackVector dummy;
2103#ifdef debug_BIC_DoTimeStep
2109 thePropagator->Transport(theSecondaryList, dummy, theTimeStep);
2115 theMomentumTransfer += thePropagator->GetMomentumTransfer();
2116#ifdef debug_BIC_DoTimeStep
2117 G4cout <<
"DoTimeStep : theMomentumTransfer = " << theMomentumTransfer <<
G4endl;
2118 PrintKTVector(&theSecondaryList, std::string(
"DoTimeStep - secondaries aft trsprt"));
2125 G4KineticTrackVector * kt_gone_in =
new G4KineticTrackVector;
2126 std::for_each( kt_outside->begin(),kt_outside->end(),
2132 G4KineticTrackVector * kt_gone_out =
new G4KineticTrackVector;
2133 std::for_each( kt_inside->begin(),kt_inside->end(),
2138 G4KineticTrackVector *fail=CorrectBarionsOnBoundary(kt_gone_in,kt_gone_out);
2143 kt_gone_in->clear();
2144 std::for_each( kt_outside->begin(),kt_outside->end(),
2147 kt_gone_out->clear();
2148 std::for_each( kt_inside->begin(),kt_inside->end(),
2151#ifdef debug_BIC_DoTimeStep
2152 PrintKTVector(fail,std::string(
" Failed to go in/out -> miss_nucleus/captured"));
2153 PrintKTVector(kt_gone_in, std::string(
"recreated kt_gone_in"));
2154 PrintKTVector(kt_gone_out, std::string(
"recreated kt_gone_out"));
2160 std::for_each( kt_outside->begin(),kt_outside->end(),
2163 std::for_each( kt_outside->begin(),kt_outside->end(),
2166#ifdef debug_BIC_DoTimeStep
2167 PrintKTVector(kt_gone_out, std::string(
"append gone_outs to final state.. theFinalState"));
2170 theFinalState.insert(theFinalState.end(),
2171 kt_gone_out->begin(),kt_gone_out->end());
2174 G4KineticTrackVector * kt_captured =
new G4KineticTrackVector;
2175 std::for_each( theSecondaryList.begin(),theSecondaryList.end(),
2181 if ( theCollisionMgr->Entries()> 0 )
2183 if (kt_gone_out->size() )
2185 G4KineticTrack * nextPrimary = theCollisionMgr->GetNextCollision()->GetPrimary();
2186 iter = std::find(kt_gone_out->begin(),kt_gone_out->end(),nextPrimary);
2187 if ( iter != kt_gone_out->cend() )
2190#ifdef debug_BIC_DoTimeStep
2191 G4cout <<
" DoTimeStep - WARNING: deleting current collision!" <<
G4endl;
2195 if ( kt_captured->size() )
2197 G4KineticTrack * nextPrimary = theCollisionMgr->GetNextCollision()->GetPrimary();
2198 iter = std::find(kt_captured->begin(),kt_captured->end(),nextPrimary);
2199 if ( iter != kt_captured->cend() )
2202#ifdef debug_BIC_DoTimeStep
2203 G4cout <<
" DoTimeStep - WARNING: deleting current collision!" <<
G4endl;
2210 UpdateTracksAndCollisions(kt_gone_out,0 ,0);
2213 if ( kt_captured->size() )
2215 theCapturedList.insert(theCapturedList.end(),
2216 kt_captured->begin(),kt_captured->end());
2220 for(
auto i_captured=kt_captured->cbegin();i_captured!=kt_captured->cend(); ++i_captured)
2222 (*i_captured)->Hit();
2225 UpdateTracksAndCollisions(kt_captured,
nullptr,
nullptr);
2228#ifdef debug_G4BinaryCascade
2230 kt_inside =
new G4KineticTrackVector;
2231 std::for_each( theSecondaryList.begin(),theSecondaryList.end(),
2233 if ( currentZ != (GetTotalCharge(theTargetList)
2234 + GetTotalCharge(theCapturedList)
2235 + GetTotalCharge(*kt_inside)) )
2237 G4cout <<
" error-DoTimeStep aft, A, Z: " << currentA <<
" " << currentZ
2238 <<
" sum(tgt,capt,active) "
2239 << GetTotalCharge(theTargetList) + GetTotalCharge(theCapturedList) + GetTotalCharge(*kt_inside)
2240 <<
" targets: " << GetTotalCharge(theTargetList)
2241 <<
" captured: " << GetTotalCharge(theCapturedList)
2242 <<
" active: " << GetTotalCharge(*kt_inside)
2254 theCurrentTime += theTimeStep;
2267 G4KineticTrackVector * kt_fail(
nullptr);
2268 std::vector<G4KineticTrack *>::const_iterator iter;
2273 G4int secondaries_in(0);
2274 G4int secondaryBarions_in(0);
2275 G4int secondaryCharge_in(0);
2278 for ( iter =in->cbegin(); iter != in->cend(); ++iter)
2281 secondaryCharge_in +=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
2282 if ((*iter)->GetDefinition()->GetBaryonNumber()!=0 )
2284 secondaryBarions_in += (*iter)->GetDefinition()->GetBaryonNumber();
2288 secondaryMass_in += (*iter)->GetDefinition()->GetPDGMass();
2294 G4double mass_initial= GetIonMass(currentZ,currentA);
2296 currentZ += secondaryCharge_in;
2297 currentA += secondaryBarions_in;
2302 G4double mass_final= GetIonMass(currentZ,currentA);
2304 G4double correction= secondaryMass_in + mass_initial - mass_final;
2305 if (secondaries_in>1)
2306 {correction /= secondaries_in;}
2308#ifdef debug_BIC_CorrectBarionsOnBoundary
2309 G4cout <<
"CorrectBarionsOnBoundary,currentZ,currentA,"
2310 <<
"secondaryCharge_in,secondaryBarions_in,"
2311 <<
"energy correction,m_secondry,m_nucl_init,m_nucl_final "
2312 << currentZ <<
" "<< currentA <<
" "
2313 << secondaryCharge_in<<
" "<<secondaryBarions_in<<
" "
2314 << correction <<
" "
2315 << secondaryMass_in <<
" "
2316 << mass_initial <<
" "
2317 << mass_final <<
" "
2319 PrintKTVector(in,std::string(
"in be4 correction"));
2321 for ( iter = in->cbegin(); iter != in->cend(); ++iter)
2323 if ((*iter)->GetTrackingMomentum().e()+correction > (*iter)->GetActualMass())
2325 (*iter)->UpdateTrackingMomentum((*iter)->GetTrackingMomentum().e() + correction);
2328 G4RKPropagation * RKprop=(G4RKPropagation *)thePropagator;
2332 (*iter)->UpdateTrackingMomentum((*iter)->GetTrackingMomentum().e() + barrier);
2333 if ( ! kt_fail ) kt_fail=
new G4KineticTrackVector;
2334 kt_fail->push_back(*iter);
2335 currentZ -=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
2336 currentA -= (*iter)->GetDefinition()->GetBaryonNumber();
2341#ifdef debug_BIC_CorrectBarionsOnBoundary
2342 G4cout <<
" CorrectBarionsOnBoundary, aft, Z, A, sec-Z,A,m,m_in_nucleus "
2343 << currentZ <<
" " << currentA <<
" "
2344 << secondaryCharge_in <<
" " << secondaryBarions_in <<
" "
2345 << secondaryMass_in <<
" "
2347 PrintKTVector(in,std::string(
"in AFT correction"));
2354 G4int secondaries_out(0);
2355 G4int secondaryBarions_out(0);
2356 G4int secondaryCharge_out(0);
2359 for ( iter = out->cbegin(); iter != out->cend(); ++iter)
2362 secondaryCharge_out +=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
2363 if ((*iter)->GetDefinition()->GetBaryonNumber() !=0 )
2365 secondaryBarions_out += (*iter)->GetDefinition()->GetBaryonNumber();
2369 secondaryMass_out += (*iter)->GetDefinition()->GetPDGMass();
2376 G4double mass_initial= GetIonMass(currentZ,currentA);
2377 currentA -=secondaryBarions_out;
2378 currentZ -=secondaryCharge_out;
2387 G4cerr <<
"G4BinaryCascade - secondaryBarions_out,secondaryCharge_out " <<
2388 secondaryBarions_out <<
" " << secondaryCharge_out <<
G4endl;
2389 PrintKTVector(&theTargetList,
"CorrectBarionsOnBoundary Target");
2390 PrintKTVector(&theCapturedList,
"CorrectBarionsOnBoundary Captured");
2391 PrintKTVector(&theSecondaryList,
"CorrectBarionsOnBoundary Secondaries");
2392 G4cerr <<
"G4BinaryCascade - currentA, currentZ " << currentA <<
" " << currentZ <<
G4endl;
2393 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::CorrectBarionsOnBoundary() - fatal error");
2395 G4double mass_final=GetIonMass(currentZ,currentA);
2396 G4double correction= mass_initial - mass_final - secondaryMass_out;
2399 if (secondaries_out>1) correction /= secondaries_out;
2400#ifdef debug_BIC_CorrectBarionsOnBoundary
2401 G4cout <<
"DoTimeStep,(current Z,A),"
2402 <<
"(secondaries out,Charge,Barions),"
2403 <<
"* energy correction,(m_secondry,m_nucl_init,m_nucl_final) "
2404 <<
"("<< currentZ <<
","<< currentA <<
") ("
2405 << secondaries_out <<
","
2406 << secondaryCharge_out<<
","<<secondaryBarions_out<<
") * "
2407 << correction <<
" ("
2408 << secondaryMass_out <<
", "
2409 << mass_initial <<
", "
2410 << mass_final <<
")"
2412 PrintKTVector(out,std::string(
"out be4 correction"));
2415 for ( iter = out->cbegin(); iter != out->cend(); ++iter)
2417 if ((*iter)->GetTrackingMomentum().e()+correction > (*iter)->GetActualMass())
2419 (*iter)->UpdateTrackingMomentum((*iter)->GetTrackingMomentum().e() + correction);
2429 G4double barrier=((G4RKPropagation *)thePropagator)->GetBarrier((*iter)->GetDefinition()->GetPDGEncoding());
2430 (*iter)->UpdateTrackingMomentum((*iter)->GetTrackingMomentum().e() - barrier);
2431 if ( kt_fail == 0 ) kt_fail=
new G4KineticTrackVector;
2432 kt_fail->push_back(*iter);
2433 currentZ +=
G4lrint((*iter)->GetDefinition()->GetPDGCharge()/eplus);
2434 currentA += (*iter)->GetDefinition()->GetBaryonNumber();
2436#ifdef debug_BIC_CorrectBarionsOnBoundary
2439 G4cout <<
"Not correcting outgoing " << *iter <<
" "
2440 << (*iter)->GetDefinition()->GetPDGEncoding() <<
" "
2441 << (*iter)->GetDefinition()->GetParticleName() <<
G4endl;
2442 PrintKTVector(out,std::string(
"outgoing, one not corrected"));
2448#ifdef debug_BIC_CorrectBarionsOnBoundary
2449 PrintKTVector(out,std::string(
"out AFTER correction"));
2450 G4cout <<
" DoTimeStep, nucl-update, A, Z, sec-Z,A,m,m_in_nucleus, table-mass, delta "
2451 << currentA <<
" "<< currentZ <<
" "
2452 << secondaryCharge_out <<
" "<< secondaryBarions_out <<
" "<<
2453 secondaryMass_out <<
" "
2454 << massInNucleus <<
" "
2455 << GetIonMass(currentZ,currentA)
2456 <<
" " << massInNucleus - GetIonMass(currentZ,currentA)
2471#ifdef debug_BIC_FindFragments
2472 G4cout <<
"target, captured, secondary: "
2473 << theTargetList.size() <<
" "
2474 << theCapturedList.size()<<
" "
2475 << theSecondaryList.size()
2479 G4int a =
G4int(theTargetList.size()+theCapturedList.size());
2481 for(
auto i = theTargetList.cbegin(); i != theTargetList.cend(); ++i)
2483 if(
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus) == 1 )
2489 G4int zCaptured = 0;
2491 for(
auto i = theCapturedList.cbegin(); i != theCapturedList.cend(); ++i)
2493 CapturedMomentum += (*i)->Get4Momentum();
2494 if(
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus) == 1 )
2500 G4int z = zTarget+zCaptured;
2502#ifdef debug_G4BinaryCascade
2503 if ( z != (GetTotalCharge(theTargetList) + GetTotalCharge(theCapturedList)) )
2505 G4cout <<
" FindFragment Counting error z a " << z <<
" " <<a <<
" "
2506 << GetTotalCharge(theTargetList) <<
" " << GetTotalCharge(theCapturedList)<<
2508 PrintKTVector(&theTargetList, std::string(
"theTargetList"));
2509 PrintKTVector(&theCapturedList, std::string(
"theCapturedList"));
2523 if ( z < 1 )
return 0;
2526 G4int excitons = (
G4int)theCapturedList.size();
2527#ifdef debug_BIC_FindFragments
2528 G4cout <<
"Fragment: a= " << a <<
" z= " << z <<
" particles= " << excitons
2529 <<
" Charged= " << zCaptured <<
" holes= " << holes
2530 <<
" excitE= " <<GetExcitationEnergy()
2531 <<
" Final4Momentum= " << GetFinalNucleusMomentum() <<
" capturMomentum= " << CapturedMomentum
2535 G4Fragment * fragment =
new G4Fragment(a,z,GetFinalNucleusMomentum());
2553 G4LorentzVector final4Momentum = theInitial4Mom + theProjectile4Momentum;
2555 for(
auto i = theFinalState.cbegin(); i != theFinalState.cend(); ++i)
2557 final4Momentum -= (*i)->Get4Momentum();
2558 finals += (*i)->Get4Momentum();
2561 if(final4Momentum.
e()> 0 && (final4Momentum.
vect()/final4Momentum.
e()).mag()>1.0 && currentA > 0)
2563#ifdef debug_BIC_Final4Momentum
2565 G4cerr <<
"G4BinaryCascade::GetFinal4Momentum - Fatal"<<
G4endl;
2566 G4KineticTrackVector::iterator i;
2567 G4cerr <<
"Total initial 4-momentum " << theProjectile4Momentum <<
G4endl;
2568 G4cerr <<
" GetFinal4Momentum: Initial nucleus "<<theInitial4Mom<<
G4endl;
2569 for(i = theFinalState.begin(); i != theFinalState.end(); ++i)
2571 G4cerr <<
" Final state: "<<(*i)->Get4Momentum()<<(*i)->GetDefinition()->GetParticleName()<<
G4endl;
2574 G4cerr<<
" Final4Momentum = "<<final4Momentum <<
" "<<final4Momentum.
m()<<
G4endl;
2575 G4cerr <<
" current A, Z = "<< currentA<<
", "<<currentZ<<
G4endl;
2581 return final4Momentum;
2593 for(
auto i = theCapturedList.cbegin(); i != theCapturedList.cend(); ++i)
2595 CapturedMomentum += (*i)->Get4Momentum();
2601 if ( NucleusMomentum.
e() > 0 )
2605 G4ThreeVector boost= (NucleusMomentum.
vect() -CapturedMomentum.vect())/NucleusMomentum.
e();
2606 if(boost.
mag2()>1.0)
2608# ifdef debug_BIC_FinalNucleusMomentum
2609 G4cerr <<
"G4BinaryCascade::GetFinalNucleusMomentum - Fatal"<<
G4endl;
2611 G4cerr <<
"it 01"<<NucleusMomentum<<
" "<<CapturedMomentum<<
" "<<
G4endl;
2618 precompoundLorentzboost.set( boost );
2619#ifdef debug_debug_BIC_FinalNucleusMomentum
2620 G4cout <<
"GetFinalNucleusMomentum be4 boostNucleusMomentum, CapturedMomentum"<<NucleusMomentum<<
" "<<CapturedMomentum<<
" "<<
G4endl;
2622 NucleusMomentum *= nucleusBoost;
2623#ifdef debug_BIC_FinalNucleusMomentum
2624 G4cout <<
"GetFinalNucleusMomentum aft boost GetFinal4Momentum= " <<NucleusMomentum <<
G4endl;
2627 return NucleusMomentum;
2639 G4KineticTrackVector * secs =
nullptr;
2642 G4KineticTrack aTarget(aHTarg, 0., pos, mom);
2648 while(!done && tryCount++ <200)
2652 std::for_each(secs->begin(), secs->end(), DeleteKineticTrack());
2655 secs = theH1Scatterer->Scatter(*(*secondaries).front(), aTarget);
2656#ifdef debug_H1_BinaryCascade
2657 PrintKTVector(secs,
" From Scatter");
2659 for(std::size_t ss=0; secs && ss<secs->size(); ++ss)
2662 if((*secs)[ss]->GetDefinition()->IsShortLived()) done =
true;
2666 ClearAndDestroy(&theFinalState);
2667 ClearAndDestroy(secondaries);
2670 for(std::size_t current=0; secs && current<secs->size(); ++current)
2672 if((*secs)[current]->GetDefinition()->IsShortLived())
2675 G4KineticTrackVector * dec = (*secs)[current]->Decay();
2676 for(
auto jter=dec->cbegin(); jter != dec->cend(); ++jter)
2679 secs->push_back(*jter);
2682 delete (*secs)[current];
2689 theFinalState.push_back((*secs)[current]);
2694#ifdef debug_H1_BinaryCascade
2695 PrintKTVector(&theFinalState,
" FinalState");
2697 for(
auto iter = theFinalState.cbegin(); iter != theFinalState.cend(); ++iter)
2699 G4KineticTrack * kt = *iter;
2700 G4ReactionProduct * aNew =
new G4ReactionProduct(kt->
GetDefinition());
2706 products->push_back(aNew);
2707#ifdef debug_H1_BinaryCascade
2712 G4cout <<
"final shortlived : ";
2715 G4cout <<
"final un stable : ";
2722 theFinalState.clear();
2747 }
while (
sqr(x1) +
sqr(x2) > 1.);
2773 for(
auto i = ktv->cbegin(); i != ktv->cend(); ++i)
2782 for(
auto i = rpv->cbegin(); i != rpv->cend(); ++i)
2791 if (comment.size() > 0 )
G4cout <<
"G4BinaryCascade::PrintKTVector() " << comment <<
G4endl;
2793 G4cout <<
" vector: " << ktv <<
", number of tracks: " << ktv->size()
2795 std::vector<G4KineticTrack *>::const_iterator i;
2798 for(count = 0, i = ktv->cbegin(); i != ktv->cend(); ++i, ++count)
2800 G4KineticTrack * kt = *i;
2801 G4cout <<
" track n. " << count;
2805 G4cout <<
"G4BinaryCascade::PrintKTVector():No KineticTrackVector given " <<
G4endl;
2809void G4BinaryCascade::PrintKTVector(
G4KineticTrack * kt, std::string comment)
2812 if (comment.size() > 0 )
G4cout <<
"G4BinaryCascade::PrintKTVector() "<< comment <<
G4endl;
2818 const G4ParticleDefinition * definition = kt->
GetDefinition();
2820 << 1/fermi*
pos <<
" R: " << 1/fermi*
pos.mag() <<
" 4mom: "
2821 << 1/MeV*mom <<
"Tr_mom" << 1/MeV*tmom <<
" P: " << 1/MeV*mom.
vect().
mag()
2825 G4cout <<
"G4BinaryCascade::PrintKTVector(): No Kinetictrack given" <<
G4endl;
2835 if ( Z > 0 &&
A >= Z )
2839 }
else if (
A > 0 && Z>0 )
2844 }
else if (
A >= 0 && Z<=0 )
2849 }
else if (
A == 0 )
2856 G4cerr <<
"G4BinaryCascade::GetIonMass() - invalid (A,Z) = ("
2857 <<
A <<
"," << Z <<
")" <<
G4endl;
2858 throw G4HadronicException(__FILE__, __LINE__,
"G4BinaryCascade::GetIonMass() - giving up");
2869 std::vector<G4KineticTrack *>::const_iterator iter;
2870 std::vector<G4ReactionProduct *>::const_iterator rpiter;
2871 decayKTV.Decay(&theFinalState);
2873 for(iter = theFinalState.cbegin(); iter != theFinalState.cend(); ++iter)
2875 G4ReactionProduct * aNew =
new G4ReactionProduct((*iter)->GetDefinition());
2876 aNew->
SetMomentum((*iter)->Get4Momentum().vect());
2881 Esecondaries +=(*iter)->Get4Momentum().e();
2882 psecondaries +=(*iter)->Get4Momentum();
2885 products->push_back(aNew);
2890 while(theCollisionMgr->Entries() > 0)
2892 G4CollisionInitialState *
2893 collision = theCollisionMgr->GetNextCollision();
2897 if ( lates->size() == 1 ) {
2898 G4KineticTrack * atrack=*(lates->begin());
2901 G4ReactionProduct * aNew =
new G4ReactionProduct(atrack->
GetDefinition());
2910 products->push_back(aNew);
2914 theCollisionMgr->RemoveCollision(collision);
2920 decayKTV.Decay(&theSecondaryList);
2924 if ( (theSecondaryList.size() + theCapturedList.size()) > 0)
2926 transferCorrection= theMomentumTransfer /(theSecondaryList.size() + theCapturedList.size());
2929 for(iter = theSecondaryList.cbegin(); iter != theSecondaryList.cend(); ++iter)
2931 G4ReactionProduct * aNew =
new G4ReactionProduct((*iter)->GetDefinition());
2932 (*iter)->Update4Momentum((*iter)->Get4Momentum().vect()+transferCorrection);
2933 aNew->
SetMomentum((*iter)->Get4Momentum().vect());
2938 Esecondaries +=(*iter)->Get4Momentum().e();
2939 psecondaries +=(*iter)->Get4Momentum();
2941 products->push_back(aNew);
2944 for(iter = theCapturedList.cbegin(); iter != theCapturedList.cend(); ++iter)
2946 G4ReactionProduct * aNew =
new G4ReactionProduct((*iter)->GetDefinition());
2947 (*iter)->Update4Momentum((*iter)->Get4Momentum().vect()+transferCorrection);
2948 aNew->
SetMomentum((*iter)->Get4Momentum().vect());
2953 Esecondaries +=(*iter)->Get4Momentum().e();
2954 psecondaries +=(*iter)->Get4Momentum();
2956 products->push_back(aNew);
2961 for(iter = theTargetList.cbegin(); iter != theTargetList.cend(); ++iter)
2963 SumMassNucleons += (*iter)->GetDefinition()->GetPDGMass();
2964 pNucleons += (*iter)->Get4Momentum();
2967 G4double Ekinetic=theProjectile4Momentum.e() + initial_nuclear_mass - Esecondaries - SumMassNucleons;
2968 #ifdef debug_BIC_FillVoidnucleus
2970 psecondaries - pNucleons;
2974 if (Ekinetic > 0. && theTargetList.size()){
2975 Ekinetic /= theTargetList.size();
2978 if (theTargetList.size()) Ekineticrdm = ( 0.1 +
G4UniformRand()*5.) * MeV;
2980 for (rpiter=products->cbegin(); rpiter!=products->cend(); ++rpiter){
2981 TotalEkin+=(*rpiter)->GetKineticEnergy();
2984 if ( std::abs(Ekinetic) < 20*perCent * TotalEkin ){
2985 correction=1. + (Ekinetic-Ekineticrdm)/TotalEkin;
2987 #ifdef debug_G4BinaryCascade
2989 G4cout <<
"BLIC::FillVoidNucleus() fail correction, Ekinetic, TotalEkin " << Ekinetic <<
""<< TotalEkin <<
G4endl;
2993 for (rpiter=products->cbegin(); rpiter!=products->cend(); ++rpiter){
2994 (*rpiter)->SetKineticEnergy((*rpiter)->GetKineticEnergy()*correction);
2995 (*rpiter)->SetMomentum((*rpiter)->GetTotalMomentum() * (*rpiter)->GetMomentum().unit());
2999 Ekinetic=Ekineticrdm*correction;
3000 if (theTargetList.size())Ekinetic /= theTargetList.size();
3004 for(iter = theTargetList.cbegin(); iter != theTargetList.cend(); ++iter) {
3007 G4ReactionProduct * aNew =
new G4ReactionProduct((*iter)->GetDefinition());
3014 products->push_back(aNew);
3019 for (rpiter=products->cbegin(); rpiter!=products->cend(); ++rpiter){
3020 psecondaries +=
G4LorentzVector((*rpiter)->GetMomentum(),(*rpiter)->GetTotalEnergy() );
3030 SumMom=initial4Mom.
vect()-SumMom;
3034 while ( SumMom.
mag() > 0.1*MeV && loopcount++ < 10)
3037 for (
auto reverse=products->crbegin(); reverse!=products->crend(); ++reverse, --index){
3038 SumMom=initial4Mom.
vect();
3039 for (rpiter=products->cbegin(); rpiter!=products->cend(); ++rpiter){
3040 SumMom-=(*rpiter)->GetMomentum();
3043 (*reverse)->SetMomentum( p*(((*reverse)->GetMomentum()+SumMom).unit()));
3052 for(
auto iter = secondaries->cbegin(); iter != secondaries->cend(); ++iter)
3054 G4ReactionProduct * aNew =
new G4ReactionProduct((*iter)->GetDefinition());
3055 aNew->
SetMomentum((*iter)->Get4Momentum().vect());
3062 products->push_back(aNew);
3064 const G4ParticleDefinition* fragment = 0;
3065 if (currentA == 1 && currentZ == 0) {
3067 }
else if (currentA == 1 && currentZ == 1) {
3069 }
else if (currentA == 2 && currentZ == 1) {
3071 }
else if (currentA == 3 && currentZ == 1) {
3073 }
else if (currentA == 3 && currentZ == 2) {
3075 }
else if (currentA == 4 && currentZ == 2) {
3081 if (fragment != 0) {
3082 G4ReactionProduct * theNew =
new G4ReactionProduct(fragment);
3088 products->push_back(theNew);
3093void G4BinaryCascade::PrintWelcomeMessage()
3095 G4cout <<
"Thank you for using G4BinaryCascade. "<<
G4endl;
3105 for (
auto i =products->cbegin(); i != products->cend(); ++i)
3107 G4int PDGcode=std::abs((*i)->GetDefinition()->GetPDGEncoding());
3108 if (std::abs(PDGcode)==211 || PDGcode==111 ) havePion=
true;
3111 if ( !products || havePion)
3114 G4cout <<
" Collision " << collision <<
", type: "<<
typeid(action).
name()
3115 <<
", with NO products! " <<
G4endl;
3132G4bool G4BinaryCascade::CheckChargeAndBaryonNumber(
const G4String& where)
3134 static G4int lastdA(0), lastdZ(0);
3141 G4int CapturedA(0), CapturedZ(0);
3142 G4int secsA(0), secsZ(0);
3143 for (
auto i=theCapturedList.cbegin(); i!=theCapturedList.cend(); ++i) {
3144 CapturedA += (*i)->GetDefinition()->GetBaryonNumber();
3145 CapturedZ +=
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus);
3148 for (
auto i=theSecondaryList.cbegin(); i!=theSecondaryList.cend(); ++i) {
3150 secsA += (*i)->GetDefinition()->GetBaryonNumber();
3151 secsZ +=
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus);
3155 for (
auto i=theFinalState.cbegin(); i!=theFinalState.cend(); ++i) {
3156 fStateA += (*i)->GetDefinition()->GetBaryonNumber();
3157 fStateZ +=
G4lrint((*i)->GetDefinition()->GetPDGCharge()/eplus);
3160 G4int deltaA= iStateA - secsA - fStateA -currentA - lateA;
3161 G4int deltaZ= iStateZ - secsZ - fStateZ -currentZ - lateZ;
3163#ifdef debugCheckChargeAndBaryonNumberverbose
3164 G4cout << where <<
" A: iState= "<< iStateA<<
", secs= "<< secsA<<
", fState= "<< fStateA<<
", current= "<<currentA<<
", late= " <<lateA <<
G4endl;
3165 G4cout << where <<
" Z: iState= "<< iStateZ<<
", secs= "<< secsZ<<
", fState= "<< fStateZ<<
", current= "<<currentZ<<
", late= " <<lateZ <<
G4endl;
3168 if (deltaA != 0 || deltaZ!=0 ) {
3169 if (deltaA != lastdA || deltaZ != lastdZ ) {
3170 G4cout <<
"baryon/charge imbalance - " << where <<
G4endl
3171 <<
"deltaA " <<deltaA<<
", iStateA "<<iStateA<<
", CapturedA "<<CapturedA <<
", secsA "<<secsA
3172 <<
", fStateA "<<fStateA <<
", currentA "<<currentA <<
", lateA "<<lateA <<
G4endl
3173 <<
"deltaZ "<<deltaZ<<
", iStateZ "<<iStateZ<<
", CapturedZ "<<CapturedZ <<
", secsZ "<<secsZ
3174 <<
", fStateZ "<<fStateZ <<
", currentZ "<<currentZ <<
", lateZ "<<lateZ <<
G4endl<<
G4endl;
3178 }
else { lastdA=lastdZ=0;}
3187 PrintKTVector(collision->
GetPrimary(),std::string(
" Primary particle"));
3189 PrintKTVector(products,std::string(
" Scatterer products"));
3199 G4RKPropagation * RKprop=(G4RKPropagation *)thePropagator;
3209 for (
unsigned int it=0; it < ktv.size(); ++it)
3227 G4int product_barions(0);
3230 for (
unsigned int it=0; it < products->size(); ++it)
3242 <<
" " << fin <<
G4endl;;
3247 G4int finalA = currentA;
3248 G4int finalZ = currentZ;
3251 finalA -= product_barions;
3252 finalZ -= GetTotalCharge(*products);
3254 G4double delta = GetIonMass(currentZ,currentA) - (GetIonMass(finalZ,finalA) + mass_out);
3255 G4cout <<
" current/final a,z " << currentA <<
" " << currentZ <<
" "<< finalA<<
" "<< finalZ
3256 <<
" delta-mass " << delta<<
G4endl;
3258 mass_out = GetIonMass(finalZ,finalA);
3259 G4cout <<
" initE/ E_out/ Mfinal/ Excit " << currentInitialEnergy
3260 <<
" " << fin <<
" "
3262 << currentInitialEnergy - fin - mass_out
3264 currentInitialEnergy-=fin;
3280 for(
auto iter = products->cbegin(); iter != products->cend(); ++iter)
3283 G4cout <<
" Secondary E - Ekin / p " <<
3284 (*iter)->GetDefinition()->GetParticleName() <<
" " <<
3285 (*iter)->GetTotalEnergy() <<
" - " <<
3286 (*iter)->GetKineticEnergy()<<
" / " <<
3287 (*iter)->GetMomentum().x() <<
" " <<
3288 (*iter)->GetMomentum().y() <<
" " <<
3289 (*iter)->GetMomentum().z() <<
G4endl;
3290 Efinal += (*iter)->GetTotalEnergy();
3291 pFinal += (*iter)->GetMomentum();
3294 G4cout <<
"e outgoing/ total : " << Efinal <<
" " << Efinal+GetFinal4Momentum().e()<<
G4endl;
3295 G4cout <<
"BIC E/p delta " <<
3296 (aTrack.
Get4Momentum().e()+theInitial4Mom.
e() - Efinal)/MeV <<
3303G4bool G4BinaryCascade::DebugEpConservation(
const G4String& where)
3313 std::vector<G4KineticTrack *>::const_iterator ktiter;
3314 for(ktiter = theSecondaryList.cbegin(); ktiter != theSecondaryList.cend(); ++ktiter)
3317 G4cout <<
" Secondary E - Ekin / p " <<
3318 (*ktiter)->GetDefinition()->GetParticleName() <<
" " <<
3319 (*ktiter)->Get4Momentum().e() <<
" - " <<
3320 (*ktiter)->Get4Momentum().e() - (*ktiter)->Get4Momentum().mag() <<
" / " <<
3321 (*ktiter)->Get4Momentum().vect() <<
G4endl;
3322 psecs += (*ktiter)->Get4Momentum();
3325 for(ktiter = theTargetList.cbegin(); ktiter != theTargetList.cend(); ++ktiter)
3328 G4cout <<
" Target E - Ekin / p " <<
3329 (*ktiter)->GetDefinition()->GetParticleName() <<
" " <<
3330 (*ktiter)->Get4Momentum().e() <<
" - " <<
3331 (*ktiter)->Get4Momentum().e() - (*ktiter)->Get4Momentum().mag() <<
" / " <<
3332 (*ktiter)->Get4Momentum().vect() <<
G4endl;
3333 ptgts += (*ktiter)->Get4Momentum();
3336 for(ktiter = theCapturedList.cbegin(); ktiter != theCapturedList.cend(); ++ktiter)
3339 G4cout <<
" Captured E - Ekin / p " <<
3340 (*ktiter)->GetDefinition()->GetParticleName() <<
" " <<
3341 (*ktiter)->Get4Momentum().e() <<
" - " <<
3342 (*ktiter)->Get4Momentum().e() - (*ktiter)->Get4Momentum().mag() <<
" / " <<
3343 (*ktiter)->Get4Momentum().vect() <<
G4endl;
3344 pcpts += (*ktiter)->Get4Momentum();
3347 for(ktiter = theFinalState.cbegin(); ktiter != theFinalState.cend(); ++ktiter)
3350 G4cout <<
" Finals E - Ekin / p " <<
3351 (*ktiter)->GetDefinition()->GetParticleName() <<
" " <<
3352 (*ktiter)->Get4Momentum().e() <<
" - " <<
3353 (*ktiter)->Get4Momentum().e() - (*ktiter)->Get4Momentum().mag() <<
" / " <<
3354 (*ktiter)->Get4Momentum().vect() <<
G4endl;
3355 pfins += (*ktiter)->Get4Momentum();
3358 G4cout <<
" Secondaries " << psecs <<
", Targets " << ptgts <<
G4endl
3359 <<
" Captured " << pcpts <<
", Finals " << pfins <<
G4endl
3360 <<
" Sum " << psecs + ptgts + pcpts + pfins <<
" PTransfer " << theMomentumTransfer
3361 <<
" Sum+PTransfer " << psecs + ptgts + pcpts + pfins + theMomentumTransfer
#define _CheckChargeAndBaryonNumber_(val)
#define _DebugEpConservation(val)
const G4DNABoundingBox initial
CLHEP::HepLorentzRotation G4LorentzRotation
CLHEP::HepLorentzVector G4LorentzVector
std::vector< G4ReactionProduct * > G4ReactionProductVector
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
Hep3Vector orthogonal() const
Hep3Vector cross(const Hep3Vector &) const
HepLorentzRotation inverse() const
Hep3Vector boostVector() const
static G4Alpha * AlphaDefinition()
virtual void PropagateModelDescription(std::ostream &) const
G4HadFinalState * ApplyYourself(const G4HadProjectile &aTrack, G4Nucleus &theNucleus)
virtual G4ReactionProductVector * Propagate(G4KineticTrackVector *, G4V3DNucleus *)
G4BinaryCascade(G4VPreCompoundModel *ptr=0)
virtual void ModelDescription(std::ostream &) const
virtual ~G4BinaryCascade()
G4KineticTrackVector & GetTargetCollection(void)
G4KineticTrackVector * GetFinalState()
const G4BCAction * GetGenerator()
G4int GetTargetBaryonNumber()
G4double GetCollisionTime(void)
G4KineticTrack * GetPrimary(void)
static G4Deuteron * DeuteronDefinition()
G4double GetFermiMomentum(G4double density)
void Init(G4int anA, G4int aZ)
void SetNumberOfCharged(G4int value)
const G4LorentzVector & GetMomentum() const
void SetCreatorModelID(G4int value)
void SetNumberOfHoles(G4int valueTot, G4int valueP=0)
void SetNumberOfParticles(G4int value)
const G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const
const G4LorentzVector & Get4Momentum() const
G4double GetGlobalTime() const
void SetParentResonanceDef(const G4ParticleDefinition *parentDef)
void SetTime(G4double aT)
void SetCreatorModelID(G4int id)
void SetParentResonanceID(const G4int parentID)
G4HadronicInteraction * FindModel(const G4String &name)
static G4HadronicInteractionRegistry * Instance()
G4HadFinalState theParticleChange
void SetMinEnergy(G4double anEnergy)
G4HadronicInteraction(const G4String &modelName="HadronicModel")
void SetEnergyMomentumCheckLevels(G4double relativeLevel, G4double absoluteLevel)
void SetMaxEnergy(const G4double anEnergy)
static G4HadronicParameters * Instance()
G4bool GetBinaryDebug() const
static G4He3 * He3Definition()
G4ParticleDefinition * GetIon(G4int Z, G4int A, G4int lvl=0)
G4double GetIonMass(G4int Z, G4int A, G4int nL=0, G4int lvl=0) const
CascadeState SetState(const CascadeState new_state)
G4int GetParentResonanceID() const
G4int GetCreatorModelID() const
CascadeState GetState() const
void SetNucleon(G4Nucleon *aN)
void Set4Momentum(const G4LorentzVector &a4Momentum)
const G4ThreeVector & GetPosition() const
const G4ParticleDefinition * GetDefinition() const
G4bool IsParticipant() const
const G4LorentzVector & GetTrackingMomentum() const
void Update4Momentum(G4double aEnergy)
const G4ParticleDefinition * GetParentResonanceDef() const
const G4LorentzVector & Get4Momentum() const
G4double GetActualMass() const
static G4Neutron * NeutronDefinition()
static G4Neutron * Neutron()
G4bool GetPDGStable() const
G4bool IsShortLived() const
G4double GetPDGMass() const
G4int GetPDGEncoding() const
G4double GetPDGCharge() const
G4int GetBaryonNumber() const
const G4String & GetParticleName() const
G4IonTable * GetIonTable() const
static G4ParticleTable * GetParticleTable()
static G4int GetModelID(const G4int modelIndex)
static G4PionMinus * PionMinusDefinition()
static G4PionPlus * PionPlusDefinition()
static G4Proton * ProtonDefinition()
static G4Proton * Proton()
G4double GetField(G4int encoding, G4ThreeVector pos)
G4double GetBarrier(G4int encoding)
void SetMomentum(const G4double x, const G4double y, const G4double z)
void SetTotalEnergy(const G4double en)
void SetParentResonanceDef(const G4ParticleDefinition *parentDef)
G4double GetTotalMomentum() const
G4double GetKineticEnergy() const
G4double GetTotalEnergy() const
void SetCreatorModelID(const G4int mod)
void SetNewlyAdded(const G4bool f)
G4ThreeVector GetMomentum() const
void SetKineticEnergy(const G4double en)
void SetParentResonanceID(const G4int parentID)
static void ConstructParticle()
static G4Triton * TritonDefinition()
virtual G4int GetCharge()=0
G4VPreCompoundModel * theDeExcitation
G4VIntraNuclearTransportModel(const G4String &mName="CascadeModel", G4VPreCompoundModel *ptr=nullptr)
G4V3DNucleus * the3DNucleus
G4VPreCompoundModel * GetDeExcitation() const
const G4HadProjectile * GetPrimaryProjectile() const
void SetDeExcitation(G4VPreCompoundModel *ptr)
G4double GetDensity(const G4ThreeVector &aPosition) const
G4ExcitationHandler * GetExcitationHandler() const
SelectFromKTV(G4KineticTrackVector *out, G4KineticTrack::CascadeState astate)
void operator()(G4KineticTrack *&kt) const
ParticleList decay(Cluster *const c)
Carries out a cluster decay.
G4double energy(const ThreeVector &p, const G4double m)
const char * name(G4int ptype)
G4bool nucleon(G4int ityp)