Thermal-FIST 1.5
Package for hadron resonance gas model applications
Loading...
Searching...
No Matches
thermalfist::ExcludedVolumeModelComponents Class Reference

Implementation of an excluded volume model with components. More...

#include <ExcludedVolumeModelsMulti.h>

Inheritance diagram for thermalfist::ExcludedVolumeModelComponents:
thermalfist::ExcludedVolumeModelMultiBase

Public Member Functions

 ExcludedVolumeModelComponents (int components, const std::vector< ExcludedVolumeModelBase * > &evmods, const std::vector< int > &ind, const std::vector< double > &b, const std::vector< double > &dbdT=std::vector< double >())
 Constructor for the ExcludedVolumeModelComponents class.
 
virtual ~ExcludedVolumeModelComponents ()
 Destructor for the ExcludedVolumeModelComponents class.
 
virtual double f (int i) const
 Calculates the suppression factor for species i.
 
virtual double df (int i, int j) const
 Calculates the first derivative of the suppression factor.
 
virtual double d2f (int i, int j, int k) const
 Calculates the second derivative of the suppression factor.
 
virtual double d3f (int i, int j, int k, int l) const
 Calculates the third derivative of the suppression factor.
 
virtual double d4f (int i, int j, int k, int l, int m) const
 Calculates the fourth derivative of the suppression factor.
 
virtual double dfdT (int i) const
 Calculates the temperature derivative of the suppression factor.
 
virtual std::vector< double > nsol (const std::vector< double > &nid)
 Solves for the actual densities given the ideal gas densities.
 
virtual void SetDensities (const std::vector< double > &n)
 Sets the densities of particle species.
 
- Public Member Functions inherited from thermalfist::ExcludedVolumeModelMultiBase
 ExcludedVolumeModelMultiBase (int N)
 Constructor for the ExcludedVolumeModelMultiBase class.
 
virtual ~ExcludedVolumeModelMultiBase ()
 
virtual std::vector< double > nsolBroyden (const std::vector< double > &ntil)
 Solves for the actual densities using Broyden's method.
 
virtual std::vector< double > nsolBroydenComponents (const std::vector< double > &ntil)
 Solves for the actual densities using Broyden's method, considering components.
 
virtual const std::vector< int > & ComponentIndices () const
 Gets the component indices.
 
virtual const std::vector< int > & ComponentIndicesFrom () const
 Gets the component indices from.
 
virtual const int ComponentsNumber () const
 Gets the number of components.
 

Protected Member Functions

virtual void ComputeComponents ()
 Computes the components based on the excluded volume parameters.
 

Protected Attributes

std::vector< ExcludedVolumeModelBase * > m_evmodels
 
std::vector< double > m_b
 
std::vector< double > m_dbdT
 
std::vector< double > m_densities_components
 
- Protected Attributes inherited from thermalfist::ExcludedVolumeModelMultiBase
int m_N
 
std::vector< double > m_densities
 
std::vector< int > m_components
 
std::vector< int > m_componentsFrom
 
int m_componentsNumber
 

Detailed Description

Implementation of an excluded volume model with components.

This class implements an excluded volume model where particles are grouped into components with similar excluded volume properties.

Definition at line 643 of file ExcludedVolumeModelsMulti.h.

Constructor & Destructor Documentation

◆ ExcludedVolumeModelComponents()

thermalfist::ExcludedVolumeModelComponents::ExcludedVolumeModelComponents ( int components,
const std::vector< ExcludedVolumeModelBase * > & evmods,
const std::vector< int > & ind,
const std::vector< double > & b,
const std::vector< double > & dbdT = std::vector<double>() )
inline

Constructor for the ExcludedVolumeModelComponents class.

Parameters
componentsNumber of components.
evmodsVector of excluded volume models for each component.
indVector of component indices for each particle species.
bVector of excluded volumes for each species.
dbdTVector of temperature derivatives of excluded volumes (optional).

Definition at line 655 of file ExcludedVolumeModelsMulti.h.

◆ ~ExcludedVolumeModelComponents()

thermalfist::ExcludedVolumeModelComponents::~ExcludedVolumeModelComponents ( )
virtual

Destructor for the ExcludedVolumeModelComponents class.

Definition at line 483 of file ExcludedVolumeModelsMulti.cpp.

Member Function Documentation

◆ ComputeComponents()

void thermalfist::ExcludedVolumeModelComponents::ComputeComponents ( )
protectedvirtual

Computes the components based on the excluded volume parameters.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 475 of file ExcludedVolumeModelsMulti.cpp.

◆ d2f()

double thermalfist::ExcludedVolumeModelComponents::d2f ( int i,
int j,
int k ) const
virtual

Calculates the second derivative of the suppression factor.

Parameters
iFirst species index.
jSecond species index.
kThird species index.
Returns
Second derivative of the suppression factor.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 511 of file ExcludedVolumeModelsMulti.cpp.

◆ d3f()

double thermalfist::ExcludedVolumeModelComponents::d3f ( int i,
int j,
int k,
int l ) const
virtual

Calculates the third derivative of the suppression factor.

Parameters
iFirst species index.
jSecond species index.
kThird species index.
lFourth species index.
Returns
Third derivative of the suppression factor.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 523 of file ExcludedVolumeModelsMulti.cpp.

◆ d4f()

double thermalfist::ExcludedVolumeModelComponents::d4f ( int i,
int j,
int k,
int l,
int m ) const
virtual

Calculates the fourth derivative of the suppression factor.

Parameters
iFirst species index.
jSecond species index.
kThird species index.
lFourth species index.
mFifth species index.
Returns
Fourth derivative of the suppression factor.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 536 of file ExcludedVolumeModelsMulti.cpp.

◆ df()

double thermalfist::ExcludedVolumeModelComponents::df ( int i,
int j ) const
virtual

Calculates the first derivative of the suppression factor.

Parameters
iFirst species index.
jSecond species index.
Returns
First derivative of the suppression factor.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 500 of file ExcludedVolumeModelsMulti.cpp.

◆ dfdT()

double thermalfist::ExcludedVolumeModelComponents::dfdT ( int i) const
virtual

Calculates the temperature derivative of the suppression factor.

Parameters
iSpecies index.
Returns
Temperature derivative of the suppression factor.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 550 of file ExcludedVolumeModelsMulti.cpp.

◆ f()

double thermalfist::ExcludedVolumeModelComponents::f ( int i) const
virtual

Calculates the suppression factor for species i.

Parameters
iIndex of the particle species.
Returns
Suppression factor for species i.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 493 of file ExcludedVolumeModelsMulti.cpp.

◆ nsol()

std::vector< double > thermalfist::ExcludedVolumeModelComponents::nsol ( const std::vector< double > & nid)
virtual

Solves for the actual densities given the ideal gas densities.

Parameters
nidVector of ideal gas densities.
Returns
Vector of actual densities.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 557 of file ExcludedVolumeModelsMulti.cpp.

◆ SetDensities()

void thermalfist::ExcludedVolumeModelComponents::SetDensities ( const std::vector< double > & n)
virtual

Sets the densities of particle species.

Parameters
nVector of densities.

Reimplemented from thermalfist::ExcludedVolumeModelMultiBase.

Definition at line 464 of file ExcludedVolumeModelsMulti.cpp.

Member Data Documentation

◆ m_b

std::vector<double> thermalfist::ExcludedVolumeModelComponents::m_b
protected

Definition at line 753 of file ExcludedVolumeModelsMulti.h.

◆ m_dbdT

std::vector<double> thermalfist::ExcludedVolumeModelComponents::m_dbdT
protected

Definition at line 754 of file ExcludedVolumeModelsMulti.h.

◆ m_densities_components

std::vector<double> thermalfist::ExcludedVolumeModelComponents::m_densities_components
protected

Definition at line 755 of file ExcludedVolumeModelsMulti.h.

◆ m_evmodels

std::vector<ExcludedVolumeModelBase*> thermalfist::ExcludedVolumeModelComponents::m_evmodels
protected

Definition at line 751 of file ExcludedVolumeModelsMulti.h.


The documentation for this class was generated from the following files: