37 m_Parameters.muS = 0.;
39 m_TAG =
"ThermalModelCanonicalStrangeness";
42 m_InteractionModel =
Ideal;
52 m_Parameters.muS = 0.;
57 m_Parameters.muS = 0.0;
65 m_ConstrainMuS =
false;
66 m_ConstrainMuC =
false;
73 m_QuantumStats = stats;
74 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i)
75 if (m_TPS->Particles()[i].Strangeness() == 0) m_TPS->Particle(i).UseStatistics(stats);
76 else m_TPS->Particle(i).UseStatistics(
false);
80 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i) {
83 m_GCECalculated =
true;
88 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i) {
96 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i) {
103 if (!m_GCECalculated)
109 vector<double> xi(3, 0.), yi(3, 0.);
111 for (
size_t i = 0; i <
m_StrVals.size(); ++i) {
113 for (
int j = 0; j < m_TPS->ComponentsNumber(); ++j)
114 if (
m_StrVals[i] == m_TPS->Particles()[j].Strangeness())
118 for (
int i = 0; i < 3; ++i) {
126 for (
unsigned int i = 0; i <
m_StrVals.size(); ++i) {
129 for (
int m = -iters; m <= iters; ++m)
130 for (
int n = -iters; n <= iters; ++n) {
134 pow(yi[0],
m_StrVals[i] - 3 * m - 2 * n) *
137 if (tmp != tmp)
continue;
145 assert(m_IGFExtraConfig.MagneticField.B == 0.);
148 throw std::runtime_error(
"ThermalModelCanonicalStrangeness::CalculatePrimordialDensities(): PCE not supported!");
151 m_FluctuationsCalculated =
false;
160 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i) {
161 if (
m_StrMap.count(-m_TPS->Particles()[i].Strangeness()))
171 m_wprim.resize(m_densities.size());
172 m_wtot.resize(m_densities.size());
173 for (
size_t i = 0; i < m_wprim.size(); ++i) {
188 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i)
189 if (
m_StrMap.count(-m_TPS->Particles()[i].Strangeness()))
199 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i)
200 if (m_TPS->Particles()[i].Strangeness() != 0) {
201 if (
m_StrMap.count(-m_TPS->Particles()[i].Strangeness()))
215 for (
int i = 0; i < m_TPS->ComponentsNumber(); ++i)
216 if (
m_StrMap.count(-m_TPS->Particles()[i].Strangeness()))
map< string, double > params
virtual void ChangeTPS(ThermalParticleSystem *TPS)
Change the particle list.
bool UsePartialChemicalEquilibrium()
Whether partial chemical equilibrium with additional chemical potentials is used.
virtual void FixParameters()
Method which actually implements ConstrainChemicalPotentials() (for backward compatibility).
virtual void SetParameters(const ThermalModelParameters ¶ms)
The thermal parameters.
virtual void ValidateCalculation()
Checks whether issues have occured during the calculation of particle densities in the CalculateDensi...
ThermalModelBase(ThermalParticleSystem *TPS, const ThermalModelParameters ¶ms=ThermalModelParameters())
Construct a new ThermalModelBase object.
virtual void CalculateDensities()
Calculates the primordial and total (after decays) densities of all species.
@ SCE
Strangeness-canonical ensemble.
std::vector< double > m_Zsum
virtual void SetStatistics(bool stats)
virtual void CalculateEnergyDensitiesGCE()
Calculates the grand-canonical energy densities.
virtual void CalculateDensitiesGCE()
Calculates the particle densities in a grand-canonical ensemble.
virtual double CalculateEnergyDensity()
virtual void CalculatePrimordialDensities()
Calculates the primordial densities of all species.
ThermalModelCanonicalStrangeness(ThermalParticleSystem *TPS, const ThermalModelParameters ¶ms=ThermalModelParameters())
Construct a new ThermalModelCanonicalStrangeness object.
virtual void SetStrangenessChemicalPotential(double muS)
Override the base class method to always set to zero.
virtual void FixParameters()
Method which actually implements ConstrainChemicalPotentials() (for backward compatibility).
std::vector< int > m_StrVals
virtual void CalculateSums(double Vc)
Calculates the strangeness-canonical partition functions.
std::map< int, int > m_StrMap
void CalculateFluctuations()
Dummy function. Fluctuations not yet supported.
std::vector< double > m_partialS
virtual ~ThermalModelCanonicalStrangeness(void)
Destroy the ThermalModelCanonicalStrangeness object.
virtual bool IsConservedChargeCanonical(ConservedCharge::Name charge) const
virtual void CalculatePressuresGCE()
Calculates the grand-canonical pressures.
std::vector< double > m_pressuresGCE
virtual void ChangeTPS(ThermalParticleSystem *TPS)
Change the particle list.
std::vector< double > m_densitiesGCE
virtual void SetParameters(const ThermalModelParameters ¶ms)
The thermal parameters.
virtual double CalculateEntropyDensity()
std::vector< double > m_energydensitiesGCE
virtual double CalculatePressure()
Class containing the particle list.
double BesselI(int n, double x)
Integer order modified Bessel function I_n(x)
The main namespace where all classes and functions of the Thermal-FIST library reside.
Name
Set of all conserved charges considered.
@ StrangenessCharge
Strangeness.
Structure containing all thermal parameters of the model.
Contains some extra mathematical functions used in the code.