Cantera
2.5.1
|
Class Phase is the base class for phases of matter, managing the species and elements in a phase, as well as the independent variables of temperature, mass density (compressible substances) or pressure (incompressible substances), species mass/mole fraction, and other generalized forces and intrinsic properties (such as electric potential) that define the thermodynamic state. More...
#include <Phase.h>
Public Member Functions | |
Phase () | |
Default constructor. More... | |
Phase (const Phase &)=delete | |
Phase & | operator= (const Phase &)=delete |
XML_Node & | xml () const |
Returns a const reference to the XML_Node that describes the phase. More... | |
void | setXMLdata (XML_Node &xmlPhase) |
Stores the XML tree information for the current phase. More... | |
virtual bool | isPure () const |
Return whether phase represents a pure (single species) substance. More... | |
virtual bool | hasPhaseTransition () const |
Return whether phase represents a substance with phase transitions. More... | |
virtual bool | isCompressible () const |
Return whether phase represents a compressible substance. More... | |
virtual std::map< std::string, size_t > | nativeState () const |
Return a map of properties defining the native state of a substance. More... | |
virtual std::vector< std::string > | fullStates () const |
Return a vector containing full states defining a phase. More... | |
virtual std::vector< std::string > | partialStates () const |
Return a vector of settable partial property sets within a phase. More... | |
virtual size_t | stateSize () const |
Return size of vector defining internal state of the phase. More... | |
void | saveState (vector_fp &state) const |
Save the current internal state of the phase. More... | |
virtual void | saveState (size_t lenstate, doublereal *state) const |
Write to array 'state' the current internal state. More... | |
void | restoreState (const vector_fp &state) |
Restore a state saved on a previous call to saveState. More... | |
virtual void | restoreState (size_t lenstate, const doublereal *state) |
Restore the state of the phase from a previously saved state vector. More... | |
doublereal | molecularWeight (size_t k) const |
Molecular weight of species k . More... | |
void | getMolecularWeights (vector_fp &weights) const |
Copy the vector of molecular weights into vector weights. More... | |
void | getMolecularWeights (doublereal *weights) const |
Copy the vector of molecular weights into array weights. More... | |
const vector_fp & | molecularWeights () const |
Return a const reference to the internal vector of molecular weights. More... | |
void | getCharges (double *charges) const |
Copy the vector of species charges into array charges. More... | |
virtual bool | ready () const |
Returns a bool indicating whether the object is ready for use. More... | |
int | stateMFNumber () const |
Return the State Mole Fraction Number. More... | |
virtual void | invalidateCache () |
Invalidate any cached values which are normally updated only when a change in state is detected. More... | |
bool | caseSensitiveSpecies () const |
Returns true if case sensitive species names are enforced. More... | |
void | setCaseSensitiveSpecies (bool cflag=true) |
Set flag that determines whether case sensitive species are enforced in look-up operations, e.g. More... | |
virtual void | setRoot (std::shared_ptr< Solution > root) |
Set root Solution holding all phase information. More... | |
vector_fp | getCompositionFromMap (const compositionMap &comp) const |
Converts a compositionMap to a vector with entries for each species Species that are not specified are set to zero in the vector. More... | |
void | massFractionsToMoleFractions (const double *Y, double *X) const |
Converts a mixture composition from mole fractions to mass fractions. More... | |
void | moleFractionsToMassFractions (const double *X, double *Y) const |
Converts a mixture composition from mass fractions to mole fractions. More... | |
Name | |
Class Phase uses the string name to identify a phase. The name is the value of the corresponding key in the phase map (in YAML), name (in CTI), or id (in XML) that is used to initialize a phase when it is read. However, the name field may be changed to another value during the course of a calculation. For example, if duplicates of a phase object are instantiated and used in multiple places (e.g. a ReactorNet), they will have the same constitutive input, i.e. the names of the phases will be the same. Note that this is not a problem for Cantera internally; however, a user may want to rename phase objects in order to clarify. | |
std::string | id () const |
Return the string id for the phase. More... | |
void | setID (const std::string &id) |
Set the string id for the phase. More... | |
std::string | name () const |
Return the name of the phase. More... | |
void | setName (const std::string &nm) |
Sets the string name for the phase. More... | |
virtual std::string | type () const |
String indicating the thermodynamic model implemented. More... | |
Element and Species Information | |
std::string | elementName (size_t m) const |
Name of the element with index m. More... | |
size_t | elementIndex (const std::string &name) const |
Return the index of element named 'name'. More... | |
const std::vector< std::string > & | elementNames () const |
Return a read-only reference to the vector of element names. More... | |
doublereal | atomicWeight (size_t m) const |
Atomic weight of element m. More... | |
doublereal | entropyElement298 (size_t m) const |
Entropy of the element in its standard state at 298 K and 1 bar. More... | |
int | atomicNumber (size_t m) const |
Atomic number of element m. More... | |
int | elementType (size_t m) const |
Return the element constraint type Possible types include: More... | |
int | changeElementType (int m, int elem_type) |
Change the element type of the mth constraint Reassigns an element type. More... | |
const vector_fp & | atomicWeights () const |
Return a read-only reference to the vector of atomic weights. More... | |
size_t | nElements () const |
Number of elements. More... | |
void | checkElementIndex (size_t m) const |
Check that the specified element index is in range. More... | |
void | checkElementArraySize (size_t mm) const |
Check that an array size is at least nElements(). More... | |
doublereal | nAtoms (size_t k, size_t m) const |
Number of atoms of element m in species k . More... | |
void | getAtoms (size_t k, double *atomArray) const |
Get a vector containing the atomic composition of species k. More... | |
size_t | speciesIndex (const std::string &name) const |
Returns the index of a species named 'name' within the Phase object. More... | |
std::string | speciesName (size_t k) const |
Name of the species with index k. More... | |
std::string | speciesSPName (int k) const |
Returns the expanded species name of a species, including the phase name This is guaranteed to be unique within a Cantera problem. More... | |
const std::vector< std::string > & | speciesNames () const |
Return a const reference to the vector of species names. More... | |
size_t | nSpecies () const |
Returns the number of species in the phase. More... | |
void | checkSpeciesIndex (size_t k) const |
Check that the specified species index is in range. More... | |
void | checkSpeciesArraySize (size_t kk) const |
Check that an array size is at least nSpecies(). More... | |
Set thermodynamic state | |
Set the internal thermodynamic state by setting the internally stored temperature, density and species composition. Note that the composition is always set first. Temperature and density are held constant if not explicitly set. | |
void | setMoleFractionsByName (const compositionMap &xMap) |
Set the species mole fractions by name. More... | |
void | setMoleFractionsByName (const std::string &x) |
Set the mole fractions of a group of species by name. More... | |
void | setMassFractionsByName (const compositionMap &yMap) |
Set the species mass fractions by name. More... | |
void | setMassFractionsByName (const std::string &x) |
Set the species mass fractions by name. More... | |
void | setState_TRX (doublereal t, doublereal dens, const doublereal *x) |
Set the internally stored temperature (K), density, and mole fractions. More... | |
void | setState_TRX (doublereal t, doublereal dens, const compositionMap &x) |
Set the internally stored temperature (K), density, and mole fractions. More... | |
void | setState_TRY (doublereal t, doublereal dens, const doublereal *y) |
Set the internally stored temperature (K), density, and mass fractions. More... | |
void | setState_TRY (doublereal t, doublereal dens, const compositionMap &y) |
Set the internally stored temperature (K), density, and mass fractions. More... | |
void | setState_TNX (doublereal t, doublereal n, const doublereal *x) |
Set the internally stored temperature (K), molar density (kmol/m^3), and mole fractions. More... | |
void | setState_TR (doublereal t, doublereal rho) |
Set the internally stored temperature (K) and density (kg/m^3) More... | |
void | setState_TX (doublereal t, doublereal *x) |
Set the internally stored temperature (K) and mole fractions. More... | |
void | setState_TY (doublereal t, doublereal *y) |
Set the internally stored temperature (K) and mass fractions. More... | |
void | setState_RX (doublereal rho, doublereal *x) |
Set the density (kg/m^3) and mole fractions. More... | |
void | setState_RY (doublereal rho, doublereal *y) |
Set the density (kg/m^3) and mass fractions. More... | |
Composition | |
compositionMap | getMoleFractionsByName (double threshold=0.0) const |
Get the mole fractions by name. More... | |
double | moleFraction (size_t k) const |
Return the mole fraction of a single species. More... | |
double | moleFraction (const std::string &name) const |
Return the mole fraction of a single species. More... | |
compositionMap | getMassFractionsByName (double threshold=0.0) const |
Get the mass fractions by name. More... | |
double | massFraction (size_t k) const |
Return the mass fraction of a single species. More... | |
double | massFraction (const std::string &name) const |
Return the mass fraction of a single species. More... | |
void | getMoleFractions (double *const x) const |
Get the species mole fraction vector. More... | |
virtual void | setMoleFractions (const double *const x) |
Set the mole fractions to the specified values. More... | |
virtual void | setMoleFractions_NoNorm (const double *const x) |
Set the mole fractions to the specified values without normalizing. More... | |
void | getMassFractions (double *const y) const |
Get the species mass fractions. More... | |
const double * | massFractions () const |
Return a const pointer to the mass fraction array. More... | |
virtual void | setMassFractions (const double *const y) |
Set the mass fractions to the specified values and normalize them. More... | |
virtual void | setMassFractions_NoNorm (const double *const y) |
Set the mass fractions to the specified values without normalizing. More... | |
void | getConcentrations (double *const c) const |
Get the species concentrations (kmol/m^3). More... | |
double | concentration (const size_t k) const |
Concentration of species k. More... | |
virtual void | setConcentrations (const double *const conc) |
Set the concentrations to the specified values within the phase. More... | |
virtual void | setConcentrationsNoNorm (const double *const conc) |
Set the concentrations without ignoring negative concentrations. More... | |
doublereal | elementalMassFraction (const size_t m) const |
Elemental mass fraction of element m. More... | |
doublereal | elementalMoleFraction (const size_t m) const |
Elemental mole fraction of element m. More... | |
const double * | moleFractdivMMW () const |
Returns a const pointer to the start of the moleFraction/MW array. More... | |
doublereal | charge (size_t k) const |
Dimensionless electrical charge of a single molecule of species k The charge is normalized by the the magnitude of the electron charge. More... | |
doublereal | chargeDensity () const |
Charge density [C/m^3]. More... | |
size_t | nDim () const |
Returns the number of spatial dimensions (1, 2, or 3) More... | |
void | setNDim (size_t ndim) |
Set the number of spatial dimensions (1, 2, or 3). More... | |
Thermodynamic Properties | |
doublereal | temperature () const |
Temperature (K). More... | |
virtual double | pressure () const |
Return the thermodynamic pressure (Pa). More... | |
virtual double | density () const |
Density (kg/m^3). More... | |
double | molarDensity () const |
Molar density (kmol/m^3). More... | |
double | molarVolume () const |
Molar volume (m^3/kmol). More... | |
virtual void | setDensity (const double density_) |
Set the internally stored density (kg/m^3) of the phase. More... | |
virtual void | setMolarDensity (const double molarDensity) |
Set the internally stored molar density (kmol/m^3) of the phase. More... | |
virtual void | setPressure (double p) |
Set the internally stored pressure (Pa) at constant temperature and composition. More... | |
virtual void | setTemperature (const doublereal temp) |
Set the internally stored temperature of the phase (K). More... | |
Mean Properties | |
doublereal | mean_X (const doublereal *const Q) const |
Evaluate the mole-fraction-weighted mean of an array Q. More... | |
doublereal | mean_X (const vector_fp &Q) const |
Evaluate the mole-fraction-weighted mean of an array Q. More... | |
doublereal | meanMolecularWeight () const |
The mean molecular weight. Units: (kg/kmol) More... | |
doublereal | sum_xlogx () const |
Evaluate \( \sum_k X_k \log X_k \). More... | |
Adding Elements and Species | |
These methods are used to add new elements or species. These are not usually called by user programs. Since species are checked to insure that they are only composed of declared elements, it is necessary to first add all elements before adding any species. | |
size_t | addElement (const std::string &symbol, doublereal weight=-12345.0, int atomicNumber=0, doublereal entropy298=ENTROPY298_UNKNOWN, int elem_type=CT_ELEM_TYPE_ABSPOS) |
Add an element. More... | |
virtual bool | addSpecies (shared_ptr< Species > spec) |
Add a Species to this Phase. More... | |
virtual void | modifySpecies (size_t k, shared_ptr< Species > spec) |
Modify the thermodynamic data associated with a species. More... | |
void | addSpeciesAlias (const std::string &name, const std::string &alias) |
Add a species alias (i.e. More... | |
virtual std::vector< std::string > | findIsomers (const compositionMap &compMap) const |
Return a vector with isomers names matching a given composition map. More... | |
virtual std::vector< std::string > | findIsomers (const std::string &comp) const |
Return a vector with isomers names matching a given composition string. More... | |
shared_ptr< Species > | species (const std::string &name) const |
Return the Species object for the named species. More... | |
shared_ptr< Species > | species (size_t k) const |
Return the Species object for species whose index is k. More... | |
void | ignoreUndefinedElements () |
Set behavior when adding a species containing undefined elements to just skip the species. More... | |
void | addUndefinedElements () |
Set behavior when adding a species containing undefined elements to add those elements to the phase. More... | |
void | throwUndefinedElements () |
Set the behavior when adding a species containing undefined elements to throw an exception. More... | |
Protected Member Functions | |
void | assertCompressible (const std::string &setter) const |
Ensure that phase is compressible. More... | |
void | assignDensity (const double density_) |
Set the internally stored constant density (kg/m^3) of the phase. More... | |
void | setMolecularWeight (const int k, const double mw) |
Set the molecular weight of a single species to a given value. More... | |
virtual void | compositionChanged () |
Apply changes to the state which are needed after the composition changes. More... | |
Protected Attributes | |
ValueCache | m_cache |
Cached for saved calculations within each ThermoPhase. More... | |
size_t | m_kk |
Number of species in the phase. More... | |
size_t | m_ndim |
Dimensionality of the phase. More... | |
vector_fp | m_speciesComp |
Atomic composition of the species. More... | |
vector_fp | m_speciesCharge |
Vector of species charges. length m_kk. More... | |
std::map< std::string, shared_ptr< Species > > | m_species |
UndefElement::behavior | m_undefinedElementBehavior |
Flag determining behavior when adding species with an undefined element. More... | |
bool | m_caseSensitiveSpecies |
Flag determining whether case sensitive species names are enforced. More... | |
Private Member Functions | |
size_t | findSpeciesLower (const std::string &nameStr) const |
Find lowercase species name in m_speciesIndices when case sensitive species names are not enforced and a user specifies a non-canonical species name. More... | |
Private Attributes | |
XML_Node * | m_xml |
XML node containing the XML info for this phase. More... | |
std::string | m_id |
ID of the phase. More... | |
std::string | m_name |
Name of the phase. More... | |
doublereal | m_temp |
Temperature (K). This is an independent variable. More... | |
doublereal | m_dens |
Density (kg m-3). More... | |
doublereal | m_mmw |
mean molecular weight of the mixture (kg kmol-1) More... | |
vector_fp | m_ym |
m_ym[k] = mole fraction of species k divided by the mean molecular weight of mixture. More... | |
vector_fp | m_y |
Mass fractions of the species. More... | |
vector_fp | m_molwts |
species molecular weights (kg kmol-1) More... | |
vector_fp | m_rmolwts |
inverse of species molecular weights (kmol kg-1) More... | |
int | m_stateNum |
State Change variable. More... | |
std::vector< std::string > | m_speciesNames |
Vector of the species names. More... | |
std::map< std::string, size_t > | m_speciesIndices |
Map of species names to indices. More... | |
std::map< std::string, size_t > | m_speciesLower |
Map of lower-case species names to indices. More... | |
size_t | m_mm |
Number of elements. More... | |
vector_fp | m_atomicWeights |
element atomic weights (kg kmol-1) More... | |
vector_int | m_atomicNumbers |
element atomic numbers More... | |
std::vector< std::string > | m_elementNames |
element names More... | |
vector_int | m_elem_type |
Vector of element types. More... | |
vector_fp | m_entropy298 |
Entropy at 298.15 K and 1 bar of stable state pure elements (J kmol-1) More... | |
std::weak_ptr< Solution > | m_root |
reference to Solution More... | |
Class Phase is the base class for phases of matter, managing the species and elements in a phase, as well as the independent variables of temperature, mass density (compressible substances) or pressure (incompressible substances), species mass/mole fraction, and other generalized forces and intrinsic properties (such as electric potential) that define the thermodynamic state.
Class Phase provides information about the elements and species in a phase - names, index numbers (location in arrays), atomic or molecular weights, etc. The set of elements must include all those that compose the species, but may include additional elements.
It also stores an array of species molecular weights, which are used to convert between mole and mass representations of the composition. For efficiency in mass/mole conversion, the vector of mass fractions divided by molecular weight \( Y_k/M_k \) is also stored.
Class Phase is not usually used directly. Its primary use is as a base class for class ThermoPhase. It is not generally necessary to overloaded any of class Phase's methods, which handles both compressible and incompressible phases. For incompressible phases, the density is replaced by the pressure as the independent variable, and can no longer be set directly. In this case, the density needs to be calculated from a suitable equation of state, and assigned to the object using the assignDensity() method. This also applies for nearly-incompressible phases or phases which utilize standard states based on a T and P, in which case they need to overload these functions too.
Class Phase contains a number of utility functions that will set the state of the phase in its entirety, by first setting the composition, then the temperature and then density (or pressure for incompressible substances) An example of this is the function Phase::setState_TRY(double t, double dens, const double* y).
Class Phase contains methods for saving and restoring the full internal state of a given phase. These are saveState() and restoreState(). These functions operate on a state vector, which by default uses the first two entries for temperature and density (compressible substances) or temperature and pressure (incompressible substances). If the substance is not pure in a thermodynamic sense (that is, it may contain multiple species), the state also contains nSpecies() entries that specify the composition by corresponding mass fractions. Default definitions can be overloaded by derived classes. For any phase, the native definition of its thermodynamic state is defined the method nativeState(), with the length of the state vector returned by by stateSize(). In addition, methods isPure() and isCompressible() provide information on the implementation of a Phase object.
A species name is referred to via speciesName(), which is unique within a given phase. Note that within multiphase mixtures (MultiPhase()), both a phase name/index as well as species name are required to access information about a species in a particular phase. For surfaces, the species names are unique among the phases.
XML_Node & xml | ( | ) | const |
Returns a const reference to the XML_Node that describes the phase.
The XML_Node for the phase contains all of the input data used to set up the model for the phase during its initialization.
Definition at line 45 of file Phase.cpp.
References Phase::m_xml.
Referenced by TransportFactory::newTransport().
void setXMLdata | ( | XML_Node & | xmlPhase | ) |
Stores the XML tree information for the current phase.
This function now stores the complete XML_Node tree as read into the code via a file. This is needed to move around within the XML tree during construction of transport and kinetics mechanisms after copy construction operations.
xmlPhase | Reference to the XML node corresponding to the phase |
Definition at line 50 of file Phase.cpp.
References XML_Node::copy(), Cantera::findXMLPhase(), XML_Node::id(), Phase::m_xml, and XML_Node::root().
Referenced by Cantera::importPhase().
std::string id | ( | ) | const |
Return the string id for the phase.
Definition at line 69 of file Phase.cpp.
References Phase::m_id, and Cantera::warn_deprecated().
Referenced by MultiPhase::phaseName(), and vcs_VolPhase::transferElementsFM().
void setID | ( | const std::string & | id | ) |
Set the string id for the phase.
id | String id of the phase |
Definition at line 76 of file Phase.cpp.
References Phase::m_id, Phase::m_name, and Cantera::warn_deprecated().
std::string name | ( | ) | const |
Return the name of the phase.
Names are unique within a Cantera problem.
Definition at line 84 of file Phase.cpp.
References Phase::m_name.
Referenced by MultiPhase::addPhase(), Phase::addSpeciesAlias(), Phase::assertCompressible(), Cantera::checkElectrochemReaction(), Phase::findSpeciesLower(), Cantera::importPhase(), BinarySolutionTabulatedThermo::initThermo(), Kinetics::kineticsSpeciesIndex(), Cantera::operator<<(), ThermoPhase::report(), MolalityVPSSTP::report(), PureFluidPhase::report(), vcs_MultiPhaseEquil::reportCSV(), LatticeSolidPhase::setLatticeStoichiometry(), Phase::setName(), PureFluidPhase::setSubstance(), Phase::species(), and VCS_SOLVE::VCS_SOLVE().
void setName | ( | const std::string & | nm | ) |
Sets the string name for the phase.
nm | String name of the phase |
Definition at line 89 of file Phase.cpp.
References Phase::m_id, Phase::m_name, and Phase::name().
Referenced by FixedChemPotSSTP::FixedChemPotSSTP(), Cantera::importPhase(), and Cantera::setupPhase().
|
inlinevirtual |
String indicating the thermodynamic model implemented.
Usually corresponds to the name of the derived class, less any suffixes such as "Phase", TP", "VPSS", etc.
Reimplemented in WaterSSTP, ThermoPhase, SurfPhase, StoichSubstance, SingleSpeciesTP, RedlichKwongMFTP, RedlichKisterVPSSTP, PureFluidPhase, MixtureFugacityTP, MetalPhase, MaskellSolidSolnPhase, MargulesVPSSTP, LatticeSolidPhase, LatticePhase, IonsFromNeutralVPSSTP, IdealSolnGasVPSS, IdealSolidSolnPhase, IdealMolalSoln, IdealGasPhase, HMWSoln, FixedChemPotSSTP, EdgePhase, DebyeHuckel, ConstDensityThermo, and BinarySolutionTabulatedThermo.
Definition at line 176 of file Phase.h.
Referenced by Phase::assertCompressible().
string elementName | ( | size_t | m | ) | const |
Name of the element with index m.
m | Element index. |
Definition at line 114 of file Phase.cpp.
References Phase::checkElementIndex(), and Phase::m_elementNames.
Referenced by MultiPhase::addPhase(), PDSS_HKFT::convertDGFormation(), Phase::elementIndex(), ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), MolalityVPSSTP::findCLMIndex(), ChemEquil::initialize(), ChemEquil::setInitialMoles(), and vcs_VolPhase::transferElementsFM().
size_t elementIndex | ( | const std::string & | name | ) | const |
Return the index of element named 'name'.
The index is an integer assigned to each element in the order it was added. Returns npos if the specified element is not found.
name | Name of the element |
Definition at line 120 of file Phase.cpp.
References Phase::elementName(), Phase::m_elementNames, Phase::m_mm, and Cantera::npos.
Referenced by Phase::addSpecies(), MultiPhase::init(), WaterSSTP::initThermo(), PDSS_HKFT::LookupGe(), ThermoPhase::o2Present(), and ThermoPhase::o2Required().
const vector< string > & elementNames | ( | ) | const |
Return a read-only reference to the vector of element names.
Definition at line 130 of file Phase.cpp.
References Phase::m_elementNames.
Referenced by IonsFromNeutralVPSSTP::initThermo().
doublereal atomicWeight | ( | size_t | m | ) | const |
Atomic weight of element m.
m | Element index |
Definition at line 135 of file Phase.cpp.
References Phase::m_atomicWeights.
Referenced by Phase::elementalMassFraction(), ChemEquil::initialize(), and WaterSSTP::initThermo().
doublereal entropyElement298 | ( | size_t | m | ) | const |
Entropy of the element in its standard state at 298 K and 1 bar.
If no entropy value was provided when the phase was constructed, returns the value ENTROPY298_UNKNOWN
.
m | Element index |
Definition at line 140 of file Phase.cpp.
References Phase::checkElementIndex(), and Phase::m_entropy298.
Referenced by PDSS_HKFT::LookupGe().
int atomicNumber | ( | size_t | m | ) | const |
Atomic number of element m.
m | Element index |
Definition at line 151 of file Phase.cpp.
References Phase::m_atomicNumbers.
Referenced by MultiPhase::addPhase().
int elementType | ( | size_t | m | ) | const |
Return the element constraint type Possible types include:
CT_ELEM_TYPE_TURNEDOFF -1
CT_ELEM_TYPE_ABSPOS 0
CT_ELEM_TYPE_ELECTRONCHARGE 1
CT_ELEM_TYPE_CHARGENEUTRALITY 2
CT_ELEM_TYPE_LATTICERATIO 3
CT_ELEM_TYPE_KINETICFROZEN 4
CT_ELEM_TYPE_SURFACECONSTRAINT 5
CT_ELEM_TYPE_OTHERCONSTRAINT 6
The default is CT_ELEM_TYPE_ABSPOS
.
m | Element index |
Definition at line 156 of file Phase.cpp.
References Phase::m_elem_type.
Referenced by vcs_VolPhase::transferElementsFM().
int changeElementType | ( | int | m, |
int | elem_type | ||
) |
Change the element type of the mth constraint Reassigns an element type.
m | Element index |
elem_type | New elem type to be assigned |
Definition at line 161 of file Phase.cpp.
References Phase::m_elem_type.
const vector_fp & atomicWeights | ( | ) | const |
Return a read-only reference to the vector of atomic weights.
Definition at line 146 of file Phase.cpp.
References Phase::m_atomicWeights.
Referenced by Phase::addSpecies().
size_t nElements | ( | ) | const |
Number of elements.
Definition at line 95 of file Phase.cpp.
References Phase::m_mm.
Referenced by MultiPhase::addPhase(), Phase::addSpecies(), PDSS_HKFT::convertDGFormation(), Phase::elementalMoleFraction(), ChemEquil::equilibrate(), MolalityVPSSTP::findCLMIndex(), ChemEquil::initialize(), IonsFromNeutralVPSSTP::initThermo(), LatticeSolidPhase::setLatticeStoichiometry(), vcs_VolPhase::transferElementsFM(), and VCS_SOLVE::VCS_SOLVE().
void checkElementIndex | ( | size_t | m | ) | const |
Check that the specified element index is in range.
Throws an exception if m is greater than nElements()-1
Definition at line 100 of file Phase.cpp.
References Phase::m_mm.
Referenced by Phase::elementalMassFraction(), Phase::elementalMoleFraction(), Phase::elementName(), Phase::entropyElement298(), and Phase::nAtoms().
void checkElementArraySize | ( | size_t | mm | ) | const |
Check that an array size is at least nElements().
Throws an exception if mm is less than nElements(). Used before calls which take an array pointer.
Definition at line 107 of file Phase.cpp.
References Phase::m_mm.
doublereal nAtoms | ( | size_t | k, |
size_t | m | ||
) | const |
Number of atoms of element m
in species k
.
k | species index |
m | element index |
Definition at line 168 of file Phase.cpp.
References Phase::checkElementIndex(), Phase::checkSpeciesIndex(), Phase::m_mm, and Phase::m_speciesComp.
Referenced by PDSS_HKFT::convertDGFormation(), Phase::elementalMassFraction(), Phase::elementalMoleFraction(), MolalityVPSSTP::findCLMIndex(), MultiPhase::init(), ChemEquil::initialize(), IonsFromNeutralVPSSTP::initThermo(), ThermoPhase::o2Present(), ThermoPhase::o2Required(), and vcs_VolPhase::transferElementsFM().
void getAtoms | ( | size_t | k, |
double * | atomArray | ||
) | const |
Get a vector containing the atomic composition of species k.
k | species index |
atomArray | vector containing the atomic number in the species. Length: m_mm |
Definition at line 175 of file Phase.cpp.
References Phase::m_mm, and Phase::m_speciesComp.
size_t speciesIndex | ( | const std::string & | name | ) | const |
Returns the index of a species named 'name' within the Phase object.
The first species in the phase will have an index 0, and the last one will have an index of nSpecies() - 1.
name | String name of the species. It may also be in the form phaseName:speciesName |
Definition at line 201 of file Phase.cpp.
References Phase::findSpeciesLower(), Phase::m_caseSensitiveSpecies, Phase::m_id, Phase::m_name, Phase::m_speciesIndices, Cantera::npos, Cantera::parseSpeciesName(), and Cantera::warn_deprecated().
Referenced by RedlichKisterVPSSTP::addBinaryInteraction(), InterfaceKinetics::addReaction(), Phase::addSpeciesAlias(), InterfaceKinetics::buildSurfaceArrhenius(), Cantera::checkElectrochemReaction(), Phase::getCompositionFromMap(), BinarySolutionTabulatedThermo::initThermo(), RedlichKwongMFTP::initThermo(), RedlichKwongMFTP::initThermoXML(), BinarySolutionTabulatedThermo::initThermoXML(), FlowDevice::install(), Kinetics::kineticsSpeciesIndex(), Phase::massFraction(), Phase::moleFraction(), HMWSoln::readXMLBinarySalt(), RedlichKisterVPSSTP::readXMLBinarySpecies(), HMWSoln::readXMLLambdaNeutral(), HMWSoln::readXMLMunnnNeutral(), HMWSoln::readXMLPsi(), HMWSoln::readXMLTheta(), HMWSoln::readXMLZetaCation(), OutletRes1D::restore(), ReactingSurf1D::restore(), StFlow::restore(), DebyeHuckel::setBeta(), RedlichKwongMFTP::setBinaryCoeffs(), RedlichKwongMFTP::setSpeciesCoeffs(), Phase::species(), and Kinetics::speciesPhase().
string speciesName | ( | size_t | k | ) | const |
Name of the species with index k.
k | index of the species |
Definition at line 229 of file Phase.cpp.
References Phase::checkSpeciesIndex(), and Phase::m_speciesNames.
Referenced by ReactingSurf1D::componentName(), StFlow::componentName(), ChemEquil::estimateElementPotentials(), MolalityVPSSTP::findCLMIndex(), Phase::getMassFractionsByName(), Phase::getMoleFractionsByName(), MultiPhase::init(), ChemEquil::initialize(), PDSS_HKFT::initThermo(), StoichSubstance::initThermo(), RedlichKwongMFTP::initThermoXML(), FlowDevice::install(), Kinetics::kineticsSpeciesName(), Phase::modifySpecies(), ThermoPhase::modifySpecies(), HMWSoln::printCoeffs(), vcs_MultiPhaseEquil::reportCSV(), ThermoPhase::reportCSV(), StFlow::restore(), OutletRes1D::save(), ReactingSurf1D::save(), StFlow::save(), SurfPhase::setCoveragesByName(), ChemEquil::setInitialMoles(), MolalityVPSSTP::setMolalitiesByName(), Transport::setThermo(), ReactingSurf1D::showSolution(), Phase::species(), Phase::speciesSPName(), and ChemEquil::update().
std::string speciesSPName | ( | int | k | ) | const |
Returns the expanded species name of a species, including the phase name This is guaranteed to be unique within a Cantera problem.
k | Species index within the phase |
Definition at line 254 of file Phase.cpp.
References Phase::m_name, and Phase::speciesName().
const vector< string > & speciesNames | ( | ) | const |
Return a const reference to the vector of species names.
Definition at line 235 of file Phase.cpp.
References Phase::m_speciesNames.
Referenced by SurfPhase::setCoveragesByName(), and MolalityVPSSTP::setMolalitiesByName().
|
inline |
Returns the number of species in the phase.
Definition at line 285 of file Phase.h.
References Phase::m_kk.
Referenced by MultiPhase::addPhase(), InterfaceKinetics::applyVoltageKfwdCorrection(), MultiPhase::calcElemAbundances(), MultiPhaseEquil::computeReactionSteps(), MargulesVPSSTP::cp_mole(), MargulesVPSSTP::enthalpy_mole(), MargulesVPSSTP::entropy_mole(), ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), ThermoPhase::getActivities(), MetalPhase::getActivityConcentrations(), HighPressureGasTransport::getBinaryDiffCoeffs(), MetalPhase::getChemPotentials(), ImplicitSurfChem::getConcSpecies(), MolalityVPSSTP::getCsvReportData(), ThermoPhase::getCsvReportData(), MetalPhase::getEnthalpy_RT(), MetalPhase::getEntropy_R(), MultiTransport::getMassFluxes(), MultiTransport::getMolarFluxes(), MultiPhase::getMoles(), HighPressureGasTransport::getMultiDiffCoeffs(), MetalPhase::getPartialMolarEnthalpies(), MetalPhase::getStandardChemPotentials(), Cantera::hasChargedSpecies(), MultiPhase::init(), OutletRes1D::init(), IonGasTransport::init(), GasTransport::init(), ChemEquil::initialize(), DustyGasTransport::initialize(), IdealMolalSoln::initThermo(), BinarySolutionTabulatedThermo::initThermoXML(), FlowDevice::install(), vcs_MultiPhaseEquil::reportCSV(), ThermoPhase::reportCSV(), ThermoPhase::resetHf298(), StFlow::restore(), IonsFromNeutralVPSSTP::s_update_dlnActCoeff_dlnN(), Kinetics::selectPhase(), ImplicitSurfChem::setConcSpecies(), MultiPhase::setMoles(), MultiPhase::setPhaseMoleFractions(), Transport::setThermo(), ReactorBase::setThermoMgr(), solveSP::solveSP(), Phase::stateSize(), HighPressureGasTransport::thermalConductivity(), vcs_VolPhase::transferElementsFM(), MixTransport::update_T(), MultiTransport::update_T(), InterfaceKinetics::updateExchangeCurrentQuantities(), InterfaceKinetics::updateMu0(), MultiTransport::updateThermal_T(), MultiPhase::uploadMoleFractionsFromPhases(), VCS_SOLVE::vcs_prob_specifyFully(), VCS_SOLVE::VCS_SOLVE(), and HighPressureGasTransport::viscosity().
void checkSpeciesIndex | ( | size_t | k | ) | const |
Check that the specified species index is in range.
Throws an exception if k is greater than nSpecies()-1
Definition at line 240 of file Phase.cpp.
References Phase::m_kk.
Referenced by Phase::concentration(), Phase::massFraction(), Phase::molecularWeight(), Phase::moleFraction(), Phase::nAtoms(), Phase::species(), and Phase::speciesName().
void checkSpeciesArraySize | ( | size_t | kk | ) | const |
Check that an array size is at least nSpecies().
Throws an exception if kk is less than nSpecies(). Used before calls which take an array pointer.
Definition at line 247 of file Phase.cpp.
References Phase::m_kk.
|
inlinevirtual |
Return whether phase represents a pure (single species) substance.
Reimplemented in SingleSpeciesTP, and PureFluidPhase.
Definition at line 301 of file Phase.h.
Referenced by Phase::fullStates(), Phase::nativeState(), Phase::partialStates(), and Phase::stateSize().
|
inlinevirtual |
Return whether phase represents a substance with phase transitions.
Reimplemented in PureFluidPhase.
|
inlinevirtual |
Return whether phase represents a compressible substance.
Reimplemented in VPStandardStateTP, StoichSubstance, MetalPhase, LatticeSolidPhase, LatticePhase, IdealSolidSolnPhase, FixedChemPotSSTP, and ConstDensityThermo.
Definition at line 311 of file Phase.h.
Referenced by Phase::assertCompressible(), Phase::fullStates(), Phase::nativeState(), Phase::partialStates(), Phase::restoreState(), and Phase::saveState().
|
virtual |
Return a map of properties defining the native state of a substance.
By default, entries include "T", "D", "Y" for a compressible substance and "T", "P", "Y" for an incompressible substance, with offsets 0, 1 and 2, respectively. Mass fractions "Y" are omitted for pure species. In all cases, offsets into the state vector are used by saveState() and restoreState().
Reimplemented in LatticeSolidPhase, and LatticePhase.
Definition at line 259 of file Phase.cpp.
References Phase::isCompressible(), and Phase::isPure().
Referenced by Phase::restoreState(), and Phase::saveState().
|
virtual |
Return a vector containing full states defining a phase.
Full states list combinations of properties that allow for the specification of a thermodynamic state based on user input. Properties and states are represented by single letter acronyms, and combinations of letters, respectively (e.g. "TDY", "TPX", "SVX"). Supported property acronyms are: "T": temperature "P": pressure "D": density "X": mole fractions "Y": mass fractions "T": temperature "U": specific internal energy "V": specific volume "H": specific enthalpy "S": specific entropy "Q": vapor fraction
Reimplemented in PureFluidPhase.
Definition at line 276 of file Phase.cpp.
References Phase::isCompressible(), and Phase::isPure().
|
virtual |
Return a vector of settable partial property sets within a phase.
Partial states encompass all valid combinations of properties that allow for the specification of a state while ignoring species concentrations (e.g. "TD", "TP", "SV").
Reimplemented in PureFluidPhase.
Definition at line 294 of file Phase.cpp.
References Phase::isCompressible(), and Phase::isPure().
|
virtual |
Return size of vector defining internal state of the phase.
Used by saveState() and restoreState().
Definition at line 307 of file Phase.cpp.
References Phase::isPure(), and Phase::nSpecies().
Referenced by Phase::restoreState(), and Phase::saveState().
void saveState | ( | vector_fp & | state | ) | const |
Save the current internal state of the phase.
Write to vector 'state' the current internal state.
state | output vector. Will be resized to stateSize(). |
Definition at line 315 of file Phase.cpp.
References Phase::stateSize().
Referenced by ThermoPhase::equilibrate(), ChemEquil::equilibrate(), ChemEquil::estimateEP_Brinkley(), and TransportFactory::newTransport().
|
virtual |
Write to array 'state' the current internal state.
lenstate | length of the state array. Must be >= stateSize() |
state | output vector. Must be of length stateSizes() or greater. |
Definition at line 321 of file Phase.cpp.
References Phase::density(), Phase::getMassFractions(), Phase::getMoleFractions(), Phase::isCompressible(), Phase::nativeState(), Phase::pressure(), and Phase::temperature().
void restoreState | ( | const vector_fp & | state | ) |
Restore a state saved on a previous call to saveState.
state | State vector containing the previously saved state. |
Definition at line 339 of file Phase.cpp.
Referenced by ChemEquil::equilibrate(), MultiTransport::getMassFluxes(), TransportFactory::newTransport(), and ReactorBase::restoreState().
|
virtual |
Restore the state of the phase from a previously saved state vector.
lenstate | Length of the state vector |
state | Vector of state conditions. |
Definition at line 344 of file Phase.cpp.
References Phase::compositionChanged(), Phase::isCompressible(), Phase::nativeState(), Phase::setDensity(), Phase::setMassFractions_NoNorm(), Phase::setMoleFractions_NoNorm(), Phase::setPressure(), Phase::setTemperature(), and Phase::stateSize().
void setMoleFractionsByName | ( | const compositionMap & | xMap | ) |
Set the species mole fractions by name.
Species not listed by name in xMap
are set to zero.
xMap | map from species names to mole fraction values. |
Definition at line 409 of file Phase.cpp.
References Phase::getCompositionFromMap(), and Phase::setMoleFractions().
Referenced by OutletRes1D::setMoleFractions(), Phase::setMoleFractionsByName(), ThermoPhase::setState(), ThermoPhase::setState_RPX(), ThermoPhase::setState_TPX(), Phase::setState_TRX(), MixtureFugacityTP::setStateFromXML(), and ThermoPhase::setStateFromXML().
void setMoleFractionsByName | ( | const std::string & | x | ) |
Set the mole fractions of a group of species by name.
Species which are not listed by name in the composition map are set to zero.
x | string x in the form of a composition map |
Definition at line 415 of file Phase.cpp.
References Cantera::parseCompString(), and Phase::setMoleFractionsByName().
void setMassFractionsByName | ( | const compositionMap & | yMap | ) |
Set the species mass fractions by name.
Species not listed by name in yMap
are set to zero.
yMap | map from species names to mass fraction values. |
Definition at line 445 of file Phase.cpp.
References Phase::getCompositionFromMap(), and Phase::setMassFractions().
Referenced by Phase::setMassFractionsByName(), ThermoPhase::setState(), ThermoPhase::setState_RPY(), ThermoPhase::setState_TPY(), Phase::setState_TRY(), MixtureFugacityTP::setStateFromXML(), and ThermoPhase::setStateFromXML().
void setMassFractionsByName | ( | const std::string & | x | ) |
Set the species mass fractions by name.
Species not listed by name in x
are set to zero.
x | String containing a composition map |
Definition at line 451 of file Phase.cpp.
References Cantera::parseCompString(), and Phase::setMassFractionsByName().
void setState_TRX | ( | doublereal | t, |
doublereal | dens, | ||
const doublereal * | x | ||
) |
Set the internally stored temperature (K), density, and mole fractions.
t | Temperature in kelvin |
dens | Density (kg/m^3) |
x | vector of species mole fractions, length m_kk |
Definition at line 456 of file Phase.cpp.
References Phase::setDensity(), Phase::setMoleFractions(), and Phase::setTemperature().
void setState_TRX | ( | doublereal | t, |
doublereal | dens, | ||
const compositionMap & | x | ||
) |
Set the internally stored temperature (K), density, and mole fractions.
t | Temperature in kelvin |
dens | Density (kg/m^3) |
x | Composition Map containing the mole fractions. Species not included in the map are assumed to have a zero mole fraction. |
Definition at line 470 of file Phase.cpp.
References Phase::setDensity(), Phase::setMoleFractionsByName(), and Phase::setTemperature().
void setState_TRY | ( | doublereal | t, |
doublereal | dens, | ||
const doublereal * | y | ||
) |
Set the internally stored temperature (K), density, and mass fractions.
t | Temperature in kelvin |
dens | Density (kg/m^3) |
y | vector of species mass fractions, length m_kk |
Definition at line 477 of file Phase.cpp.
References Phase::setDensity(), Phase::setMassFractions(), and Phase::setTemperature().
void setState_TRY | ( | doublereal | t, |
doublereal | dens, | ||
const compositionMap & | y | ||
) |
Set the internally stored temperature (K), density, and mass fractions.
t | Temperature in kelvin |
dens | Density (kg/m^3) |
y | Composition Map containing the mass fractions. Species not included in the map are assumed to have a zero mass fraction. |
Definition at line 484 of file Phase.cpp.
References Phase::setDensity(), Phase::setMassFractionsByName(), and Phase::setTemperature().
void setState_TNX | ( | doublereal | t, |
doublereal | n, | ||
const doublereal * | x | ||
) |
Set the internally stored temperature (K), molar density (kmol/m^3), and mole fractions.
t | Temperature in kelvin |
n | molar density (kmol/m^3) |
x | vector of species mole fractions, length m_kk |
Definition at line 463 of file Phase.cpp.
References Phase::setMolarDensity(), Phase::setMoleFractions(), and Phase::setTemperature().
void setState_TR | ( | doublereal | t, |
doublereal | rho | ||
) |
Set the internally stored temperature (K) and density (kg/m^3)
t | Temperature in kelvin |
rho | Density (kg/m^3) |
Definition at line 491 of file Phase.cpp.
References Phase::setDensity(), and Phase::setTemperature().
Referenced by ThermoPhase::setState_TP().
void setState_TX | ( | doublereal | t, |
doublereal * | x | ||
) |
Set the internally stored temperature (K) and mole fractions.
t | Temperature in kelvin |
x | vector of species mole fractions, length m_kk |
Definition at line 497 of file Phase.cpp.
References Phase::setMoleFractions(), and Phase::setTemperature().
void setState_TY | ( | doublereal | t, |
doublereal * | y | ||
) |
Set the internally stored temperature (K) and mass fractions.
t | Temperature in kelvin |
y | vector of species mass fractions, length m_kk |
Definition at line 503 of file Phase.cpp.
References Phase::setMassFractions(), and Phase::setTemperature().
void setState_RX | ( | doublereal | rho, |
doublereal * | x | ||
) |
Set the density (kg/m^3) and mole fractions.
rho | Density (kg/m^3) |
x | vector of species mole fractions, length m_kk |
Definition at line 509 of file Phase.cpp.
References Phase::setDensity(), and Phase::setMoleFractions().
void setState_RY | ( | doublereal | rho, |
doublereal * | y | ||
) |
Set the density (kg/m^3) and mass fractions.
rho | Density (kg/m^3) |
y | vector of species mass fractions, length m_kk |
Definition at line 515 of file Phase.cpp.
References Phase::setDensity(), and Phase::setMassFractions().
doublereal molecularWeight | ( | size_t | k | ) | const |
Molecular weight of species k
.
k | index of species k |
k
. Definition at line 521 of file Phase.cpp.
References Phase::checkSpeciesIndex(), and Phase::m_molwts.
Referenced by IdealSolidSolnPhase::addSpecies(), LatticePhase::addSpecies(), MolalityVPSSTP::addSpecies(), InterfaceKinetics::buildSurfaceArrhenius(), Phase::elementalMassFraction(), SingleSpeciesTP::getPartialMolarVolumes(), SingleSpeciesTP::getStandardVolumes(), VPStandardStateTP::installPDSS(), and ConstDensityThermo::standardConcentration().
void getMolecularWeights | ( | vector_fp & | weights | ) | const |
Copy the vector of molecular weights into vector weights.
weights | Output vector of molecular weights (kg/kmol) |
Definition at line 527 of file Phase.cpp.
References Phase::molecularWeights().
void getMolecularWeights | ( | doublereal * | weights | ) | const |
Copy the vector of molecular weights into array weights.
weights | Output array of molecular weights (kg/kmol) |
Definition at line 532 of file Phase.cpp.
References Phase::molecularWeights().
const vector_fp & molecularWeights | ( | ) | const |
Return a const reference to the internal vector of molecular weights.
units = kg / kmol
Definition at line 538 of file Phase.cpp.
References Phase::m_molwts.
Referenced by ReactingSurf1D::eval(), Phase::getMolecularWeights(), MixTransport::getSpeciesFluxes(), DustyGasTransport::initialize(), ThermoPhase::o2Present(), and ThermoPhase::o2Required().
void getCharges | ( | double * | charges | ) | const |
Copy the vector of species charges into array charges.
charges | Output array of species charges (elem. charge) |
Definition at line 543 of file Phase.cpp.
References Phase::m_speciesCharge.
compositionMap getMoleFractionsByName | ( | double | threshold = 0.0 | ) | const |
Get the mole fractions by name.
threshold | Exclude species with mole fractions less than or equal to this threshold. |
Definition at line 548 of file Phase.cpp.
References Phase::m_kk, Phase::moleFraction(), and Phase::speciesName().
double moleFraction | ( | size_t | k | ) | const |
Return the mole fraction of a single species.
k | species index |
Definition at line 577 of file Phase.cpp.
References Phase::checkSpeciesIndex(), Phase::m_mmw, and Phase::m_ym.
Referenced by BinarySolutionTabulatedThermo::_updateThermo(), Phase::chargeDensity(), Phase::elementalMoleFraction(), SurfPhase::entropy_mole(), ChemEquil::equilibrate(), DebyeHuckel::getActivities(), HMWSoln::getActivities(), IdealMolalSoln::getActivities(), MolalityVPSSTP::getActivityCoefficients(), IdealSolnGasVPSS::getActivityConcentrations(), RedlichKwongMFTP::getActivityConcentrations(), ConstDensityThermo::getChemPotentials(), DebyeHuckel::getChemPotentials(), HMWSoln::getChemPotentials(), IdealGasPhase::getChemPotentials(), IdealMolalSoln::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials(), IdealSolnGasVPSS::getChemPotentials(), LatticePhase::getChemPotentials(), RedlichKwongMFTP::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials_RT(), IdealMolalSoln::getMolalityActivityCoefficients(), Phase::getMoleFractionsByName(), DebyeHuckel::getPartialMolarEntropies(), HMWSoln::getPartialMolarEntropies(), IdealGasPhase::getPartialMolarEntropies(), IdealMolalSoln::getPartialMolarEntropies(), IdealSolidSolnPhase::getPartialMolarEntropies(), IdealSolnGasVPSS::getPartialMolarEntropies(), LatticePhase::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarEntropies(), Phase::moleFraction(), vcs_MultiPhaseEquil::reportCSV(), DebyeHuckel::s_update_d2lnMolalityActCoeff_dT2(), DebyeHuckel::s_update_dlnMolalityActCoeff_dP(), DebyeHuckel::s_update_dlnMolalityActCoeff_dT(), DebyeHuckel::s_update_lnMolalityActCoeff(), HMWSoln::s_updateIMS_lnMolalityActCoeff(), IdealMolalSoln::s_updateIMS_lnMolalityActCoeff(), and ChemEquil::setInitialMoles().
double moleFraction | ( | const std::string & | name | ) | const |
Return the mole fraction of a single species.
name | String name of the species |
Definition at line 583 of file Phase.cpp.
References Phase::moleFraction(), Cantera::npos, and Phase::speciesIndex().
compositionMap getMassFractionsByName | ( | double | threshold = 0.0 | ) | const |
Get the mass fractions by name.
threshold | Exclude species with mass fractions less than or equal to this threshold. |
Definition at line 560 of file Phase.cpp.
References Phase::m_kk, Phase::massFraction(), and Phase::speciesName().
double massFraction | ( | size_t | k | ) | const |
Return the mass fraction of a single species.
k | species index |
Definition at line 598 of file Phase.cpp.
References Phase::checkSpeciesIndex(), and Phase::m_y.
Referenced by Phase::elementalMassFraction(), and Phase::getMassFractionsByName().
double massFraction | ( | const std::string & | name | ) | const |
Return the mass fraction of a single species.
name | String name of the species |
Definition at line 604 of file Phase.cpp.
References Phase::massFractions(), Cantera::npos, and Phase::speciesIndex().
void getMoleFractions | ( | double *const | x | ) | const |
Get the species mole fraction vector.
x | On return, x contains the mole fractions. Must have a length greater than or equal to the number of species. |
Definition at line 572 of file Phase.cpp.
References Phase::m_mmw, Phase::m_ym, and Cantera::scale().
Referenced by MolalityVPSSTP::calcMolalities(), HMWSoln::calcMolalitiesCropped(), MixtureFugacityTP::compositionChanged(), ChemEquil::estimateElementPotentials(), LatticePhase::getActivityConcentrations(), HighPressureGasTransport::getBinaryDiffCoeffs(), MolalityVPSSTP::getCsvReportData(), ThermoPhase::getCsvReportData(), MultiTransport::getMassFluxes(), LatticeSolidPhase::getMoleFractions(), HighPressureGasTransport::getMultiDiffCoeffs(), DustyGasTransport::initialize(), HMWSoln::printCoeffs(), HMWSoln::relative_molal_enthalpy(), ThermoPhase::reportCSV(), Phase::saveState(), MolalityVPSSTP::setMolalitiesByName(), MultiPhase::setMoles(), MixtureFugacityTP::setState_TP(), HighPressureGasTransport::thermalConductivity(), ChemEquil::update(), MixTransport::update_C(), MultiTransport::update_C(), solveSP::updateMFKinSpecies(), DustyGasTransport::updateTransport_C(), MultiPhase::uploadMoleFractionsFromPhases(), and HighPressureGasTransport::viscosity().
|
virtual |
Set the mole fractions to the specified values.
There is no restriction on the sum of the mole fraction vector. Internally, the Phase object will normalize this vector before storing its contents.
x | Array of unnormalized mole fraction values (input). Must have a length greater than or equal to the number of species, m_kk. |
Reimplemented in SingleSpeciesTP, and LatticeSolidPhase.
Definition at line 368 of file Phase.cpp.
References Phase::compositionChanged(), Phase::m_kk, Phase::m_mmw, Phase::m_molwts, Phase::m_y, and Phase::m_ym.
Referenced by ChemEquil::calcEmoles(), ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), MolalityVPSSTP::setMolalities(), MolalityVPSSTP::setMolalitiesByName(), OutletRes1D::setMoleFractions(), LatticeSolidPhase::setMoleFractions(), Phase::setMoleFractionsByName(), ThermoPhase::setState_PX(), ThermoPhase::setState_RPX(), Phase::setState_RX(), Phase::setState_TNX(), ThermoPhase::setState_TPX(), Phase::setState_TRX(), and Phase::setState_TX().
|
virtual |
Set the mole fractions to the specified values without normalizing.
This is useful when the normalization condition is being handled by some other means, for example by a constraint equation as part of a larger set of equations.
x | Input vector of mole fractions. Length is m_kk. |
Definition at line 400 of file Phase.cpp.
References Phase::compositionChanged(), Cantera::dot(), Phase::m_kk, Phase::m_mmw, Phase::m_molwts, Phase::m_y, Phase::m_ym, and Cantera::scale().
Referenced by Phase::restoreState().
void getMassFractions | ( | double *const | y | ) | const |
Get the species mass fractions.
[out] | y | Array of mass fractions, length nSpecies() |
Definition at line 614 of file Phase.cpp.
References Phase::m_y.
Referenced by StFlow::_getInitialSoln(), ThermoPhase::getCsvReportData(), StFlow::resetBadValues(), Phase::saveState(), and OutletRes1D::setMoleFractions().
|
inline |
Return a const pointer to the mass fraction array.
Definition at line 544 of file Phase.h.
References Phase::m_y.
Referenced by ThermoPhase::equivalenceRatio(), MultiTransport::getMassFluxes(), MixTransport::getSpeciesFluxes(), MultiTransport::getSpeciesFluxes(), and Phase::massFraction().
|
virtual |
Set the mass fractions to the specified values and normalize them.
[in] | y | Array of unnormalized mass fraction values. Length must be greater than or equal to the number of species. The Phase object will normalize this vector before storing its contents. |
Reimplemented in SingleSpeciesTP, and LatticeSolidPhase.
Definition at line 420 of file Phase.cpp.
References Phase::compositionChanged(), Phase::m_kk, Phase::m_mmw, Phase::m_rmolwts, Phase::m_y, Phase::m_ym, and Cantera::scale().
Referenced by StFlow::resetBadValues(), Phase::setMassFractionsByName(), ThermoPhase::setState_PY(), ThermoPhase::setState_RPY(), Phase::setState_RY(), ThermoPhase::setState_TPY(), Phase::setState_TRY(), and Phase::setState_TY().
|
virtual |
Set the mass fractions to the specified values without normalizing.
This is useful when the normalization condition is being handled by some other means, for example by a constraint equation as part of a larger set of equations.
y | Input vector of mass fractions. Length is m_kk. |
Reimplemented in LatticeSolidPhase.
Definition at line 434 of file Phase.cpp.
References Phase::compositionChanged(), Phase::m_kk, Phase::m_mmw, Phase::m_rmolwts, Phase::m_y, and Phase::m_ym.
Referenced by Phase::restoreState(), StFlow::setGas(), and StFlow::setGasAtMidpoint().
void getConcentrations | ( | double *const | c | ) | const |
Get the species concentrations (kmol/m^3).
[out] | c | The vector of species concentrations. Units are kmol/m^3. The length of the vector must be greater than or equal to the number of species within the phase. |
Definition at line 625 of file Phase.cpp.
References Phase::m_dens, Phase::m_ym, and Cantera::scale().
Referenced by InterfaceKinetics::_update_rates_C(), ConstDensityThermo::getActivityConcentrations(), IdealGasPhase::getActivityConcentrations(), IdealSolnGasVPSS::getActivityConcentrations(), SurfPhase::getActivityConcentrations(), ImplicitSurfChem::getConcSpecies(), and SurfPhase::getCoverages().
double concentration | ( | const size_t | k | ) | const |
Concentration of species k.
If k is outside the valid range, an exception will be thrown.
[in] | k | Index of the species within the phase. |
Definition at line 619 of file Phase.cpp.
References Phase::checkSpeciesIndex(), Phase::m_dens, Phase::m_rmolwts, and Phase::m_y.
Referenced by SurfPhase::entropy_mole().
|
virtual |
Set the concentrations to the specified values within the phase.
We set the concentrations here and therefore we set the overall density of the phase. We hold the temperature constant during this operation. Therefore, we have possibly changed the pressure of the phase by calling this routine.
[in] | conc | Array of concentrations in dimensional units. For bulk phases c[k] is the concentration of the kth species in kmol/m3. For surface phases, c[k] is the concentration in kmol/m2. The length of the vector is the number of species in the phase. |
Reimplemented in LatticeSolidPhase.
Definition at line 630 of file Phase.cpp.
References Phase::assertCompressible(), Phase::compositionChanged(), Phase::m_kk, Phase::m_mmw, Phase::m_molwts, Phase::m_y, Phase::m_ym, and Phase::setDensity().
Referenced by ImplicitSurfChem::setConcSpecies(), and SurfPhase::setCoverages().
|
virtual |
Set the concentrations without ignoring negative concentrations.
Definition at line 652 of file Phase.cpp.
References Phase::assertCompressible(), Phase::compositionChanged(), Phase::m_kk, Phase::m_mmw, Phase::m_molwts, Phase::m_y, Phase::m_ym, and Phase::setDensity().
Referenced by SurfPhase::setCoveragesNoNorm().
doublereal elementalMassFraction | ( | const size_t | m | ) | const |
Elemental mass fraction of element m.
The elemental mass fraction \(Z_{\mathrm{mass},m}\) of element \(m\) is defined as
\[ Z_{\mathrm{mass},m} = \sum_k \frac{a_{m,k} M_m}{M_k} Y_k \]
with \(a_{m,k}\) being the number of atoms of element \(m\) in species \(k\), \(M_m\) the atomic weight of element \(m\), \(M_k\) the molecular weight of species \(k\), and \(Y_k\) the mass fraction of species \(k\).
[in] | m | Index of the element within the phase. If m is outside the valid range, an exception will be thrown. |
Definition at line 671 of file Phase.cpp.
References Phase::atomicWeight(), Phase::checkElementIndex(), Phase::m_kk, Phase::massFraction(), Phase::molecularWeight(), and Phase::nAtoms().
doublereal elementalMoleFraction | ( | const size_t | m | ) | const |
Elemental mole fraction of element m.
The elemental mole fraction \(Z_{\mathrm{mole},m}\) of element \(m\) is the number of atoms of element m divided by the total number of atoms. It is defined as:
\[ Z_{\mathrm{mole},m} = \frac{\sum_k a_{m,k} X_k} {\sum_k \sum_j a_{j,k} X_k} \]
with \(a_{m,k}\) being the number of atoms of element \(m\) in species \(k\), \(\sum_j\) being a sum over all elements, and \(X_k\) being the mole fraction of species \(k\).
[in] | m | Index of the element within the phase. If m is outside the valid range, an exception will be thrown. |
Definition at line 682 of file Phase.cpp.
References Phase::checkElementIndex(), Phase::m_kk, Phase::moleFraction(), Phase::nAtoms(), and Phase::nElements().
const double * moleFractdivMMW | ( | ) | const |
Returns a const pointer to the start of the moleFraction/MW array.
This array is the array of mole fractions, each divided by the mean molecular weight.
Definition at line 593 of file Phase.cpp.
References Phase::m_ym.
Referenced by IdealSolidSolnPhase::calcDensity(), IdealSolnGasVPSS::calcDensity(), RedlichKwongMFTP::calcDensity(), and IdealSolidSolnPhase::getActivityConcentrations().
|
inline |
Dimensionless electrical charge of a single molecule of species k The charge is normalized by the the magnitude of the electron charge.
k | species index |
Definition at line 643 of file Phase.h.
References Phase::m_speciesCharge.
Referenced by RedlichKisterVPSSTP::addBinaryInteraction(), HMWSoln::applyphScale(), InterfaceKinetics::applyVoltageKfwdCorrection(), HMWSoln::calcMolalitiesCropped(), Phase::chargeDensity(), Cantera::checkElectrochemReaction(), ThermoPhase::getElectrochemPotentials(), Cantera::hasChargedSpecies(), PDSS_HKFT::initThermo(), HMWSoln::printCoeffs(), HMWSoln::relative_molal_enthalpy(), HMWSoln::s_updatePitzer_d2lnMolalityActCoeff_dT2(), HMWSoln::s_updatePitzer_dlnMolalityActCoeff_dP(), HMWSoln::s_updatePitzer_dlnMolalityActCoeff_dT(), HMWSoln::s_updatePitzer_lnMolalityActCoeff(), HMWSoln::s_updateScaling_pHScaling(), HMWSoln::s_updateScaling_pHScaling_dP(), HMWSoln::s_updateScaling_pHScaling_dT(), HMWSoln::s_updateScaling_pHScaling_dT2(), MolalityVPSSTP::setMolalitiesByName(), vcs_VolPhase::transferElementsFM(), and InterfaceKinetics::updateMu0().
doublereal chargeDensity | ( | ) | const |
Charge density [C/m^3].
Definition at line 737 of file Phase.cpp.
References Phase::charge(), Cantera::Faraday, Phase::m_kk, and Phase::moleFraction().
|
inline |
Returns the number of spatial dimensions (1, 2, or 3)
Definition at line 651 of file Phase.h.
References Phase::m_ndim.
Referenced by Kinetics::addPhase(), InterfaceKinetics::buildSurfaceArrhenius(), InterfaceKinetics::init(), IdealMolalSoln::standardConcentrationUnits(), IdealSolidSolnPhase::standardConcentrationUnits(), and ThermoPhase::standardConcentrationUnits().
|
inline |
Set the number of spatial dimensions (1, 2, or 3).
The number of spatial dimensions is used for vector involving directions.
ndim | Input number of dimensions. |
Definition at line 658 of file Phase.h.
References Phase::m_ndim.
Referenced by EdgePhase::EdgePhase(), FixedChemPotSSTP::FixedChemPotSSTP(), Cantera::importPhase(), and SurfPhase::SurfPhase().
|
inline |
Temperature (K).
Definition at line 667 of file Phase.h.
References Phase::m_temp.
Referenced by StFlow::_getInitialSoln(), MixtureFugacityTP::_updateReferenceStateThermo(), VPStandardStateTP::_updateStandardStateThermo(), BinarySolutionTabulatedThermo::_updateThermo(), ConstDensityThermo::_updateThermo(), IdealGasPhase::_updateThermo(), IdealSolidSolnPhase::_updateThermo(), LatticePhase::_updateThermo(), LatticeSolidPhase::_updateThermo(), SingleSpeciesTP::_updateThermo(), SurfPhase::_updateThermo(), MultiPhase::addPhase(), HMWSoln::calcDensity(), IonsFromNeutralVPSSTP::calcDensity(), MixtureFugacityTP::calculatePsat(), RedlichKwongMFTP::cp_mole(), RedlichKwongMFTP::cv_mole(), ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), RedlichKwongMFTP::getActivityCoefficients(), RedlichKwongMFTP::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials_RT(), PureFluidPhase::getEnthalpy_RT_ref(), PureFluidPhase::getEntropy_R_ref(), PureFluidPhase::getGibbs_RT_ref(), DebyeHuckel::getPartialMolarCp(), HMWSoln::getPartialMolarCp(), DebyeHuckel::getPartialMolarEnthalpies(), HMWSoln::getPartialMolarEnthalpies(), IonsFromNeutralVPSSTP::getPartialMolarEnthalpies(), MargulesVPSSTP::getPartialMolarEnthalpies(), RedlichKwongMFTP::getPartialMolarEnthalpies(), IonsFromNeutralVPSSTP::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarVolumes(), WaterSSTP::getStandardChemPotentials(), ThermoPhase::gibbs_mole(), PureFluidPhase::phaseOfMatter(), MixtureFugacityTP::phaseState(), IdealGasPhase::pressure(), MixTransport::pressure_ig(), RedlichKwongMFTP::pressureDerivatives(), ThermoPhase::RT(), HMWSoln::s_update_d2lnMolalityActCoeff_dT2(), MargulesVPSSTP::s_update_dlnActCoeff_dT(), HMWSoln::s_update_dlnMolalityActCoeff_dP(), HMWSoln::s_update_dlnMolalityActCoeff_dT(), HMWSoln::s_updatePitzer_dlnMolalityActCoeff_dP(), HMWSoln::satPressure(), WaterSSTP::satPressure(), Phase::saveState(), WaterSSTP::setDensity(), ChemEquil::setInitialMoles(), MixtureFugacityTP::setPressure(), VPStandardStateTP::setPressure(), vcs_VolPhase::setPtrThermoPhase(), SingleSpeciesTP::setState_HP(), ThermoPhase::setState_HPorUV(), SingleSpeciesTP::setState_SP(), ThermoPhase::setState_SPorSV(), SingleSpeciesTP::setState_SV(), ThermoPhase::setState_TP(), SingleSpeciesTP::setState_UV(), MixtureFugacityTP::setStateFromXML(), MixtureFugacityTP::setTemperature(), ImplicitSurfChem::solvePseudoSteadyStateProblem(), HighPressureGasTransport::thermalConductivity(), WaterTransport::thermalConductivity(), IdealGasPhase::thermalExpansionCoeff(), ChemEquil::update(), MixTransport::update_T(), MultiTransport::update_T(), RedlichKwongMFTP::updateAB(), VPStandardStateTP::updateStandardStateThermo(), MultiTransport::updateThermal_T(), DustyGasTransport::updateTransport_T(), WaterSSTP::vaporFraction(), HighPressureGasTransport::viscosity(), and WaterTransport::viscosity().
|
inlinevirtual |
Return the thermodynamic pressure (Pa).
This method must be overloaded in derived classes. Within Cantera, the independent variable is either density or pressure. If the state is defined by temperature, density, and mass fractions, this method should use these values to implement the mechanical equation of state \( P(T, \rho, Y_1, \dots, Y_K) \). Alternatively, it returns a stored value.
Reimplemented in WaterSSTP, VPStandardStateTP, SurfPhase, StoichSubstance, RedlichKwongMFTP, PureFluidPhase, MetalPhase, MaskellSolidSolnPhase, LatticeSolidPhase, LatticePhase, IdealSolidSolnPhase, IdealGasPhase, FixedChemPotSSTP, and ConstDensityThermo.
Definition at line 679 of file Phase.h.
Referenced by MultiPhase::addPhase(), ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), HighPressureGasTransport::getBinaryDiffCoeffs(), MixtureFugacityTP::getEntropy_R(), MixtureFugacityTP::getGibbs_RT(), MultiTransport::getMassFluxes(), HighPressureGasTransport::getMultiDiffCoeffs(), MixtureFugacityTP::getPureGibbs(), MixtureFugacityTP::getStandardChemPotentials(), MixtureFugacityTP::getStandardVolumes(), ThermoPhase::intEnergy_mole(), Phase::saveState(), ThermoPhase::setEquivalenceRatio(), ChemEquil::setInitialMoles(), ImplicitSurfChem::solvePseudoSteadyStateProblem(), and MixtureFugacityTP::z().
|
inlinevirtual |
Density (kg/m^3).
Definition at line 685 of file Phase.h.
References Phase::m_dens.
Referenced by MixtureFugacityTP::calculatePsat(), WaterSSTP::dthermalExpansionCoeffdT(), ChemEquil::equilibrate(), MultiTransport::getMassFluxes(), UnityLewisTransport::getMixDiffCoeffs(), UnityLewisTransport::getMixDiffCoeffsMass(), ConstDensityThermo::getParameters(), StoichSubstance::getParameters(), SingleSpeciesTP::getPartialMolarVolumes(), MultiTransport::getSpeciesFluxes(), SingleSpeciesTP::getStandardVolumes(), RedlichKwongMFTP::hresid(), Phase::molarDensity(), WaterSSTP::satPressure(), Phase::saveState(), DebyeHuckel::setDensity(), HMWSoln::setDensity(), IdealMolalSoln::setDensity(), IdealSolidSolnPhase::setDensity(), ThermoPhase::setState_TP(), MixtureFugacityTP::setStateFromXML(), MixtureFugacityTP::setTemperature(), WaterSSTP::setTemperature(), RedlichKwongMFTP::sresid(), ConstDensityThermo::standardConcentration(), WaterTransport::thermalConductivity(), ChemEquil::update(), StFlow::updateThermo(), StFlow::updateTransport(), WaterSSTP::vaporFraction(), WaterTransport::viscosity(), and MixtureFugacityTP::z().
double molarDensity | ( | ) | const |
Molar density (kmol/m^3).
Definition at line 700 of file Phase.cpp.
References Phase::density(), and Phase::meanMolecularWeight().
Referenced by solveSP::calc_t(), ConstDensityThermo::enthalpy_mole(), IdealSolidSolnPhase::enthalpy_mole(), LatticePhase::enthalpy_mole(), ConstDensityThermo::getChemPotentials(), StoichSubstance::getEnthalpy_RT(), StoichSubstance::getIntEnergy_RT(), StoichSubstance::getIntEnergy_RT_ref(), IdealGasPhase::getPartialMolarVolumes(), PureFluidPhase::getPartialMolarVolumes(), MixTransport::getSpeciesFluxes(), IdealGasPhase::getStandardVolumes(), Phase::molarVolume(), IdealGasPhase::pressure(), MixTransport::pressure_ig(), DebyeHuckel::setMolarDensity(), IdealMolalSoln::setMolarDensity(), and GasKinetics::update_rates_C().
double molarVolume | ( | ) | const |
Molar volume (m^3/kmol).
Definition at line 711 of file Phase.cpp.
References Phase::molarDensity().
Referenced by RedlichKwongMFTP::cp_mole(), RedlichKwongMFTP::cv_mole(), RedlichKwongMFTP::getActivityCoefficients(), RedlichKwongMFTP::getChemPotentials(), RedlichKwongMFTP::getPartialMolarEnthalpies(), RedlichKwongMFTP::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarVolumes(), ThermoPhase::intEnergy_mole(), and RedlichKwongMFTP::pressureDerivatives().
|
virtual |
Set the internally stored density (kg/m^3) of the phase.
Note the density of a phase is an independent variable.
[in] | density_ | density (kg/m^3). |
Reimplemented in MaskellSolidSolnPhase, IdealSolidSolnPhase, IdealMolalSoln, HMWSoln, DebyeHuckel, WaterSSTP, and PureFluidPhase.
Definition at line 716 of file Phase.cpp.
References Phase::assertCompressible(), and Phase::m_dens.
Referenced by RedlichKwongMFTP::calcDensity(), Phase::restoreState(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), PureFluidPhase::setDensity(), WaterSSTP::setDensity(), IdealGasPhase::setPressure(), ThermoPhase::setState_HPorUV(), IdealGasPhase::setState_RP(), Phase::setState_RX(), Phase::setState_RY(), ThermoPhase::setState_SPorSV(), SingleSpeciesTP::setState_SV(), Phase::setState_TR(), Phase::setState_TRX(), Phase::setState_TRY(), SingleSpeciesTP::setState_UV(), and ThermoPhase::setStateFromXML().
|
virtual |
Set the internally stored molar density (kmol/m^3) of the phase.
[in] | molarDensity | Input molar density (kmol/m^3). |
Reimplemented in MaskellSolidSolnPhase, IdealSolidSolnPhase, IdealMolalSoln, HMWSoln, and DebyeHuckel.
Definition at line 705 of file Phase.cpp.
References Phase::assertCompressible(), Phase::m_dens, and Phase::meanMolecularWeight().
Referenced by Phase::setState_TNX().
|
inlinevirtual |
Set the internally stored pressure (Pa) at constant temperature and composition.
This method must be reimplemented in derived classes, where it may involve the solution of a nonlinear equation. Within Cantera, the independent variable is either density or pressure. Therefore, this function may either solve for the density that will yield the desired input pressure or set an independent variable. The temperature and composition are held constant during this process.
p | input Pressure (Pa) |
Reimplemented in MetalPhase, WaterSSTP, VPStandardStateTP, SurfPhase, StoichSubstance, PureFluidPhase, MixtureFugacityTP, MaskellSolidSolnPhase, LatticeSolidPhase, LatticePhase, IdealSolnGasVPSS, IdealSolidSolnPhase, IdealGasPhase, FixedChemPotSSTP, and ConstDensityThermo.
Definition at line 718 of file Phase.h.
Referenced by ChemEquil::calcEmoles(), Phase::restoreState(), ThermoPhase::setState_conditional_TP(), SingleSpeciesTP::setState_HP(), ThermoPhase::setState_HPorUV(), ThermoPhase::setState_PX(), ThermoPhase::setState_PY(), SingleSpeciesTP::setState_SP(), ThermoPhase::setState_SPorSV(), ThermoPhase::setState_TP(), and ThermoPhase::setStateFromXML().
|
inlinevirtual |
Set the internally stored temperature of the phase (K).
temp | Temperature in Kelvin |
Reimplemented in WaterSSTP, VPStandardStateTP, RedlichKwongMFTP, MixtureFugacityTP, and PureFluidPhase.
Definition at line 724 of file Phase.h.
References Phase::m_temp.
Referenced by ChemEquil::equilibrate(), ReactingSurf1D::eval(), Phase::restoreState(), StFlow::setGas(), StFlow::setGasAtMidpoint(), ThermoPhase::setState_conditional_TP(), IdealGasPhase::setState_RP(), SingleSpeciesTP::setState_SV(), Phase::setState_TNX(), ThermoPhase::setState_TP(), MixtureFugacityTP::setState_TP(), VPStandardStateTP::setState_TP(), Phase::setState_TR(), Phase::setState_TRX(), Phase::setState_TRY(), Phase::setState_TX(), Phase::setState_TY(), SingleSpeciesTP::setState_UV(), SurfPhase::setStateFromXML(), ThermoPhase::setStateFromXML(), RedlichKwongMFTP::setTemperature(), WaterSSTP::setTemperature(), and ChemEquil::setToEquilState().
doublereal mean_X | ( | const doublereal *const | Q | ) | const |
Evaluate the mole-fraction-weighted mean of an array Q.
\[ \sum_k X_k Q_k. \]
Q should contain pure-species molar property values.
[in] | Q | Array of length m_kk that is to be averaged. |
Definition at line 746 of file Phase.cpp.
References Phase::m_mmw, and Phase::m_ym.
Referenced by DebyeHuckel::calcDensity(), HMWSoln::calcDensity(), IdealMolalSoln::calcDensity(), ConstDensityThermo::cp_mole(), DebyeHuckel::cp_mole(), HMWSoln::cp_mole(), IdealGasPhase::cp_mole(), IdealMolalSoln::cp_mole(), IdealSolidSolnPhase::cp_mole(), IdealSolnGasVPSS::cp_mole(), IonsFromNeutralVPSSTP::cp_mole(), LatticePhase::cp_mole(), RedlichKwongMFTP::cp_mole(), SurfPhase::cp_mole(), IonsFromNeutralVPSSTP::cv_mole(), RedlichKwongMFTP::cv_mole(), ConstDensityThermo::enthalpy_mole(), DebyeHuckel::enthalpy_mole(), HMWSoln::enthalpy_mole(), IdealGasPhase::enthalpy_mole(), IdealMolalSoln::enthalpy_mole(), IdealSolidSolnPhase::enthalpy_mole(), IdealSolnGasVPSS::enthalpy_mole(), IonsFromNeutralVPSSTP::enthalpy_mole(), LatticePhase::enthalpy_mole(), RedlichKwongMFTP::enthalpy_mole(), SurfPhase::enthalpy_mole(), ConstDensityThermo::entropy_mole(), DebyeHuckel::entropy_mole(), HMWSoln::entropy_mole(), IdealGasPhase::entropy_mole(), IdealMolalSoln::entropy_mole(), IdealSolidSolnPhase::entropy_mole(), IdealSolnGasVPSS::entropy_mole(), IonsFromNeutralVPSSTP::entropy_mole(), LatticePhase::entropy_mole(), RedlichKwongMFTP::entropy_mole(), DebyeHuckel::gibbs_mole(), HMWSoln::gibbs_mole(), IdealMolalSoln::gibbs_mole(), IdealSolidSolnPhase::gibbs_mole(), IonsFromNeutralVPSSTP::gibbs_mole(), IdealMolalSoln::intEnergy_mole(), and HMWSoln::relative_enthalpy().
doublereal mean_X | ( | const vector_fp & | Q | ) | const |
Evaluate the mole-fraction-weighted mean of an array Q.
\[ \sum_k X_k Q_k. \]
Q should contain pure-species molar property values.
[in] | Q | Array of length m_kk that is to be averaged. |
Definition at line 751 of file Phase.cpp.
References Phase::m_mmw, and Phase::m_ym.
|
inline |
The mean molecular weight. Units: (kg/kmol)
Definition at line 748 of file Phase.h.
References Phase::m_mmw.
Referenced by DebyeHuckel::calcDensity(), HMWSoln::calcDensity(), IdealMolalSoln::calcDensity(), IdealSolnGasVPSS::calcDensity(), LatticePhase::calcDensity(), MixtureFugacityTP::calculatePsat(), ThermoPhase::cp_mass(), RedlichKwongMFTP::critDensity(), ThermoPhase::cv_mass(), RedlichKwongMFTP::densityCalc(), MixtureFugacityTP::densityCalc(), ThermoPhase::enthalpy_mass(), ThermoPhase::entropy_mass(), IdealSolidSolnPhase::getActivityConcentrations(), HighPressureGasTransport::getMultiDiffCoeffs(), MultiTransport::getMultiDiffCoeffs(), ThermoPhase::gibbs_mass(), RedlichKwongMFTP::hresid(), StoichSubstance::initThermo(), ThermoPhase::intEnergy_mass(), Phase::molarDensity(), Phase::setMolarDensity(), IdealGasPhase::setPressure(), IdealGasPhase::setState_RP(), RedlichKwongMFTP::sresid(), StFlow::updateThermo(), StFlow::updateTransport(), HighPressureGasTransport::viscosity(), and MixtureFugacityTP::z().
doublereal sum_xlogx | ( | ) | const |
Evaluate \( \sum_k X_k \log X_k \).
Definition at line 756 of file Phase.cpp.
References Phase::m_kk, Phase::m_mmw, Phase::m_ym, and Cantera::SmallNumber.
Referenced by ConstDensityThermo::entropy_mole(), IdealGasPhase::entropy_mole(), IdealSolidSolnPhase::entropy_mole(), IdealSolnGasVPSS::entropy_mole(), LatticePhase::entropy_mole(), RedlichKwongMFTP::entropy_mole(), and IdealSolidSolnPhase::gibbs_mole().
size_t addElement | ( | const std::string & | symbol, |
doublereal | weight = -12345.0 , |
||
int | atomicNumber = 0 , |
||
doublereal | entropy298 = ENTROPY298_UNKNOWN , |
||
int | elem_type = CT_ELEM_TYPE_ABSPOS |
||
) |
Add an element.
symbol | Atomic symbol std::string. |
weight | Atomic mass in amu. |
atomicNumber | Atomic number of the element (unitless) |
entropy298 | Entropy of the element at 298 K and 1 bar in its most stable form. The default is the value ENTROPY298_UNKNOWN, which is interpreted as an unknown, and if used will cause Cantera to throw an error. |
elem_type | Specifies the type of the element constraint equation. This defaults to CT_ELEM_TYPE_ABSPOS, i.e., an element. |
Definition at line 765 of file Phase.cpp.
References XML_Node::child(), ENTROPY298_UNKNOWN, XML_Node::findByAttr(), Cantera::fpValueCheck(), Cantera::get_XML_File(), Cantera::getElementWeight(), and XML_Node::hasChild().
Referenced by LatticeSolidPhase::addLattice(), Phase::addSpecies(), FixedChemPotSSTP::FixedChemPotSSTP(), Cantera::installElements(), and LatticeSolidPhase::setLatticeStoichiometry().
|
virtual |
Returns true
if the species was successfully added, or false
if the species was ignored.
Derived classes which need to size arrays according to the number of species should overload this method. The derived class implementation should call the base class method, and, if this returns true
(indicating that the species has been added), adjust their array sizes accordingly.
Reimplemented in VPStandardStateTP, ThermoPhase, SurfPhase, SingleSpeciesTP, RedlichKwongMFTP, MolalityVPSSTP, MixtureFugacityTP, LatticeSolidPhase, LatticePhase, IonsFromNeutralVPSSTP, IdealSolnGasVPSS, IdealSolidSolnPhase, IdealMolalSoln, IdealGasPhase, GibbsExcessVPSSTP, DebyeHuckel, and ConstDensityThermo.
Definition at line 833 of file Phase.cpp.
References Phase::addElement(), Phase::atomicWeights(), CT_ELEM_TYPE_ELECTRONCHARGE, Phase::elementIndex(), Phase::invalidateCache(), Phase::m_kk, Phase::m_mmw, Phase::m_molwts, Phase::m_name, Phase::m_rmolwts, Phase::m_speciesCharge, Phase::m_speciesComp, Phase::m_speciesIndices, Phase::m_speciesLower, Phase::m_speciesNames, Phase::m_undefinedElementBehavior, Phase::m_y, Phase::m_ym, Phase::nElements(), Cantera::npos, Cantera::Tiny, and Cantera::toLowerCopy().
Referenced by ThermoPhase::addSpecies(), and VPStandardStateTP::addSpecies().
|
virtual |
Modify the thermodynamic data associated with a species.
The species name, elemental composition, and type of thermo parameterization must be unchanged. If there are Kinetics objects that depend on this phase, Kinetics::invalidateCache() should be called on those objects after calling this function.
Reimplemented in ThermoPhase.
Definition at line 929 of file Phase.cpp.
References Phase::invalidateCache(), and Phase::speciesName().
Referenced by ThermoPhase::modifySpecies().
void addSpeciesAlias | ( | const std::string & | name, |
const std::string & | alias | ||
) |
Add a species alias (i.e.
user-defined alternative species name). Aliases are case-sensitive.
name | original species name std::string. |
alias | alternate name std::string. |
true
if the alias was successfully added (i.e. the original species name is found) Definition at line 946 of file Phase.cpp.
References Phase::m_speciesIndices, Phase::name(), Cantera::npos, and Phase::speciesIndex().
|
virtual |
Return a vector with isomers names matching a given composition map.
compMap | compositionMap of the species. |
Definition at line 962 of file Phase.cpp.
Referenced by Phase::findIsomers().
|
virtual |
Return a vector with isomers names matching a given composition string.
comp | String containing a composition map |
Definition at line 975 of file Phase.cpp.
References Phase::findIsomers(), and Cantera::parseCompString().
shared_ptr< Species > species | ( | const std::string & | name | ) | const |
Return the Species object for the named species.
Changes to this object do not affect the ThermoPhase object until the modifySpecies function is called.
Definition at line 980 of file Phase.cpp.
References Phase::name(), Cantera::npos, Phase::speciesIndex(), and Phase::speciesName().
Referenced by DebyeHuckel::initThermo(), MargulesVPSSTP::initThermo(), RedlichKisterVPSSTP::initThermo(), StoichSubstance::initThermo(), VPStandardStateTP::installPDSS(), LatticePhase::setSiteDensity(), and RedlichKwongMFTP::setSpeciesCoeffs().
shared_ptr< Species > species | ( | size_t | k | ) | const |
Return the Species object for species whose index is k.
Changes to this object do not affect the ThermoPhase object until the modifySpecies function is called.
Definition at line 991 of file Phase.cpp.
References Phase::checkSpeciesIndex(), and Phase::m_speciesNames.
void ignoreUndefinedElements | ( | ) |
Set behavior when adding a species containing undefined elements to just skip the species.
Definition at line 997 of file Phase.cpp.
References Phase::m_undefinedElementBehavior.
Referenced by Cantera::importPhase(), and Cantera::setupPhase().
void addUndefinedElements | ( | ) |
Set behavior when adding a species containing undefined elements to add those elements to the phase.
This is the default behavior.
Definition at line 1001 of file Phase.cpp.
References Phase::m_undefinedElementBehavior.
void throwUndefinedElements | ( | ) |
Set the behavior when adding a species containing undefined elements to throw an exception.
Definition at line 1005 of file Phase.cpp.
References Phase::m_undefinedElementBehavior.
Referenced by Cantera::importPhase(), and Cantera::setupPhase().
|
virtual |
Returns a bool indicating whether the object is ready for use.
Reimplemented in PureFluid, Metal, Interface, IncompressibleSolid, IdealGasMix, and Edge.
Definition at line 1009 of file Phase.cpp.
References Phase::m_kk.
|
inline |
Return the State Mole Fraction Number.
Definition at line 856 of file Phase.h.
References Phase::m_stateNum.
Referenced by HMWSoln::calcDensity(), HMWSoln::s_update_d2lnMolalityActCoeff_dT2(), HMWSoln::s_update_dlnMolalityActCoeff_dP(), and HMWSoln::s_update_dlnMolalityActCoeff_dT().
|
virtual |
Invalidate any cached values which are normally updated only when a change in state is detected.
Reimplemented in VPStandardStateTP, ThermoPhase, and MixtureFugacityTP.
Definition at line 1014 of file Phase.cpp.
References ValueCache::clear(), and Phase::m_cache.
Referenced by Phase::addSpecies(), ThermoPhase::invalidateCache(), and Phase::modifySpecies().
|
inline |
Returns true
if case sensitive species names are enforced.
Definition at line 865 of file Phase.h.
References Phase::m_caseSensitiveSpecies.
|
inline |
Set flag that determines whether case sensitive species are enforced in look-up operations, e.g.
speciesIndex
Definition at line 871 of file Phase.h.
References Phase::m_caseSensitiveSpecies.
|
inlinevirtual |
Set root Solution holding all phase information.
Definition at line 876 of file Phase.h.
References Phase::m_root.
vector_fp getCompositionFromMap | ( | const compositionMap & | comp | ) | const |
Converts a compositionMap to a vector with entries for each species Species that are not specified are set to zero in the vector.
[in] | comp | compositionMap containing the mixture composition |
Definition at line 1032 of file Phase.cpp.
References Phase::m_kk, Cantera::npos, and Phase::speciesIndex().
Referenced by ThermoPhase::equivalenceRatio(), ThermoPhase::mixtureFraction(), ThermoPhase::setEquivalenceRatio(), Phase::setMassFractionsByName(), ThermoPhase::setMixtureFraction(), Phase::setMoleFractionsByName(), and ThermoPhase::stoichAirFuelRatio().
void massFractionsToMoleFractions | ( | const double * | Y, |
double * | X | ||
) | const |
Converts a mixture composition from mole fractions to mass fractions.
[in] | Y | mixture composition in mass fractions (length m_kk) |
[out] | X | mixture composition in mole fractions (length m_kk) |
Definition at line 1046 of file Phase.cpp.
References Phase::m_kk, and Phase::m_molwts.
void moleFractionsToMassFractions | ( | const double * | X, |
double * | Y | ||
) | const |
Converts a mixture composition from mass fractions to mole fractions.
[in] | X | mixture composition in mole fractions (length m_kk) |
[out] | Y | mixture composition in mass fractions (length m_kk) |
Definition at line 1061 of file Phase.cpp.
References Cantera::dot(), Phase::m_kk, and Phase::m_molwts.
|
inlineprotected |
Ensure that phase is compressible.
An error is raised if the state is incompressible
setter | name of setter (used for exception handling) |
Definition at line 902 of file Phase.h.
References Phase::isCompressible(), Phase::name(), and Phase::type().
Referenced by Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setDensity(), Phase::setMolarDensity(), ThermoPhase::setState_SV(), and ThermoPhase::setState_UV().
|
protected |
Set the internally stored constant density (kg/m^3) of the phase.
Used for incompressible phases where the density is not an independent variable, e.g. density does not affect pressure in state calculations.
[in] | density_ | density (kg/m^3). |
Definition at line 727 of file Phase.cpp.
References Phase::m_dens.
Referenced by DebyeHuckel::calcDensity(), HMWSoln::calcDensity(), IdealMolalSoln::calcDensity(), IdealSolidSolnPhase::calcDensity(), IdealSolnGasVPSS::calcDensity(), IonsFromNeutralVPSSTP::calcDensity(), LatticePhase::calcDensity(), LatticeSolidPhase::calcDensity(), ConstDensityThermo::initThermo(), MetalPhase::initThermo(), StoichSubstance::initThermo(), StoichSubstance::initThermoXML(), ConstDensityThermo::setParameters(), StoichSubstance::setParameters(), ConstDensityThermo::setParametersFromXML(), MetalPhase::setParametersFromXML(), and StoichSubstance::setParametersFromXML().
|
protected |
Set the molecular weight of a single species to a given value.
Used by phases where the equation of state is defined for a specific value of the molecular weight which may not exactly correspond to the value computed from the chemical formula.
k | id of the species |
mw | Molecular Weight (kg kmol-1) |
Definition at line 1018 of file Phase.cpp.
References Phase::m_mmw, Phase::m_molwts, Phase::m_rmolwts, Phase::m_y, and Phase::m_ym.
Referenced by WaterSSTP::initThermo().
|
protectedvirtual |
Apply changes to the state which are needed after the composition changes.
This function is called after any call to setMassFractions(), setMoleFractions(), or similar. For phases which need to execute a callback after any change to the composition, it should be done by overriding this function rather than overriding all of the composition- setting functions. Derived class implementations of compositionChanged() should call the parent class method as well.
Reimplemented in RedlichKwongMFTP, MixtureFugacityTP, LatticePhase, IonsFromNeutralVPSSTP, IdealSolidSolnPhase, GibbsExcessVPSSTP, and BinarySolutionTabulatedThermo.
Definition at line 1028 of file Phase.cpp.
References Phase::m_stateNum.
Referenced by IdealSolidSolnPhase::compositionChanged(), LatticePhase::compositionChanged(), MixtureFugacityTP::compositionChanged(), Phase::restoreState(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), Phase::setMoleFractions(), and Phase::setMoleFractions_NoNorm().
|
private |
Find lowercase species name in m_speciesIndices when case sensitive species names are not enforced and a user specifies a non-canonical species name.
Raise exception if lowercase name is not unique.
Definition at line 182 of file Phase.cpp.
References Phase::m_speciesLower, Phase::name(), Cantera::npos, and Cantera::toLowerCopy().
Referenced by Phase::speciesIndex().
|
mutableprotected |
Cached for saved calculations within each ThermoPhase.
For more information on how to use this, see examples within the source code and documentation for this within ValueCache class itself.
Definition at line 922 of file Phase.h.
Referenced by IdealGasPhase::_updateThermo(), HMWSoln::calcDensity(), Phase::invalidateCache(), HMWSoln::s_update_d2lnMolalityActCoeff_dT2(), HMWSoln::s_update_dlnMolalityActCoeff_dP(), and HMWSoln::s_update_dlnMolalityActCoeff_dT().
|
protected |
Number of species in the phase.
Definition at line 942 of file Phase.h.
Referenced by DebyeHuckel::_lnactivityWaterHelgesonFixedForm(), MixtureFugacityTP::_updateReferenceStateThermo(), VPStandardStateTP::_updateStandardStateThermo(), BinarySolutionTabulatedThermo::_updateThermo(), ConstDensityThermo::_updateThermo(), IdealGasPhase::_updateThermo(), IdealSolidSolnPhase::_updateThermo(), LatticePhase::_updateThermo(), SurfPhase::_updateThermo(), IdealGasPhase::addSpecies(), IdealSolidSolnPhase::addSpecies(), IonsFromNeutralVPSSTP::addSpecies(), LatticePhase::addSpecies(), MixtureFugacityTP::addSpecies(), MolalityVPSSTP::addSpecies(), Phase::addSpecies(), RedlichKwongMFTP::addSpecies(), SingleSpeciesTP::addSpecies(), SurfPhase::addSpecies(), ThermoPhase::addSpecies(), VPStandardStateTP::addSpecies(), HMWSoln::applyphScale(), IonsFromNeutralVPSSTP::calcIonMoleFractions(), MolalityVPSSTP::calcMolalities(), HMWSoln::calcMolalitiesCropped(), IonsFromNeutralVPSSTP::calcNeutralMoleculeMoleFractions(), RedlichKwongMFTP::calculateAB(), Phase::chargeDensity(), Phase::checkSpeciesArraySize(), Phase::checkSpeciesIndex(), HMWSoln::counterIJ_setup(), RedlichKisterVPSSTP::cp_mole(), RedlichKwongMFTP::critCompressibility(), RedlichKwongMFTP::critDensity(), RedlichKwongMFTP::critPressure(), RedlichKwongMFTP::critTemperature(), RedlichKwongMFTP::critVolume(), Phase::elementalMassFraction(), Phase::elementalMoleFraction(), RedlichKisterVPSSTP::enthalpy_mole(), RedlichKisterVPSSTP::entropy_mole(), SurfPhase::entropy_mole(), MolalityVPSSTP::findCLMIndex(), DebyeHuckel::getActivities(), HMWSoln::getActivities(), IdealMolalSoln::getActivities(), ConstDensityThermo::getActivityCoefficients(), IdealGasPhase::getActivityCoefficients(), IdealSolidSolnPhase::getActivityCoefficients(), IdealSolnGasVPSS::getActivityCoefficients(), IonsFromNeutralVPSSTP::getActivityCoefficients(), LatticePhase::getActivityCoefficients(), LatticeSolidPhase::getActivityCoefficients(), MolalityVPSSTP::getActivityCoefficients(), RedlichKwongMFTP::getActivityCoefficients(), ThermoPhase::getActivityCoefficients(), DebyeHuckel::getActivityConcentrations(), HMWSoln::getActivityConcentrations(), IdealMolalSoln::getActivityConcentrations(), IdealSolidSolnPhase::getActivityConcentrations(), IdealSolnGasVPSS::getActivityConcentrations(), RedlichKwongMFTP::getActivityConcentrations(), ConstDensityThermo::getChemPotentials(), DebyeHuckel::getChemPotentials(), HMWSoln::getChemPotentials(), IdealGasPhase::getChemPotentials(), IdealMolalSoln::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials(), IdealSolnGasVPSS::getChemPotentials(), LatticePhase::getChemPotentials(), MargulesVPSSTP::getChemPotentials(), RedlichKisterVPSSTP::getChemPotentials(), RedlichKwongMFTP::getChemPotentials(), SurfPhase::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials_RT(), MixtureFugacityTP::getChemPotentials_RT(), RedlichKwongMFTP::getChemPotentials_RT(), VPStandardStateTP::getChemPotentials_RT(), Phase::getCompositionFromMap(), SurfPhase::getCoverages(), IdealSolidSolnPhase::getCp_R_ref(), MargulesVPSSTP::getd2lnActCoeffdT2(), RedlichKisterVPSSTP::getd2lnActCoeffdT2(), IonsFromNeutralVPSSTP::getdlnActCoeffdlnN(), MargulesVPSSTP::getdlnActCoeffdlnN(), RedlichKisterVPSSTP::getdlnActCoeffdlnN(), ThermoPhase::getdlnActCoeffdlnN(), IonsFromNeutralVPSSTP::getdlnActCoeffdlnN_diag(), MargulesVPSSTP::getdlnActCoeffdlnN_diag(), RedlichKisterVPSSTP::getdlnActCoeffdlnN_diag(), IonsFromNeutralVPSSTP::getdlnActCoeffdlnX_diag(), MargulesVPSSTP::getdlnActCoeffdlnX_diag(), RedlichKisterVPSSTP::getdlnActCoeffdlnX_diag(), IonsFromNeutralVPSSTP::getdlnActCoeffds(), RedlichKisterVPSSTP::getdlnActCoeffds(), MargulesVPSSTP::getdlnActCoeffdT(), RedlichKisterVPSSTP::getdlnActCoeffdT(), ThermoPhase::getElectrochemPotentials(), IdealSolidSolnPhase::getEnthalpy_RT(), LatticePhase::getEnthalpy_RT(), IdealSolidSolnPhase::getEnthalpy_RT_ref(), IdealGasPhase::getEntropy_R(), MixtureFugacityTP::getEntropy_R(), IdealSolidSolnPhase::getEntropy_R_ref(), IdealSolidSolnPhase::getGibbs_ref(), LatticePhase::getGibbs_ref(), LatticeSolidPhase::getGibbs_ref(), VPStandardStateTP::getGibbs_ref(), WaterSSTP::getGibbs_ref(), IdealGasPhase::getGibbs_RT(), IdealSolidSolnPhase::getGibbs_RT(), LatticePhase::getGibbs_RT(), MixtureFugacityTP::getGibbs_RT(), IdealSolidSolnPhase::getGibbs_RT_ref(), LatticePhase::getGibbs_RT_ref(), IdealGasPhase::getIntEnergy_RT(), IdealSolidSolnPhase::getIntEnergy_RT(), MixtureFugacityTP::getIntEnergy_RT(), VPStandardStateTP::getIntEnergy_RT(), IdealGasPhase::getIntEnergy_RT_ref(), IdealSolidSolnPhase::getIntEnergy_RT_ref(), MargulesVPSSTP::getLnActivityCoefficients(), RedlichKisterVPSSTP::getLnActivityCoefficients(), ThermoPhase::getLnActivityCoefficients(), Phase::getMassFractionsByName(), MolalityVPSSTP::getMolalities(), DebyeHuckel::getMolalityActivityCoefficients(), IdealMolalSoln::getMolalityActivityCoefficients(), Phase::getMoleFractionsByName(), IonsFromNeutralVPSSTP::getNeutralMoleculeMoleGrads(), DebyeHuckel::getPartialMolarCp(), HMWSoln::getPartialMolarCp(), IdealMolalSoln::getPartialMolarCp(), IdealSolidSolnPhase::getPartialMolarCp(), IdealSolnGasVPSS::getPartialMolarCp(), LatticePhase::getPartialMolarCp(), RedlichKwongMFTP::getPartialMolarCp(), SurfPhase::getPartialMolarCp(), DebyeHuckel::getPartialMolarEnthalpies(), HMWSoln::getPartialMolarEnthalpies(), IdealMolalSoln::getPartialMolarEnthalpies(), IdealSolnGasVPSS::getPartialMolarEnthalpies(), IonsFromNeutralVPSSTP::getPartialMolarEnthalpies(), MargulesVPSSTP::getPartialMolarEnthalpies(), RedlichKwongMFTP::getPartialMolarEnthalpies(), SurfPhase::getPartialMolarEnthalpies(), DebyeHuckel::getPartialMolarEntropies(), HMWSoln::getPartialMolarEntropies(), IdealGasPhase::getPartialMolarEntropies(), IdealMolalSoln::getPartialMolarEntropies(), IdealSolidSolnPhase::getPartialMolarEntropies(), IdealSolnGasVPSS::getPartialMolarEntropies(), IonsFromNeutralVPSSTP::getPartialMolarEntropies(), LatticePhase::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarEntropies(), SurfPhase::getPartialMolarEntropies(), IdealGasPhase::getPartialMolarIntEnergies(), IdealSolnGasVPSS::getPartialMolarIntEnergies(), RedlichKwongMFTP::getPartialMolarIntEnergies(), DebyeHuckel::getPartialMolarVolumes(), HMWSoln::getPartialMolarVolumes(), IdealGasPhase::getPartialMolarVolumes(), RedlichKisterVPSSTP::getPartialMolarVolumes(), RedlichKwongMFTP::getPartialMolarVolumes(), IdealGasPhase::getPureGibbs(), IdealSolidSolnPhase::getPureGibbs(), LatticePhase::getPureGibbs(), MixtureFugacityTP::getPureGibbs(), VPStandardStateTP::getPureGibbs(), IdealGasPhase::getStandardChemPotentials(), MixtureFugacityTP::getStandardChemPotentials(), VPStandardStateTP::getStandardChemPotentials(), IdealGasPhase::getStandardVolumes(), MixtureFugacityTP::getStandardVolumes(), SurfPhase::getStandardVolumes(), IdealGasPhase::getStandardVolumes_ref(), MixtureFugacityTP::getStandardVolumes_ref(), HMWSoln::getUnscaledMolalityActivityCoefficients(), HMWSoln::initLengths(), MargulesVPSSTP::initLengths(), RedlichKisterVPSSTP::initLengths(), IonsFromNeutralVPSSTP::initThermo(), RedlichKwongMFTP::initThermo(), StoichSubstance::initThermo(), ThermoPhase::initThermo(), VPStandardStateTP::initThermo(), RedlichKwongMFTP::initThermoXML(), Phase::massFractionsToMoleFractions(), Phase::moleFractionsToMassFractions(), Phase::nSpecies(), ThermoPhase::o2Present(), ThermoPhase::o2Required(), MolalityVPSSTP::osmoticCoefficient(), HMWSoln::printCoeffs(), Phase::ready(), HMWSoln::relative_enthalpy(), HMWSoln::relative_molal_enthalpy(), DebyeHuckel::s_update_d2lnMolalityActCoeff_dT2(), HMWSoln::s_update_d2lnMolalityActCoeff_dT2(), IonsFromNeutralVPSSTP::s_update_dlnActCoeff_dlnN(), IonsFromNeutralVPSSTP::s_update_dlnActCoeff_dlnN_diag(), IonsFromNeutralVPSSTP::s_update_dlnActCoeff_dlnX_diag(), MargulesVPSSTP::s_update_dlnActCoeff_dT(), RedlichKisterVPSSTP::s_update_dlnActCoeff_dT(), IonsFromNeutralVPSSTP::s_update_dlnActCoeffdT(), DebyeHuckel::s_update_dlnMolalityActCoeff_dP(), HMWSoln::s_update_dlnMolalityActCoeff_dP(), DebyeHuckel::s_update_dlnMolalityActCoeff_dT(), HMWSoln::s_update_dlnMolalityActCoeff_dT(), IonsFromNeutralVPSSTP::s_update_lnActCoeff(), DebyeHuckel::s_update_lnMolalityActCoeff(), HMWSoln::s_updateIMS_lnMolalityActCoeff(), IdealMolalSoln::s_updateIMS_lnMolalityActCoeff(), HMWSoln::s_updatePitzer_d2lnMolalityActCoeff_dT2(), HMWSoln::s_updatePitzer_dlnMolalityActCoeff_dP(), HMWSoln::s_updatePitzer_dlnMolalityActCoeff_dT(), HMWSoln::s_updatePitzer_lnMolalityActCoeff(), HMWSoln::s_updateScaling_pHScaling(), HMWSoln::s_updateScaling_pHScaling_dP(), HMWSoln::s_updateScaling_pHScaling_dT(), HMWSoln::s_updateScaling_pHScaling_dT2(), RedlichKwongMFTP::setBinaryCoeffs(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), SurfPhase::setCoverages(), SurfPhase::setCoveragesByName(), SurfPhase::setCoveragesNoNorm(), DebyeHuckel::setDefaultIonicRadius(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), MolalityVPSSTP::setMolalities(), MolalityVPSSTP::setMolalitiesByName(), Phase::setMoleFractions(), Phase::setMoleFractions_NoNorm(), LatticePhase::setSiteDensity(), RedlichKwongMFTP::setSpeciesCoeffs(), IdealSolnGasVPSS::setToEquilState(), IdealGasPhase::setToEquilState(), IdealSolidSolnPhase::setToEquilState(), ThermoPhase::speciesData(), IdealSolidSolnPhase::standardConcentration(), Phase::sum_xlogx(), and RedlichKwongMFTP::updateAB().
|
protected |
Dimensionality of the phase.
Volumetric phases have dimensionality 3 and surface phases have dimensionality 2.
Definition at line 946 of file Phase.h.
Referenced by SurfPhase::initThermo(), Phase::nDim(), and Phase::setNDim().
|
protected |
Atomic composition of the species.
The number of atoms of element i in species k is equal to m_speciesComp[k * m_mm + i] The length of this vector is equal to m_kk * m_mm
Definition at line 951 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::getAtoms(), Phase::nAtoms(), and LatticeSolidPhase::setLatticeStoichiometry().
|
protected |
Vector of species charges. length m_kk.
Definition at line 953 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::charge(), Phase::getCharges(), IonsFromNeutralVPSSTP::getDissociationCoeffs(), and DebyeHuckel::s_update_lnMolalityActCoeff().
|
protected |
Flag determining behavior when adding species with an undefined element.
Definition at line 958 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::addUndefinedElements(), Phase::ignoreUndefinedElements(), and Phase::throwUndefinedElements().
|
protected |
Flag determining whether case sensitive species names are enforced.
Definition at line 961 of file Phase.h.
Referenced by Phase::caseSensitiveSpecies(), Phase::setCaseSensitiveSpecies(), and Phase::speciesIndex().
|
private |
XML node containing the XML info for this phase.
Definition at line 969 of file Phase.h.
Referenced by Phase::setXMLdata(), and Phase::xml().
|
private |
ID of the phase.
This is the value of the ID attribute of the XML phase node. The field will stay that way even if the name is changed.
Definition at line 973 of file Phase.h.
Referenced by Phase::id(), Phase::setID(), Phase::setName(), and Phase::speciesIndex().
|
private |
Name of the phase.
Initially, this is the name specified in the YAML or CTI input file, or the value of the ID attribute of the XML phase node. It may be changed to another value during the course of a calculation.
Definition at line 979 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::name(), Phase::setID(), Phase::setName(), Phase::speciesIndex(), and Phase::speciesSPName().
|
private |
Temperature (K). This is an independent variable.
Definition at line 981 of file Phase.h.
Referenced by Phase::setTemperature(), and Phase::temperature().
|
private |
Density (kg m-3).
This is an independent variable except in the case of incompressible phases, where it has to be changed using the assignDensity() method. For compressible substances, the pressure is determined from this variable rather than other way round.
Definition at line 987 of file Phase.h.
Referenced by Phase::assignDensity(), Phase::concentration(), Phase::density(), Phase::getConcentrations(), Phase::setDensity(), and Phase::setMolarDensity().
|
private |
mean molecular weight of the mixture (kg kmol-1)
Definition at line 989 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::getMoleFractions(), Phase::mean_X(), Phase::meanMolecularWeight(), Phase::moleFraction(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), Phase::setMolecularWeight(), Phase::setMoleFractions(), Phase::setMoleFractions_NoNorm(), and Phase::sum_xlogx().
|
mutableprivate |
m_ym[k] = mole fraction of species k divided by the mean molecular weight of mixture.
Definition at line 993 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::getConcentrations(), Phase::getMoleFractions(), Phase::mean_X(), Phase::moleFractdivMMW(), Phase::moleFraction(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), Phase::setMolecularWeight(), Phase::setMoleFractions(), Phase::setMoleFractions_NoNorm(), and Phase::sum_xlogx().
|
mutableprivate |
Mass fractions of the species.
Note, this vector Length is m_kk
Definition at line 1000 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::concentration(), Phase::getMassFractions(), Phase::massFraction(), Phase::massFractions(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), Phase::setMolecularWeight(), Phase::setMoleFractions(), and Phase::setMoleFractions_NoNorm().
|
private |
species molecular weights (kg kmol-1)
Definition at line 1002 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::massFractionsToMoleFractions(), Phase::molecularWeight(), Phase::molecularWeights(), Phase::moleFractionsToMassFractions(), Phase::setConcentrations(), Phase::setConcentrationsNoNorm(), Phase::setMolecularWeight(), Phase::setMoleFractions(), and Phase::setMoleFractions_NoNorm().
|
private |
inverse of species molecular weights (kmol kg-1)
Definition at line 1004 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::concentration(), Phase::setMassFractions(), Phase::setMassFractions_NoNorm(), and Phase::setMolecularWeight().
|
private |
State Change variable.
Whenever the mole fraction vector changes, this int is incremented.
Definition at line 1008 of file Phase.h.
Referenced by Phase::compositionChanged(), and Phase::stateMFNumber().
|
private |
Vector of the species names.
Definition at line 1011 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::species(), Phase::speciesName(), and Phase::speciesNames().
|
private |
Map of species names to indices.
Definition at line 1014 of file Phase.h.
Referenced by Phase::addSpecies(), Phase::addSpeciesAlias(), and Phase::speciesIndex().
|
private |
Map of lower-case species names to indices.
Definition at line 1017 of file Phase.h.
Referenced by Phase::addSpecies(), and Phase::findSpeciesLower().
|
private |
Number of elements.
Definition at line 1019 of file Phase.h.
Referenced by Phase::checkElementArraySize(), Phase::checkElementIndex(), Phase::elementIndex(), Phase::getAtoms(), Phase::nAtoms(), and Phase::nElements().
|
private |
element atomic weights (kg kmol-1)
Definition at line 1020 of file Phase.h.
Referenced by Phase::atomicWeight(), and Phase::atomicWeights().
|
private |
element atomic numbers
Definition at line 1021 of file Phase.h.
Referenced by Phase::atomicNumber().
|
private |
element names
Definition at line 1022 of file Phase.h.
Referenced by Phase::elementIndex(), Phase::elementName(), and Phase::elementNames().
|
private |
Vector of element types.
Definition at line 1023 of file Phase.h.
Referenced by Phase::changeElementType(), and Phase::elementType().
|
private |
Entropy at 298.15 K and 1 bar of stable state pure elements (J kmol-1)
Definition at line 1026 of file Phase.h.
Referenced by Phase::entropyElement298().
|
private |