Thermal-FIST 1.5
Package for hadron resonance gas model applications
Loading...
Searching...
No Matches
ThermalModelEVCrosstermsLegacy.h
Go to the documentation of this file.
1/*
2 * Thermal-FIST package
3 *
4 * Copyright (c) 2015-2018 Volodymyr Vovchenko
5 *
6 * GNU General Public License (GPLv3 or later)
7 */
8#ifndef THERMALMODELEVCROSSTERMSLEGACY_H
9#define THERMALMODELEVCROSSTERMSLEGACY_H
10
12
13namespace thermalfist {
14
39 {
40 public:
48
54
55 // Override functions begin
56
57 virtual void FillVirial(const std::vector<double> & ri = std::vector<double>(0));
58
59 virtual void ReadInteractionParameters(const std::string &filename);
60
61 virtual void WriteInteractionParameters(const std::string &filename);
62
63 void SetRadius(double rad);
64
65 double VirialCoefficient(int i, int j) const;
66
67 void SetVirial(int i, int j, double b);
68
69 virtual void ChangeTPS(ThermalParticleSystem *TPS);
70
71 virtual void CalculatePrimordialDensities();
72
74
76
77 virtual std::vector<double> CalculateChargeFluctuations(const std::vector<double> &chgs, int order = 4);
78
79 virtual double CalculatePressure();
80
81 virtual double CalculateEnergyDensity();
82
83 virtual double CalculateEntropyDensity();
84
85 // Dummy
86 virtual double CalculateBaryonMatterEntropyDensity() { return 0.; }
87 virtual double CalculateMesonMatterEntropyDensity() { return 0.; }
88
89 virtual double CalculateEnergyDensityDerivativeT() { exit(1); return 0.; } // Not implemented
90
91 // TODO properly with excluded volume
92 virtual double ParticleScaledVariance(int /*part*/) { return 1.; }
93
94 // TODO properly with excluded volume
95 virtual double ParticleSkewness(int part) { return m_skewprim[part]; }
96
97 // TODO properly with excluded volume
98 virtual double ParticleKurtosis(int part) { return m_kurtprim[part]; }
99
100 // TODO properly with excluded volume
101 virtual double ParticleScalarDensity(int /*part*/) { return 0.; }
102
103 // Override functions end
104
105
106 const std::vector< std::vector<int> >& EVComponentIndices() const { return m_EVComponentIndices; }
107 virtual double DeltaMu(int i) const { return MuShift(i); }
108 const std::vector< std::vector<double> >& VirialMatrix() const { return m_Virial; }
109
110 protected:
118 virtual void SolvePressure(bool resetPartials = true); // Using Broyden's method
119
120 void SolvePressureIter(); // Using iteration method
121
123
125
136 virtual void SolveDiagonal();
137
146 double PartialPressureDiagonal(int i, double P);
147
155 double PressureDiagonalTotal(double P);
156
166 virtual double DensityId(int i, const std::vector<double>& pstars = std::vector<double>());
167
177 virtual double Pressure(int i, const std::vector<double>& pstars = std::vector<double>());
178
189 double ScaledVarianceId(int ind);
190
201 virtual double MuShift(int i) const;
202
203 std::vector<double> m_densitiesid;
204 std::vector<double> m_Ps;
205 std::vector< std::vector<double> > m_Virial;
206 double m_Pressure;
208
209
210 std::vector<int> m_MapToEVComponent;
211 std::vector<int> m_MapFromEVComponent;
212 std::vector< std::vector<int> > m_EVComponentIndices;
213
214 private:
215 class BroydenEquationsCRS : public BroydenEquations
216 {
217 public:
218 BroydenEquationsCRS(ThermalModelEVCrosstermsLegacy*model) : BroydenEquations(), m_THM(model) { m_N = model->Densities().size(); }
219 std::vector<double> Equations(const std::vector<double> &x);
220 private:
222 };
223
224 class BroydenEquationsCRSDEV : public BroydenEquations
225 {
226 public:
227 BroydenEquationsCRSDEV(ThermalModelEVCrosstermsLegacy*model) : BroydenEquations(), m_THM(model) { m_N = 1; }
228 std::vector<double> Equations(const std::vector<double> &x);
229 private:
231 };
232
233 class BroydenJacobianCRS : public BroydenJacobian
234 {
235 public:
236 BroydenJacobianCRS(ThermalModelEVCrosstermsLegacy*model) : BroydenJacobian(), m_THM(model) { }
237 std::vector<double> Jacobian(const std::vector<double> &x);
238 private:
240 };
241
242 class BroydenSolutionCriteriumCRS : public Broyden::BroydenSolutionCriterium
243 {
244 public:
245 BroydenSolutionCriteriumCRS(ThermalModelEVCrosstermsLegacy*model, double relative_error = Broyden::TOL) : Broyden::BroydenSolutionCriterium(relative_error), m_THM(model) { }
246 virtual bool IsSolved(const std::vector<double>& x, const std::vector<double>& f, const std::vector<double>& xdelta = std::vector<double>()) const;
247 protected:
249 };
250 };
251
252} // namespace thermalfist
253
254#endif
255
map< string, double > params
BroydenSolutionCriterium(double maximum_error=TOL)
Definition Broyden.h:153
Abstract class which defines the system of non-linear equations to be solved by the Broyden's method.
Definition Broyden.h:32
int m_N
The number of equations.
Definition Broyden.h:66
BroydenEquations()=default
Default constructor. Does nothing.
static const double TOL
Default desired solution accuracy.
Definition Broyden.h:183
BroydenJacobian(BroydenEquations *eqs=NULL)
Construct a new BroydenJacobian object.
Definition Broyden.h:89
ThermalModelBase(ThermalParticleSystem *TPS, const ThermalModelParameters &params=ThermalModelParameters())
Construct a new ThermalModelBase object.
Class implementing the crossterms excluded-volume model.
const std::vector< std::vector< double > > & VirialMatrix() const
virtual double Pressure(int i, const std::vector< double > &pstars=std::vector< double >())
Calculate the ideal gas pressure of particle species i for the given values of partial pressures.
virtual void WriteInteractionParameters(const std::string &filename)
Write the QvdW interaction parameters to a file.
double VirialCoefficient(int i, int j) const
Excluded volume coefficient .
void SetVirial(int i, int j, double b)
Set the excluded volume coefficient .
void CalculateFluctuations()
Computes the fluctuation observables.
double PressureDiagonalTotal(double P)
The total pressure for the given input pressure in the diagonal model.
virtual double MuShift(int i) const
The shift in the chemical potential of particle species i due to the excluded volume interactions.
virtual ~ThermalModelEVCrosstermsLegacy(void)
Destroy the ThermalModelEVCrossterms object.
virtual void FillVirial(const std::vector< double > &ri=std::vector< double >(0))
Fills the excluded volume coefficients based on the provided radii parameters for all species.
virtual std::vector< double > CalculateChargeFluctuations(const std::vector< double > &chgs, int order=4)
Calculates fluctuations (diagonal susceptibilities) of an arbitrary "conserved" charge.
virtual double DensityId(int i, const std::vector< double > &pstars=std::vector< double >())
Calculate the ideal gas density of particle species i for the given values of partial pressures.
void CalculateTwoParticleCorrelations()
Computes the fluctuations and correlations of the primordial particle numbers.
virtual void SolvePressure(bool resetPartials=true)
Solves the system of transcdental equations for the pressure using the Broyden's method.
virtual void ReadInteractionParameters(const std::string &filename)
Reads the QvdW interaction parameters from a file.
virtual void SolveDiagonal()
Solves the transcendental equation of the corresponding diagonal EV model.
void SetRadius(double rad)
Set the same excluded volume radius parameter for all species.
virtual void ChangeTPS(ThermalParticleSystem *TPS)
Change the particle list.
const std::vector< std::vector< int > > & EVComponentIndices() const
ThermalModelEVCrosstermsLegacy(ThermalParticleSystem *TPS, const ThermalModelParameters &params=ThermalModelParameters())
Construct a new ThermalModelEVCrossterms object.
double PartialPressureDiagonal(int i, double P)
The "partial pressure" of hadron species i for the given total pressure in the diagonal model.
virtual void CalculatePrimordialDensities()
Calculates the primordial densities of all species.
double ScaledVarianceId(int ind)
Calculate the ideal gas scaled variance of particle species i number fluctuations for the given value...
Class containing the particle list.
The main namespace where all classes and functions of the Thermal-FIST library reside.
Definition CosmicEoS.h:9
Structure containing all thermal parameters of the model.