1#ifndef EFFECTIVEMASSMODEL_H
2#define EFFECTIVEMASSMODEL_H
68 virtual double D2pf(
double x)
const {
return 1. /
m_c; }
105 virtual double pf(
double x)
const {
116 virtual double Dpf(
double x)
const {
126 virtual double D2pf(
double x)
const {
148 double m_DensityScalar;
149 double m_EntropyDensity;
195 double ComputeTBEC(
double Mu,
double TBECinit = -1.)
const;
238 double Meff()
const {
return m_Meff; }
313 std::vector<double>
Equations(
const std::vector<double> &x);
339 std::vector<double>
Equations(
const std::vector<double> &x);
366 std::vector<double>
Equations(
const std::vector<double> &x);
Implementation of the generic Broyden's method routines.
int m_N
The number of equations.
BroydenEquations()=default
Default constructor. Does nothing.
virtual EMMFieldPressure * clone() const
Creates a clone of this EMMFieldPressureChPT object.
EMMFieldPressureChPT(double mass=0.135, double fpi=0.133)
Constructor for the EMMFieldPressureChPT class.
virtual double Dpf(double x) const
Derivative of the field pressure with respect to effective mass x according to ChPT.
virtual ~EMMFieldPressureChPT()
Virtual destructor for the EMMFieldPressureChPT class.
virtual double pf(double x) const
Field pressure as a function of effective mass x according to ChPT.
virtual double D2pf(double x) const
Second derivative of the field pressure with respect to effective mass x according to ChPT.
Base class implementing field pressure contribution function in the effective mass model....
EMMFieldPressure(double mass=0.135, double c=0)
Constructor for the EMMFieldPressure class.
virtual double pf(double x) const
Field pressure as a function of effective mass x.
virtual ~EMMFieldPressure()
Virtual destructor for the EMMFieldPressure class.
virtual double D2pf(double x) const
Second derivative of the field pressure with respect to effective mass x.
virtual EMMFieldPressure * clone() const
Creates a clone of this EMMFieldPressure object.
virtual double Dpf(double x) const
Derivative of the field pressure with respect to effective mass x.
BroydenEquationsEMMMeffConstrained(const EffectiveMassModel *model)
Constructor for the BroydenEquationsEMMMeffConstrained class.
std::vector< double > Equations(const std::vector< double > &x)
Implements the equations to be solved.
BroydenEquationsEMMMeff(const EffectiveMassModel *model)
Constructor for the BroydenEquationsEMMMeff class.
std::vector< double > Equations(const std::vector< double > &x)
Implements the equations to be solved.
std::vector< double > Equations(const std::vector< double > &x)
Implements the equations to be solved.
BroydenEquationsEMMTBEC(const EffectiveMassModel *model, double MuBEC)
Constructor for the BroydenEquationsEMMTBEC class.
double ComputeTBEC(double Mu, double TBECinit=-1.) const
Calculates the temperature of BEC formation for a given chemical potential.
bool IsSolved() const
Checks if the EMM equations are solved.
void SetParameters(double T, double Mu)
Sets the temperature and chemical potential of the particle.
virtual bool IsBECPhase() const
Checks if the particle is in a Bose-Einstein condensed phase.
void SetMeff(double meff)
Sets the effective mass manually.
void SolveMeff(double meffinit=-1.)
Solves for the effective mass using the given parameters.
double Density() const
Calculates the number density in 1/fm^3.
double EnergyDensity() const
Calculates the energy density in GeV/fm^3.
virtual double EffectiveMass() const
Gets the effective mass.
double ChemicalPotential() const
Gets the current chemical potential.
EffectiveMassModel(const ThermalParticle &particle=ThermalParticle(true, "pi", 211, 1.0, -1, 0.135, 0, 0, 1), EMMFieldPressure *FieldPressure=NULL)
Constructor for the EffectiveMassModel class.
double Pressure() const
Calculates the pressure in GeV/fm^3.
virtual double Quantity(IdealGasFunctions::Quantity quantity, double T, double mu)
Calculates a thermodynamic quantity.
virtual double BECFraction() const
Calculates the fraction of particles in the BEC phase.
double EntropyDensity() const
Calculates the entropy density in 1/fm^3.
double Meff() const
Gets the current effective mass.
double Temperature() const
Gets the current temperature.
virtual ~EffectiveMassModel(void)
Destructor for the EffectiveMassModel class.
Class containing all information about a particle specie.
Quantity
Identifies the thermodynamic function.
constexpr double GeVtoifm()
A constant to transform GeV into fm .
The main namespace where all classes and functions of the Thermal-FIST library reside.