Version: SMASH-3.2
forwarddeclarations.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright (c) 2014-2024
4  * SMASH Team
5  *
6  * GNU General Public License (GPLv3 or later)
7  *
8  */
9 
10 #ifndef SRC_INCLUDE_SMASH_FORWARDDECLARATIONS_H_
11 #define SRC_INCLUDE_SMASH_FORWARDDECLARATIONS_H_
12 
14 // exclude most content here from documentation
15 
16 #include <bitset>
17 #include <iosfwd>
18 #include <memory>
19 #include <vector>
20 
21 namespace smash {
22 
23 class Action;
24 class ScatterAction;
25 class ScatterActionMulti;
26 class BoxModus;
27 class Clock;
28 class CollisionBranch;
29 class Configuration;
30 class CrossSections;
31 class DecayBranch;
32 class DecayModes;
33 class DecayType;
34 class ExperimentBase;
35 class FourVector;
36 class IsoParticleType;
37 template <typename T>
38 class Key;
39 class ModusDefault;
40 class OutputInterface;
41 class ParticleData;
42 class Particles;
43 class ParticleType;
44 class ParticleTypePtr;
45 class PdgCode;
46 class ScatterActionsFinderParameters;
47 class Tabulation;
48 class ThreeVector;
49 
50 struct ExperimentParameters;
51 struct InitialConditionParameters;
52 struct StringTransitionParameters;
53 struct Nucleoncorr;
54 
56 
58 enum class CalculationFrame {
62 };
63 
65 enum class FermiMotion {
67  Off,
69  On,
71  Frozen,
72 };
73 
75 enum class Sampling {
77  Uniform,
79  Quadratic,
81  Custom,
82 };
83 
85 enum class DerivativesMode {
88  Off,
89 };
90 
96  On,
97  Off,
98 };
99 
105  ChainRule,
106  Direct,
107 };
108 
110 enum class SmearingMode {
112  Discrete,
113  Triangular,
114 };
115 
117 enum class TimeStepMode : char {
119  None,
121  Fixed,
122 };
123 
139 };
140 
151  IC_ES,
154  IC_1M,
157  IC_2M,
160  IC_Massive,
161 };
162 
171 enum class ExpansionMode {
172  NoExpansion,
173  MasslessFRW,
174  MassiveFRW,
175  Exponential,
176 };
177 
179 enum class NNbarTreatment {
183  Resonances,
185  TwoToFive,
187  Strings,
188 };
189 
194 enum class ThermodynamicQuantity : char {
198  Tmn,
200  TmnLandau,
204  j_QBS
205 };
206 
208 enum class CollisionCriterion {
210  Geometric,
212  Stochastic,
214  Covariant
215 };
216 
218 enum class OutputOnlyFinal {
220  Yes,
222  No,
225  IfNotEmpty,
226 };
227 
229 // Because std::bitset does not handle enum classes, this is a simple enum.
231  All = 50,
232  Elastic = 0,
233  NN_to_NR = 1,
234  NN_to_DR = 2,
235  KN_to_KN = 3,
238  NNbar = 6,
242 };
243 
245 typedef std::bitset<10> ReactionsBitSet;
246 
248 // Because std::bitset does not handle enum classes, this is a simple enum.
254 };
255 
257 typedef std::bitset<4> MultiParticleReactionsBitSet;
258 
269  ModeSampling,
270  BiasedBF,
271  UnbiasedBF,
272 };
273 
275 enum class EventCounting {
278  FixedNumber,
283  Invalid,
284 };
285 
289  BottomUp,
292  TopDown,
296 };
297 
302 enum class PseudoResonance {
304  None,
306  Largest,
309  Closest,
316 };
317 
320 enum class FluidizationType {
322  ConstantTau,
324  Dynamic,
325 };
326 
329 // Because std::bitset does not handle enum classes, this is a simple enum.
336 };
337 
338 typedef std::bitset<5> FluidizableProcessesBitSet;
339 
345 enum class DensityType {
346  None = 0,
347  Hadron = 1,
348  Baryon = 2,
349  BaryonicIsospin = 3,
350  Pion = 4,
351  Isospin3_tot = 5,
352  Charge = 6,
353  Strangeness = 7,
354 };
355 
357 template <typename T>
358 using build_unique_ptr_ = std::unique_ptr<T, std::default_delete<T>>;
359 template <typename T>
360 using build_vector_ = std::vector<T, std::allocator<T>>;
361 
362 using ActionPtr = build_unique_ptr_<Action>;
363 using ScatterActionPtr = build_unique_ptr_<ScatterAction>;
364 using ScatterActionMultiPtr = build_unique_ptr_<ScatterActionMulti>;
365 using ActionList = build_vector_<ActionPtr>;
366 
367 using OutputPtr = build_unique_ptr_<OutputInterface>;
368 using OutputsList = build_vector_<OutputPtr>;
369 
370 using ParticleList = build_vector_<ParticleData>;
371 using ParticleTypeList = build_vector_<ParticleType>;
372 using ParticleTypePtrList = build_vector_<ParticleTypePtr>;
373 using IsoParticleTypeList = build_vector_<IsoParticleType>;
374 
375 template <typename T>
376 using ProcessBranchPtr = build_unique_ptr_<T>;
377 template <typename T>
378 using ProcessBranchList = build_vector_<ProcessBranchPtr<T>>;
379 using DecayBranchPtr = build_unique_ptr_<DecayBranch>;
380 using DecayBranchList = build_vector_<DecayBranchPtr>;
381 using CollisionBranchPtr = build_unique_ptr_<CollisionBranch>;
382 using CollisionBranchList = build_vector_<CollisionBranchPtr>;
383 
384 using TabulationPtr = build_unique_ptr_<Tabulation>;
385 using ExperimentPtr = build_unique_ptr_<ExperimentBase>;
386 using DecayTypePtr = build_unique_ptr_<DecayType>;
387 
389 
390 } // namespace smash
391 
392 #endif // SRC_INCLUDE_SMASH_FORWARDDECLARATIONS_H_
SmearingMode
Modes of smearing.
FermiMotion
Option to use Fermi Motion.
@ On
Use fermi motion in combination with potentials.
@ Frozen
Use fermi motion without potentials.
@ Off
Don't use fermi motion.
std::bitset< 10 > ReactionsBitSet
Container for the 2 to 2 reactions in the code.
ThermalizationAlgorithm
Defines the algorithm used for the forced thermalization.
FluidizationType
Possible methods to convert SMASH particle into fluid cells.
@ ConstantTau
Hypersurface crossed at a fixed proper time.
@ Dynamic
Dynamic fluidization based on local densities.
NNbarTreatment
Treatment of N Nbar Annihilation.
@ NoAnnihilation
No Annihilation.
@ TwoToFive
Directly create 5 pions, use with multi-particle reactions.
@ Resonances
Use intermediate Resonances.
@ Strings
Use string fragmentation.
RestFrameDensityDerivativesMode
Modes of calculating the gradients: whether to calculate the rest frame density derivatives.
TimeStepMode
The time step mode.
@ Fixed
Use fixed time step.
@ None
Don't use time steps; propagate from action to action.
ThermodynamicQuantity
Represents thermodynamic quantities that can be printed out See user guide description for more infor...
@ EckartDensity
Density in the Eckart frame.
@ Tmn
Energy-momentum tensor in lab frame.
@ LandauVelocity
Velocity of the Landau rest frame.
@ j_QBS
Electric (Q), baryonic (B) and strange (S) currents.
@ TmnLandau
Energy-momentum tensor in Landau rest frame.
std::bitset< 5 > FluidizableProcessesBitSet
TotalCrossSectionStrategy
Determine how total cross sections for collision finding should be computed.
@ TopDownMeasured
Mix the two above, using the parametrizations only for measured processes, and summing up partials fo...
@ TopDown
Use parametrizations based on existing data, rescaling with AQM for unmeasured processes.
@ BottomUp
Sum the existing partial contributions.
Sampling
Possible methods of impact parameter sampling.
@ Quadratic
Sample from areal / quadratic distribution.
@ Custom
Sample from custom, user-defined distribution.
@ Uniform
Sample from uniform distribution.
IncludedFluidizableProcesses
The different processes from where fluidizable particles are produced.
@ From_HardString
@ From_Inelastic
@ From_Elastic
@ From_SoftString
@ From_Decay
std::bitset< 4 > MultiParticleReactionsBitSet
Container for the n to m reactions in the code.
CalculationFrame
The calculation frame.
IncludedMultiParticleReactions
The different groups of multi-particle reactions that one can include.
@ NNbar_5to2
@ A3_Nuclei_4to2
@ Deuteron_3to2
@ Meson_3to1
DerivativesMode
Modes of calculating the gradients.
CollisionCriterion
Criteria used to check collisions.
@ Stochastic
Stochastic Criteiron.
@ Geometric
Geometric criterion.
@ Covariant
Covariant Criterion.
FieldDerivativesMode
Modes of calculating the field gradients: chain rule or direct.
SphereInitialCondition
Initial condition for a particle in a sphere.
@ IC_ES
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.
@ IC_Massive
A generalization of IC_ES for the non-zero mass case; note that there is currently no analytical comp...
@ IC_2M
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.
@ IC_1M
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.
PseudoResonance
Which pseudo-resonance fills the inelastic gap in the transition to string region of cross sections.
@ Closest
Resonance with the pole mass closest from the invariant mass of incoming particles for all processes.
@ ClosestFromUnstable
Closest resonance for a given mass from processes with at least one resonance in the incoming particl...
@ LargestFromUnstable
Heaviest possible resonance from processes with at least one resonance in the incoming particles.
@ Largest
Resonance of largest mass for all processes.
EventCounting
Defines how the number of events is determined.
@ Invalid
Unused, only in the code for internal logic.
@ FixedNumber
The desired number of events is simulated disregarding of whether an interaction took place.
@ MinimumNonEmpty
Events are simulated until there are at least a given number of ensembles in which an interaction too...
IncludedReactions
The different groups of 2 to 2 reactions that one can include.
@ KN_to_KDelta
@ KN_to_KN
@ NN_to_NR
@ PiDeuteron_to_pidprime
@ NDeuteron_to_Ndprime
@ Strangeness_exchange
@ PiDeuteron_to_NN
@ NN_to_DR
DensityType
Allows to choose which kind of density to calculate.
OutputOnlyFinal
Whether and when only final state particles should be printed.
@ IfNotEmpty
Print only final-state particles, and those only if the event is not empty.
@ Yes
Print only final-state particles.
@ No
Print initial, intermediate and final-state particles.
BoxInitialCondition
Initial condition for a particle in a box.
@ ThermalMomentaBoltzmann
A thermalized ensemble is generated, with momenta sampled from a Maxwell-Boltzmann distribution.
@ ThermalMomentaQuantum
A thermalized ensemble is generated, with momenta of baryons(mesons) sampled from a Fermi(Bose) distr...
@ PeakedMomenta
All particles have the same momentum with T being the temperature.
ExpansionMode
Defines properties of expansion for the metric (e.g.
Definition: action.h:24