8 #ifndef SRC_INCLUDE_SMASH_ISOPARTICLETYPE_H_ 
    9 #define SRC_INCLUDE_SMASH_ISOPARTICLETYPE_H_ 
   12 #include <unordered_map> 
   79     std::string tmp_s = 
name_;
 
   80     std::size_t found_position = tmp_s.find(
"'");
 
   81     if (found_position != std::string::npos) {
 
   82       tmp_s.erase(found_position, 1);
 
   83       tmp_s.insert(found_position, 
"_prime");
 
  137   static const IsoParticleTypeList &
list_all();
 
  176     using std::runtime_error::runtime_error;
 
  215                                  const bf::path &tabulations_path);
 
IsoParticleType is a class to represent isospin multiplets.
 
double mass_
(average) mass of the multiplet
 
void add_state(const ParticleType &type)
Add a new state to an existing multiplet (and check if isospin symmetry is fulfilled).
 
bool operator==(const IsoParticleType &rhs) const
Returns whether the two IsoParticleType objects have the same PDG code for their first state; if so,...
 
double width_
(average) width of the multiplet
 
static const IsoParticleType * try_find(const std::string &name)
Returns the IsoParticleType pointer for the given name.
 
IsoParticleType(IsoParticleType &&)=default
Move constructor of IsoParticleType (needed for std::sort)
 
Tabulation * XS_NR_tabulation_
A tabulation for the NN -> NR cross sections, where R is a resonance from this multiplet.
 
Tabulation * XS_rhoR_tabulation_
A tabulation for the ρρ integrals.
 
Parity parity_
parity of the multiplet
 
static bool exists(const std::string &name)
Returns whether the ParticleType with the given pdgcode exists.
 
double width() const
Returns the (average) multiplet width.
 
static const IsoParticleType & find(const std::string &name)
Returns the IsoParticleType object for the given name.
 
double get_integral_RR(IsoParticleType *type_res_2, double sqrts)
Look up the tabulated resonance integral for the XX -> RR cross section.
 
const std::string name_filtered_prime() const
Returns the name of the multiplet, after replacing "'" with "_prime".
 
static IsoParticleType & find_private(const std::string &name)
Private version of the 'find' method that returns a non-const reference.
 
Tabulation * XS_piR_tabulation_
A tabulation of the spectral integral for the dpi -> d'pi cross sections.
 
int isospin() const
Returns twice the total isospin of the multiplet.
 
static void create_multiplet(const ParticleType &type)
Add a new multiplet to the global list of IsoParticleTypes, which contains type.
 
static void tabulate_integrals(sha256::Hash hash, const bf::path &tabulations_path)
Tabulate all relevant integrals.
 
ParticleTypePtrList states_
list of states that are contained in the multiplet
 
bool has_anti_multiplet() const
Check if there is a multiplet of antiparticles, which is different from the original multiplet.
 
IsoParticleType(const std::string &n, double m, double w, unsigned int s, Parity p)
Creates a fully initialized IsoParticleType object.
 
IsoParticleType & operator=(const IsoParticleType &)=delete
Assignment is not allowed, see copy constructor above.
 
double get_integral_NR(double sqrts)
Look up the tabulated resonance integral for the XX -> NR cross section.
 
IsoParticleType(const IsoParticleType &)=delete
Copies are not allowed as they break intended use.
 
static const IsoParticleTypeList & list_all()
Returns a list of all IsoParticleTypes.
 
double mass() const
Returns the (average) multiplet mass.
 
Tabulation * XS_DeltaR_tabulation_
A tabulation for the NN -> RΔ cross sections, where R is a resonance from this multiplet.
 
const IsoParticleType * anti_multiplet() const
Return a multiplet of antiparticles, if it is different from the original multiplet.
 
IsoParticleType & operator=(IsoParticleType &&)=default
Move constructor of IsoParticleType "="-operator (needed for std::sort)
 
const std::string & name() const
Returns the name of the multiplet.
 
double get_integral_rhoR(double sqrts)
Look up the tabulated resonance integral for the XX -> rhoR cross section.
 
static const std::vector< const IsoParticleType * > list_baryon_resonances()
Returns a list of all IsoParticleTypes that are baryon resonances.
 
double get_integral_RK(double sqrts)
Look up the tabulated resonance integral for the XX -> RK cross section.
 
std::string name_
name of the multiplet
 
unsigned int spin() const
Returns twice the spin of the multiplet.
 
unsigned int spin_
twice the spin of the multiplet
 
ParticleTypePtrList get_states() const
Returns list of states that form part of the multiplet.
 
Tabulation * XS_RK_tabulation_
A tabulation of the spectral integral for the NK -> RK cross sections.
 
double get_integral_piR(double sqrts)
Look up the tabulated resonance integral for the XX -> piR cross section.
 
static const ParticleTypePtr find_state(const std::string &name)
Returns the ParticleType object for the given name, by first finding the correct multiplet and then l...
 
A pointer-like interface to global references to ParticleType objects.
 
Particle type contains the static properties of a particle species.
 
A class for storing a one-dimensional lookup table of floating-point values.
 
std::array< uint8_t, HASH_SIZE > Hash
A SHA256 hash.
 
Parity
Represent the parity of a particle type.
 
Throw when requested particle could not be found.