38 VPSSMgr(right.m_vptp_ptr, right.m_spthermo),
85 for (
size_t k = 0; k <
m_kk; k++) {
108 copy(
m_V0.begin(),
m_V0.end(), vol);
158 for (
size_t k = 1; k <
m_kk; k++) {
165 #ifdef DEBUG_MODE_NOT
167 if (fabs(
m_h0_RT[k] - h) > 1.0E-4) {
168 printf(
" VPSSMgr_Water_HKFT::_updateRefStateThermo:: we have a discrepancy\n");
175 for (
size_t k = 1; k <
m_kk; k++) {
192 for (
size_t k = 1; k <
m_kk; k++) {
222 for (
size_t k = 1; k <
m_kk; k++) {
226 "No species Node for species " + sss[k]);
231 "No standardState Node for species " + sss[k]);
233 std::string model =
lowercase((*ss)[
"model"]);
234 if (model !=
"hkft") {
236 "Standard state model for a solute species isn't "
237 "the HKFT standard state model: " + sss[k]);
244 const XML_Node*
const phaseNode_ptr)
250 std::string sName = speciesNode[
"name"];
251 throw CanteraError(
"VPSSMgr_Water_HKFT::installSpecies",
252 "No standardState Node for species " + sName);
258 string xn = speciesNode[
"name"];
259 if (xn !=
"H2O(L)") {
260 throw CanteraError(
"VPSSMgr_Water_HKFT::installSpecies",
261 "h2o wrong name: " + xn);
264 std::string model = (*ss)[
"model"];
265 if (model !=
"waterIAPWS" && model !=
"waterPDSS") {
266 throw CanteraError(
"VPSSMgr_Water_HKFT::installSpecies",
267 "wrong SS mode: " + model);
275 throw CanteraError(
"VPSSMgr_Water_HKFT::installSpecies",
276 "failed dynamic cast");
282 std::string model = (*ss)[
"model"];
283 if (model !=
"HKFT") {
284 std::string sName = speciesNode[
"name"];
286 "standardState model for species isn't "
294 throw CanteraError(
"VPSSMgr_Water_HKFT::installSpecies",
295 "failed dynamic cast");
309 throw CanteraError(
"VPSSMgr_Water_ConstVol::initAllPtrs",
vector_fp m_V0
Vector containing the species reference molar volumes.
virtual doublereal gibbs_RT() const
Return the molar Gibbs free energy divided by RT.
virtual doublereal enthalpy_RT() const
Return the standard state molar enthalpy divided by RT.
virtual doublereal cp_mole() const
Return the molar const pressure heat capacity in units of J kmol-1 K-1.
virtual void setState_T(doublereal T)
Set the temperature (K)
XML_Node * findByAttr(const std::string &attr, const std::string &val, int depth=100000) const
This routine carries out a recursive search for an XML node based on an attribute of each XML node...
doublereal molecularWeight(size_t k) const
Molecular weight of species k.
doublereal m_tlastRef
Last reference temperature calculated.
bool m_useTmpRefStateStorage
virtual void setState_TP(doublereal temp, doublereal pres)
Set the internal temperature and pressure.
virtual PDSS * createInstallPDSS(size_t k, const XML_Node &speciesNode, const XML_Node *const phaseNode_ptr)
Install specific content for species k in the standard-state thermodynamic calculator and also create...
const doublereal OneAtm
One atmosphere [Pa].
vector_fp m_sss_R
Vector containing the species Standard State entropies at T = m_tlast and P = m_plast.
VPSSMgr_Water_HKFT(VPStandardStateTP *vptp_ptr, SpeciesThermo *spth)
Constructor.
Virtual base class for the classes that manage the calculation of standard state properties for all t...
VPSSMgr & operator=(const VPSSMgr &right)
Assignment operator.
Variable pressure SS calculate for phases consisting of real water as the first species and species o...
bool m_useTmpStandardStateStorage
virtual void getEntropy_R_ref(doublereal *er) const
virtual void getGibbs_RT_ref(doublereal *grt) const
virtual void initThermoXML(XML_Node &phaseNode, const std::string &id)
Finalize the thermo after all species have been entered.
PDSS_Water * m_waterSS
Shallow pointer to the water object.
size_t m_kk
Number of species in the phase.
Class XML_Node is a tree-based representation of the contents of an XML file.
Implementation of a pressure dependent standard state virtual function for a Pure Water Phase (see Sp...
virtual VPSSMgr * duplMyselfAsVPSSMgr() const
Duplication routine for objects which derive from VPSSMgr.
virtual void initAllPtrs(VPStandardStateTP *vp_ptr, SpeciesThermo *sp_ptr)
Initialize the internal shallow pointers in this object.
virtual void initThermo()
std::string lowercase(const std::string &s)
Cast a copy of a string to lower case.
virtual doublereal density() const
Return the standard state density at standard state.
Pure Virtual base class for the species thermo manager classes.
VPSSMgr_enumType
enum for VPSSMgr types that are responsible for calculating the species standard state and reference-...
XML_Node & child(const size_t n) const
Return a changeable reference to the n'th child of the current node.
virtual void initThermoXML(XML_Node &phaseNode, const std::string &id)
Finalize the thermo after all species have been entered.
const XML_Node * findByName(const std::string &nm, int depth=100000) const
This routine carries out a recursive search for an XML node based on the name of the node...
virtual doublereal enthalpy_mole() const
Return the molar enthalpy in units of J kmol-1.
virtual void setState_P(doublereal P)
Set the pressure (Pa)
doublereal pref_safe(doublereal temp) const
Returns a reference pressure value that can be safely calculated by the underlying real equation of s...
virtual doublereal entropy_R() const
Return the standard state entropy divided by RT.
virtual void getCp_R_ref(doublereal *cpr) const
virtual doublereal entropy_mole() const
Return the molar entropy in units of J kmol-1 K-1.
virtual void getEnthalpy_RT_ref(doublereal *hrt) const
vector_fp m_cp0_R
Vector containing the species reference constant pressure heat capacities at T = m_tlast and P = p_re...
A species thermodynamic property manager for a phase.
VPStandardStateTP * m_vptp_ptr
Variable pressure ThermoPhase object.
virtual void initThermo()
virtual void initAllPtrs(VPStandardStateTP *vp_ptr, SpeciesThermo *sp_ptr)
Initialize the internal shallow pointers in this object.
virtual void setState_TP(doublereal temp, doublereal pres)
Set the internal temperature and pressure.
Class for the liquid water pressure dependent standard state.
doublereal m_plast
The last pressure at which the Standard State thermodynamic properties were calculated at...
PDSS_enumType
Types of PDSS's.
Base class for exceptions thrown by Cantera classes.
virtual void getStandardVolumes_ref(doublereal *vol) const
Get the molar volumes of the species reference states at the current T and P_ref of the solution...
Manages standard state thermo properties for real water and a set of species which have the HKFT equa...
virtual doublereal molarVolume() const
Return the molar volume at standard state.
virtual void getGibbs_ref(doublereal *g) const
This is a filter class for ThermoPhase that implements some prepatory steps for efficiently handling ...
virtual PDSS_enumType reportPDSSType(int index=-1) const
This utility function reports the type of parameterization used for the species with index number ind...
vector_fp m_Vss
Vector containing the species standard state volumes at T = m_tlast and P = m_plast.
const std::vector< std::string > & speciesNames() const
Return a const reference to the vector of species names.
vector_fp m_hss_RT
Vector containing the species Standard State enthalpies at T = m_tlast and P = m_plast.
virtual VPSSMgr_enumType reportVPSSMgrType() const
This utility function reports the type of manager for the calculation of ss properties.
vector_fp m_cpss_R
Vector containing the species Standard State constant pressure heat capacities at T = m_tlast and P =...
virtual doublereal cp_R() const
Return the molar const pressure heat capacity divided by RT.
Headers for a completely general species thermodynamic property manager for a phase (see Managers for...
VPSSMgr_Water_HKFT & operator=(const VPSSMgr_Water_HKFT &right)
Assignment operator.
virtual void _updateRefStateThermo() const
Updates the reference state thermodynamic functions at the current T of the solution and the referenc...
Virtual base class for a species with a pressure dependent standard state.
vector_fp m_g0_RT
Vector containing the species reference Gibbs functions at T = m_tlast and P = p_ref.
virtual void updateRefStateThermo() const
Updates the internal reference state thermodynamic vectors at the current T of the solution and the r...
const doublereal GasConstant
Universal Gas Constant. [J/kmol/K].
Class for pressure dependent standard states corresponding to ionic solutes in electrolyte water...
SpeciesThermo * m_spthermo
Pointer to reference state thermo calculator.
doublereal m_tlast
The last temperature at which the standard state thermodynamic properties were calculated at...
virtual void setState_TP(doublereal T, doublereal P)
Set the temperature (K) and pressure (Pa)
XML_Node & root() const
Return the root of the current XML_Node tree.
vector_fp m_gss_RT
Vector containing the species Standard State Gibbs functions at T = m_tlast and P = m_plast...
virtual void _updateStandardStateThermo()
Updates the standard state thermodynamic functions at the current T and P of the solution.
virtual doublereal entropy_mole() const
Return the molar entropy in units of J kmol-1 K-1.
XML_Node * get_XML_NameID(const std::string &nameTarget, const std::string &file_ID, XML_Node *root)
This routine will locate an XML node in either the input XML tree or in another input file specified ...
Declarations for the class PDSS_HKFT (pressure dependent standard state) which handles calculations f...
Declaration file for a derived class that handles the calculation of standard state thermo properties...
vector_fp m_s0_R
Vector containing the species reference entropies at T = m_tlast and P = p_ref.
void installPDSShandler(size_t k, PDSS *PDSS_ptr, VPSSMgr *vpssmgr_ptr)
Install a PDSS object to handle the reference state thermodynamics calculation.