58 , theABLAModel(new
G4Abla(ablaResult))
61 , isInitialised(false)
73 applyYourselfResult.Clear();
86 theABLAModel->initEvapora();
87 theABLAModel->SetParameters();
103 ed <<
"G4AblaModel is used for ";
129 applyYourselfResult.Clear();
131 for (
auto const& prod : *deExciteResult)
134 new G4DynamicParticle(prod->GetDefinition(), prod->GetTotalEnergy(), prod->GetMomentum());
136 G4double time = std::max(prod->GetFormationTime(), 0.0);
137 aNew.
SetTime(timePrimary + time);
140 applyYourselfResult.AddSecondary(aNew);
142 delete deExciteResult;
143 return &applyYourselfResult;
165 theABLAModel->DeexcitationAblaxx(ARem, ZRem, eStarRem, jRem, pxRem, pyRem, pzRem, (
G4int)eventNumber, SRem);
169 for (
G4int j = 0; j < ablaResult->ntrack; ++j)
174 ablaResult->enerj[j],
175 ablaResult->pxlab[j],
176 ablaResult->pylab[j],
177 ablaResult->pzlab[j]);
181 result->push_back(product);
189 if (
A == 1 && Z == 1 &&
S == 0)
191 else if (
A == 1 && Z == 0 &&
S == 0)
193 else if (
A == 1 && Z == 0 &&
S == -1)
195 else if (
A == -1 && Z == 1 &&
S == 0)
197 else if (
A == -1 && Z == -1 &&
S == 0)
199 else if (
A == -1 && Z == 0 &&
S == 0)
201 else if (
A == 0 && Z == 0 &&
S == 0)
203 else if (
A == 2 && Z == 1 &&
S == 0)
205 else if (
A == 3 && Z == 1 &&
S == 0)
207 else if (
A == 3 && Z == 2 &&
S == 0)
209 else if (
A == 3 && Z == 1 &&
S == -1)
211 else if (
A == 4 && Z == 2 &&
S == 0)
213 else if (
A == 4 && Z == 1 &&
S == -1)
215 else if (
A == 4 && Z == 2 &&
S == -1)
217 else if (
A == 4 && Z == 1 &&
S == -2)
219 else if (
A == 4 && Z == 0 &&
S == -2)
221 else if (
A == 5 && Z == 2 &&
S == -1)
223 else if (
A > 0 && Z > 0 &&
A > Z)
230 G4cout <<
"Can't convert particle with A=" <<
A <<
", Z=" << Z <<
", S=" <<
S
231 <<
" to G4ParticleDefinition, trouble ahead" <<
G4endl;
237 G4cout <<
"Can't convert particle with A=" <<
A <<
", Z=" << Z <<
", S=" <<
S
238 <<
" to G4ParticleDefinition, trouble ahead" <<
G4endl;
246 G4ParticleDefinition* def = toG4ParticleDefinition(
A, Z,
S);
255 G4DynamicParticle p(def, momentumDirection, energy);
256 G4ReactionProduct* r =
new G4ReactionProduct(def);
263 outFile <<
"ABLA++ does not provide an implementation of the ApplyYourself "
269 outFile <<
"ABLA++ is a statistical model for nuclear de-excitation. It simulates\n"
270 <<
"the gamma emission and the evaporation of neutrons, light charged\n"
271 <<
"particles and IMFs, as well as fission where applicable. The code\n"
272 <<
"included in Geant4 is a C++ translation of the original Fortran\n"
273 <<
"code ABLA07. Although the model has been recently extended to\n"
274 <<
"hypernuclei by including the evaporation of lambda particles.\n"
275 <<
"More details about the physics are available in the Geant4\n"
276 <<
"Physics Reference Manual and in the reference articles.\n\n"
278 <<
"(1) A. Kelic, M. V. Ricciardi, and K. H. Schmidt, in Proceedings of Joint\n"
279 <<
"ICTP-IAEA Advanced Workshop on Model Codes for Spallation Reactions,\n"
280 <<
"ICTP Trieste, Italy, 4–8 February 2008, edited by D. Filges, S. "
281 "Leray, Y. Yariv, A. Mengoni, A. Stanculescu, and G. Mank (IAEA "
282 "INDC(NDS)-530, Vienna, 2008), pp. 181–221.\n\n"
283 <<
"(2) J.L. Rodriguez-Sanchez, J.-C. David et al., Phys. Rev. C 98, 021602R (2018)\n"
284 <<
"(3) J.L. Rodriguez-Sanchez et al., Phys. Rev. C 105, 014623 (2022)\n"
285 <<
"(4) J.L. Rodriguez-Sanchez et al., Phys. Rev. Lett. 130, 132501 (2023)\n\n";
G4double S(G4double temp)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
CLHEP::HepLorentzVector G4LorentzVector
std::vector< G4ReactionProduct * > G4ReactionProductVector
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cout
virtual void BuildPhysicsTable(const G4ParticleDefinition &) final
virtual void DeExciteModelDescription(std::ostream &outFile) const
virtual G4HadFinalState * ApplyYourself(G4HadProjectile const &, G4Nucleus &) final
virtual void InitialiseModel() final
virtual void ModelDescription(std::ostream &outFile) const
virtual G4ReactionProductVector * DeExcite(G4Fragment &aFragment)
G4AblaInterface(G4ExcitationHandler *ptr=nullptr)
virtual ~G4AblaInterface()
static G4Deuteron * Deuteron()
static G4DoubleHyperDoubleNeutron * Definition()
static G4DoubleHyperH4 * Definition()
G4double GetExcitationEnergy() const
const G4LorentzVector & GetMomentum() const
void SetCreatorModelID(G4int value)
void SetCreationTime(G4double time)
void SetNumberOfHoles(G4int valueTot, G4int valueP=0)
G4int GetNumberOfLambdas() const
G4ThreeVector GetAngularMomentum() const
void SetNumberOfExcitedParticle(G4int valueTot, G4int valueP)
const G4ParticleDefinition * GetDefinition() const
const G4LorentzVector & Get4Momentum() const
G4double GetGlobalTime() const
void SetTime(G4double aT)
void SetCreatorModelID(G4int id)
const G4String & GetModelName() const
static G4HyperAlpha * Definition()
static G4HyperH4 * Definition()
static G4HyperHe5 * Definition()
static G4HyperTriton * Definition()
G4ParticleDefinition * GetIon(G4int Z, G4int A, G4int lvl=0)
static G4IonTable * GetIonTable()
static G4Lambda * Lambda()
static G4Neutron * Neutron()
static G4Neutron * Definition()
static G4double GetNuclearMass(const G4double A, const G4double Z)
const G4String & GetParticleName() const
static G4int GetModelID(const G4int modelIndex)
static G4PionMinus * PionMinus()
static G4PionPlus * PionPlus()
static G4PionZero * PionZero()
static G4Proton * Definition()
static G4Proton * Proton()
void SetCreatorModelID(const G4int mod)
static G4Triton * Triton()
G4ExcitationHandler * GetExcitationHandler() const
G4VPreCompoundModel(G4ExcitationHandler *ptr=nullptr, const G4String &modelName="PrecompoundModel")
void SetExcitationHandler(G4ExcitationHandler *ptr)
G4double energy(const ThreeVector &p, const G4double m)