8#ifndef THERMALMODELEVCROSSTERMSLEGACY_H
9#define THERMALMODELEVCROSSTERMSLEGACY_H
57 virtual void FillVirial(
const std::vector<double> & ri = std::vector<double>(0));
166 virtual double DensityId(
int i,
const std::vector<double>& pstars = std::vector<double>());
177 virtual double Pressure(
int i,
const std::vector<double>& pstars = std::vector<double>());
201 virtual double MuShift(
int i)
const;
219 std::vector<double> Equations(
const std::vector<double> &x);
228 std::vector<double> Equations(
const std::vector<double> &x);
233 class BroydenJacobianCRS :
public BroydenJacobian
237 std::vector<double> Jacobian(
const std::vector<double> &x);
242 class BroydenSolutionCriteriumCRS :
public Broyden::BroydenSolutionCriterium
246 virtual bool IsSolved(
const std::vector<double>& x,
const std::vector<double>& f,
const std::vector<double>& xdelta = std::vector<double>())
const;
map< string, double > params
BroydenSolutionCriterium(double maximum_error=TOL)
Abstract class which defines the system of non-linear equations to be solved by the Broyden's method.
int m_N
The number of equations.
BroydenEquations()=default
Default constructor. Does nothing.
static const double TOL
Default desired solution accuracy.
BroydenJacobian(BroydenEquations *eqs=NULL)
Construct a new BroydenJacobian object.
ThermalModelBase(ThermalParticleSystem *TPS, const ThermalModelParameters ¶ms=ThermalModelParameters())
Construct a new ThermalModelBase object.
Class implementing the crossterms excluded-volume model.
std::vector< int > m_MapFromEVComponent
virtual double CalculateEntropyDensity()
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 double CalculateEnergyDensity()
virtual double DeltaMu(int i) const
virtual double ParticleSkewness(int part)
virtual double CalculateEnergyDensityDerivativeT()
virtual double CalculatePressure()
std::vector< std::vector< double > > m_Virial
virtual double ParticleScaledVariance(int)
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.
virtual void CalculatePrimordialDensitiesNoReset()
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 double ParticleKurtosis(int part)
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.
double m_TotalEntropyDensity
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.
std::vector< double > m_densitiesid
std::vector< int > m_MapToEVComponent
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.
std::vector< std::vector< int > > m_EVComponentIndices
virtual double CalculateBaryonMatterEntropyDensity()
virtual void ChangeTPS(ThermalParticleSystem *TPS)
Change the particle list.
std::vector< double > m_Ps
const std::vector< std::vector< int > > & EVComponentIndices() const
ThermalModelEVCrosstermsLegacy(ThermalParticleSystem *TPS, const ThermalModelParameters ¶ms=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 double CalculateMesonMatterEntropyDensity()
virtual void CalculatePrimordialDensitiesIter()
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...
virtual double ParticleScalarDensity(int)
Class containing the particle list.
The main namespace where all classes and functions of the Thermal-FIST library reside.
Structure containing all thermal parameters of the model.