75 theParticleChange->
Clear();
87 const G4double energyThresholdForCharmAndBottomHadrons = 100.0*CLHEP::MeV;
88 if ( thePrimary.
GetKineticEnergy() < energyThresholdForCharmAndBottomHadrons &&
93 theParticleChange->SetStatusChange(
isAlive );
96 return theParticleChange;
110 const G4double energyThresholdForHyperNuclei = 100.0*CLHEP::MeV;
113 theParticleChange->SetStatusChange(
isAlive );
116 return theParticleChange;
123 if ( theQuasielastic )
125 if ( theQuasielastic->GetFraction(theNucleus, aPart) >
G4UniformRand() )
132 for(
auto & ptr : *result)
136 ptr->Get4Momentum().e(),
137 ptr->Get4Momentum().vect());
138 theParticleChange->AddSecondary(aNew, ptr->GetCreatorModelID());
145 theParticleChange->SetStatusChange(
isAlive);
149 return theParticleChange;
155 theHighEnergyGenerator->Scatter(theNucleus, aPart);
158 for (
auto & ptr : *theInitialResult ) {
159 ptr->SetCreatorModelID( theStringModelID );
163 #ifdef DEBUG_initial_result
166 for(
auto & ptr : *theInitialResult)
170 E_out += ptr->Get4Momentum().e();
176 const std::vector<G4Nucleon> & thy = theHighEnergyGenerator->GetWoundedNucleus()->GetNucleons();
178 G4int resZ(0),resA(0);
180 for(
auto & nuc : thy)
182 if(nuc.AreYouHit()) {
186 delta_m += CLHEP::proton_mass_c2;
188 delta_m += CLHEP::neutron_mass_c2;
197 G4double E_excit=init_mass + init_E - final_mass - E_out;
198 G4cout <<
" Corrected delta mass " << init_mass - final_mass - delta_m <<
G4endl;
199 G4cout <<
"initial E, mass = " << init_E <<
", " << init_mass <<
G4endl;
200 G4cout <<
" final E, mass = " << E_out <<
", " << final_mass <<
" excitation_E " << E_excit <<
G4endl;
205 G4V3DNucleus* theProjectileNucleus = theHighEnergyGenerator->GetProjectileNucleus();
206 if(theProjectileNucleus ==
nullptr)
209 const std::vector<G4Nucleon>& they = theHighEnergyGenerator->GetWoundedNucleus()->GetNucleons();
210 for(
auto & nuc : they)
212 if(nuc.AreYouHit()) ++hitCount;
214 if(hitCount != theHighEnergyGenerator->GetWoundedNucleus()->GetMassNumber() )
216 theTransport->SetPrimaryProjectile(thePrimary);
218 theTransport->Propagate(theInitialResult,
219 theHighEnergyGenerator->GetWoundedNucleus());
220 if ( !theTransportResult ) {
221 G4cout <<
"G4TheoFSGenerator: null ptr from transport propagate " <<
G4endl;
227 theTransportResult = theDecay.Propagate(theInitialResult,
228 theHighEnergyGenerator->GetWoundedNucleus());
229 if ( theTransportResult ==
nullptr ) {
230 G4cout <<
"G4TheoFSGenerator: null ptr from decay propagate " <<
G4endl;
237 theTransport->SetPrimaryProjectile(thePrimary);
238 theTransportResult = theTransport->PropagateNuclNucl(theInitialResult,
239 theHighEnergyGenerator->GetWoundedNucleus(),
240 theProjectileNucleus);
241 if ( !theTransportResult ) {
242 G4cout <<
"G4TheoFSGenerator: null ptr from transport propagate " <<
G4endl;
252 if(
nullptr == theCosmicCoalescence) {
255 if(
nullptr == theCosmicCoalescence) {
259 theCosmicCoalescence->SetP0Coalescence( thePrimary, theHighEnergyGenerator->GetModelName() );
260 theCosmicCoalescence->GenerateDeuterons( theTransportResult );
264 for(
auto & ptr : *theTransportResult)
268 ptr->GetTotalEnergy(),
271 G4double time = std::max(ptr->GetFormationTime(), 0.0);
272 aNew.
SetTime(timePrimary + time);
276 theParticleChange->AddSecondary(aNew);
281 delete theTransportResult;
284 return theParticleChange;
G4LorentzVector Get4Momentum() const
G4int GetQuarkContent(G4int flavor) const
G4bool IsHypernucleus() const
G4int GetAntiQuarkContent(G4int flavor) const
G4IonTable * GetIonTable() const
static G4ParticleTable * GetParticleTable()