316 std::vector<double>
SolveChemicalPotentials(
double T,
const std::vector<double>& muInit = std::vector<double>());
445 std::vector<double>
Equations(
const std::vector<double>& x);
Implementation of the generic Broyden's method routines.
Header with effective mass model implementation, including the Bose-condensed phase.
int m_N
The number of equations.
BroydenEquations()=default
Default constructor. Does nothing.
BroydenEquationsCosmology(CosmicEoS *model)
Constructor for the BroydenEquationsCosmology class.
std::vector< double > Equations(const std::vector< double > &x)
Implements the equations to be solved.
double BaryonAsymmetry() const
Gets the current baryon asymmetry.
double PressureHRG()
Calculates the partial pressure of the HRG part.
virtual void SetLeptonAsymmetry(LeptonFlavor::Name flavor, double l)
Sets the lepton flavor asymmetry (lepton flavor over entropy density).
double Temperature() const
Gets the current temperature.
bool m_IsCalculated
Whether the system has been calculated.
std::string GetSpeciesName(int id) const
Gets the name of particle species of given id.
virtual void SetLeptonChemicalPotential(LeptonFlavor::Name flavor, double muL)
Set the lepton chemical potential.
virtual void SetChargeAsymmetry(double q)
Sets the electric charge asymmetry (charge over entropy density).
bool m_InteractingPions
Whether to include pion interactions.
double ChargeAsymmetry() const
Gets the current electric charge asymmetry.
virtual void SetBaryonChemicalPotential(double muB)
Set the baryon chemical potential.
std::vector< double > SolveChemicalPotentials(double T, const std::vector< double > &muInit=std::vector< double >())
Calculates the values of the chemical potential (B,Q,{L}) that satisfy the given asymmetry constraint...
double EnergyDensity()
Calculates the total energy density.
virtual void SetElectricChemicalPotential(double muQ)
Set the electric chemical potential.
double LeptonChemicalPotential(LeptonFlavor::Name flavor) const
Gets the current lepton chemical potential for a specific flavor.
std::vector< ThermalParticle > m_Neutrinos
Neutrinos.
ThermalParticle m_Photon
Photons.
static double fpi
Pion decay constant for pion interactions a la ChPT.
double EntropyDensityHRG()
Calculates the entropy density of the HRG part.
std::vector< double > m_Asymmetries
Vector of asymmetries (baryon, charge, lepton flavors)
double LeptonAsymmetry(LeptonFlavor::Name flavor) const
Gets the current lepton flavor asymmetry.
CosmicEoS(ThermalModelBase *THMbase, bool pionsinteract=false)
Constructor.
int NumberOfElectroWeakSpecies() const
Gets the number of electroweak species (charged leptons and neutrinos) in the model.
std::vector< double > m_ChemCurrent
Vector of chemical potentials (baryon, charge, lepton flavors)
double ElectricChargeDensity(bool absolute=false)
Calculates the electric charge density.
ThermalModelBase * HRGModel() const
Gets the pointer to the HRG model object.
double PressureChargedLepton(int iL)
Calculates the partial pressure of charged lepton flavor.
std::vector< ThermalParticle > m_ChargedLeptons
Charged leptons.
double EnergyDensityHRG()
Calculates the energy density of the HRG part.
bool InPionCondensedPhase() const
Checks if the system has non-zero BEC of pions.
double ElectricChargeDensityHRG(bool absolute=false)
Calculates the electric charge density of the HRG part.
void SetPionsInteracting(bool pionsinteract=true, double fpiChPT=fpi)
Sets whether to include pion interactions via effective mass model.
virtual void SetTemperature(double T)
Set the temperature.
double EnergyDensityChargedLepton(int iL)
Calculates the energy density of charged lepton flavor.
const std::vector< double > & ChemicalPotentials() const
Gets the chemical potentials (baryon number, electric charge, three lepton charges).
void CalculatePrimordialDensities()
Calculates number densities of all particle species.
double NetDensityChargedLepton(int iL)
Calculates the net density of charged lepton flavor.
void ClearEMMs()
Clears the effective mass models.
double BaryonDensity(bool absolute=false)
Calculates the total baryon density.
virtual void SetBaryonAsymmetry(double b)
Sets the baryon number asymmetry (baryon over entropy density).
void SetAsymmetries(const std::vector< double > &asymmetries)
Sets all asymmetries at once.
double GetPionMass() const
Gets the mass of pi+.
double Pressure()
Calculates the total pressure.
bool InteractingPions() const
Checks if pions are interacting in the model.
double ElectricChemicalPotential() const
Gets the current electric chemical potential.
virtual ~CosmicEoS(void)
Destructor.
double LeptonFlavorDensity(LeptonFlavor::Name flavor, bool absolute=false)
Calculates the lepton flavor density.
double EntropyDensity()
Calculates the total entropy density.
ThermalModelBase * m_modelHRG
Pointer to an HRG model object.
double IsospinChargeDensity(bool absolute=false)
Calculates the isospin charge density.
double GetDensity(int id) const
Gets the number density for given species.
double m_T
Temperature in GeV.
double BaryonChemicalPotential() const
Gets the baryon chemical potential.
const ThermalParticle & PhotonParticle() const
Gets the ThermalParticle object instance corresponding to photons.
Abstract base class for an HRG model implementation.
Class containing all information about a particle specie.
The main namespace where all classes and functions of the Thermal-FIST library reside.
double IsospinCharge(const ThermalParticle &part)
Calculates the isospin charge of a particle.
An auxiliary struct containing the list of conserved lepton flavor charges.
static const int NumberOfFlavors
Number of lepton flavors.
static double m_mu
Muon mass.
Name
Set of all conserved charges considered.
static double m_e
Electron mass.
static double m_tau
Tauon mass.