Cantera
2.1.2
|
Namespace for the Cantera kernel. More...
Classes | |
class | Application |
Class to hold global data. More... | |
class | LogPrintCtrl |
This class provides some printing and cropping utilities for writing to the logfile. More... | |
class | Unit |
Unit conversion utility. More... | |
class | XML_Error |
Classs representing a generic XML error condition. More... | |
class | XML_TagMismatch |
Class representing a specific type of XML file formatting error. More... | |
class | XML_NoChild |
Class representing a specific type of XML file formatting error. More... | |
class | PropertyCalculator |
Classes used by ChemEquil. More... | |
class | Troe3 |
The 3-parameter Troe falloff parameterization. More... | |
class | Troe4 |
The 4-parameter Troe falloff parameterization. More... | |
class | SRI3 |
The 3-parameter SRI falloff function for F More... | |
class | SRI5 |
The 5-parameter SRI falloff function. More... | |
class | WF93 |
Wang-Frenklach falloff function. More... | |
class | rxninfo |
these are all used to check for duplicate reactions More... | |
class | CVodeErr |
Exception thrown when a CVODE error is encountered. More... | |
class | CVodeInt |
Wrapper class for 'cvode' integrator from LLNL. More... | |
class | ResidData |
A simple class to hold an array of parameter values and a pointer to an instance of a subclass of ResidEval. More... | |
class | Nucleus |
Represents atomic nuclei. More... | |
class | ConstCpPoly |
A constant-heat capacity species thermodynamic property manager class. More... | |
struct | awData |
class | ElementsFrozen |
Exception class to indicate a fixed set of elements. More... | |
class | Nasa9PolyMultiTempRegion |
The NASA 9 polynomial parameterization for a single species encompassing multiple temperature regions. More... | |
class | NasaPoly2 |
The NASA polynomial parameterization for two temperature ranges. More... | |
class | NasaThermo |
A species thermodynamic property manager for the NASA polynomial parameterization with two temperature ranges. More... | |
class | ShomatePoly |
The Shomate polynomial parameterization for one temperature range for one species. More... | |
class | ShomatePoly2 |
The Shomate polynomial parameterization for two temperature ranges for one species. More... | |
class | ShomateThermo |
A species thermodynamic property manager for the Shomate polynomial parameterization. More... | |
class | UnknownVPSSMgrModel |
Throw a named error for an unknown or missing vpss species thermo model. More... | |
class | VPSSMgrFactory |
Factory to build instances of classes that manage the standard-state thermodynamic properties of a set of species. More... | |
class | FtnTransport |
A class that calls external Fortran functions to evaluate transport properties. More... | |
class | LTPError |
Exception thrown if an error is encountered while reading the transport database. More... | |
class | LTPmodelError |
Exception thrown if an error is encountered while reading the transport database. More... | |
class | MMCollisionInt |
Calculation of Collision integrals. More... | |
class | TortuosityBase |
Base case to handle tortuosity corrections for diffusive transport in porous media. More... | |
class | TortuosityBruggeman |
Base case to handle tortuosity corrections for diffusive transport in porous media using the Bruggeman exponential approximation. More... | |
class | TortuosityMaxwell |
Maxwell model for tortuosity. More... | |
class | TortuosityPercolation |
This class implements transport coefficient corrections appropriate for porous media where percolation theory applies. More... | |
class | TransportDBError |
Exception thrown if an error is encountered while reading the transport database. More... | |
class | Array2D |
A class for 2D arrays stored in column-major (Fortran-compatible) form. More... | |
class | clockWC |
The class provides the wall clock timer in seconds. More... | |
class | CanteraError |
Base class for exceptions thrown by Cantera classes. More... | |
class | ArraySizeError |
Array size error. More... | |
class | IndexError |
An array index is out of range. More... | |
class | FactoryBase |
Base class for factories. More... | |
class | Logger |
Base class for 'loggers' that write text messages to log files. More... | |
class | PrintCtrl |
This class provides some printing and cropping utilities. More... | |
struct | timesConstant |
Unary operator to multiply the argument by a constant. More... | |
class | XML_Reader |
Class XML_Reader reads an XML file into an XML_Node object. More... | |
class | XML_Node |
Class XML_Node is a tree-based representation of the contents of an XML file. More... | |
class | EquilOpt |
Chemical equilibrium options. More... | |
class | ChemEquil |
Class ChemEquil implements a chemical equilibrium solver for single-phase solutions. More... | |
class | MultiPhase |
A class for multiphase mixtures. More... | |
class | MultiPhaseEquil |
class | GRI30 |
This class is a convenience class for use in C++ programs that hard-wires the GRI 3.0 reaction mechanism. More... | |
class | Interface |
An interface between multiple bulk phases. More... | |
class | AqueousKinetics |
Kinetics manager for elementary aqueous-phase chemistry. More... | |
class | EdgeKinetics |
Heterogeneous reactions at one-dimensional interfaces between multiple adjacent two-dimensional surfaces. More... | |
class | Enhanced3BConc |
Computes enhanced third-body concentrations. More... | |
class | Falloff |
Base class for falloff function calculators. More... | |
class | FalloffFactory |
Factory class to construct falloff function calculators. More... | |
class | FalloffMgr |
A falloff manager that implements any set of falloff functions. More... | |
class | GasKinetics |
Kinetics manager for elementary gas-phase chemistry. More... | |
class | GRI_30_Kinetics |
Kinetics manager implementing reaction mechanism GRI-Mech 3.0. More... | |
class | Group |
Class Group is an internal class used by class ReactionPath. More... | |
class | ImplicitSurfChem |
Advances the surface coverages of the associated set of SurfacePhase objects in time. More... | |
struct | ReactionRules |
Rules for parsing and installing reactions. More... | |
class | InterfaceKinetics |
A kinetics manager for heterogeneous reaction mechanisms. More... | |
class | Kinetics |
Public interface for kinetics managers. More... | |
class | KineticsFactory |
Factory for kinetics managers. More... | |
class | Rate1 |
This rate coefficient manager supports one parameterization of the rate constant of any type. More... | |
class | ReactionData |
Intermediate class which stores data about a reaction and its rate parameterization before adding the reaction to a Kinetics object. More... | |
class | SpeciesNode |
Nodes in reaction path graphs. More... | |
class | ReactionPathDiagram |
Reaction path diagrams (graphs). More... | |
class | ReactionStoichMgr |
Reaction mechanism stoichiometry manager. More... | |
class | Arrhenius |
Arrhenius reaction rate type depends only on temperature. More... | |
class | SurfaceArrhenius |
An Arrhenius rate with coverage-dependent terms. More... | |
class | ExchangeCurrent |
Arrhenius reaction rate type depends only on temperature. More... | |
class | solveSP |
Method to solve a pseudo steady state surface problem. More... | |
class | C1 |
Handles one species in a reaction. More... | |
class | C2 |
Handles two species in a single reaction. More... | |
class | C3 |
Handles three species in a reaction. More... | |
class | C_AnyN |
Handles any number of species in a reaction, including fractional stoichiometric coefficients, and arbitrary reaction orders. More... | |
class | BandMatrix |
A class for banded matrices, involving matrix inversion processes. More... | |
class | BEulerErr |
Exception class thrown when a BEuler error is encountered. More... | |
class | BEulerInt |
class | CVodesErr |
Exception thrown when a CVODES error is encountered. More... | |
class | CVodesIntegrator |
Wrapper class for 'cvodes' integrator from LLNL. More... | |
class | DAE_Solver |
Wrapper for DAE solvers. More... | |
class | CELapackError |
Exception thrown when an LAPACK error is encountered associated with inverting or solving a matrix. More... | |
class | DenseMatrix |
A class for full (non-sparse) matrices with Fortran-compatible data storage, which adds matrix operations to class Array2D. More... | |
class | Func1 |
Base class for 'functor' classes that evaluate a function of one variable. More... | |
class | Sin1 |
implements the sin() function More... | |
class | Cos1 |
cos More... | |
class | Exp1 |
exp More... | |
class | Pow1 |
pow More... | |
class | Const1 |
Constant. More... | |
class | Sum1 |
Sum of two functions. More... | |
class | Diff1 |
Difference of two functions. More... | |
class | Product1 |
Product of two functions. More... | |
class | TimesConstant1 |
Product of two functions. More... | |
class | PlusConstant1 |
A function plus a constant. More... | |
class | Ratio1 |
Ratio of two functions. More... | |
class | Composite1 |
Composite function. More... | |
class | Gaussian |
A Gaussian. More... | |
class | Poly1 |
Polynomial of degree n. More... | |
class | Fourier1 |
Fourier cosine/sine series. More... | |
class | Arrhenius1 |
Sum of Arrhenius terms. More... | |
class | Periodic1 |
Periodic function. More... | |
class | FuncEval |
Virtual base class for ODE right-hand-side function evaluators. More... | |
class | GeneralMatrix |
Generic matrix. More... | |
class | IDA_Err |
Exception thrown when a IDA error is encountered. More... | |
class | Integrator |
Abstract base class for ODE system integrators. More... | |
class | NonlinearSolver |
Class that calculates the solution to a nonlinear system. More... | |
class | ResidEval |
Virtual base class for DAE residual function evaluators. More... | |
class | ResidJacEval |
Wrappers for the function evaluators for Nonlinear solvers and Time steppers. More... | |
class | RootFind |
Root finder for 1D problems. More... | |
class | solveProb |
Method to solve a pseudo steady state of a nonlinear problem. More... | |
class | SquareMatrix |
A class for full (non-sparse) matrices with Fortran-compatible data storage. More... | |
class | Domain1D |
Base class for one-dimensional domains. More... | |
class | Bdry1D |
The base class for boundaries between one-dimensional spatial domains. More... | |
class | Inlet1D |
An inlet. More... | |
class | Empty1D |
A terminator that does nothing. More... | |
class | Symm1D |
A symmetry plane. More... | |
class | Outlet1D |
An outlet. More... | |
class | OutletRes1D |
An outlet with specified composition. More... | |
class | Surf1D |
A non-reacting surface. More... | |
class | ReactingSurf1D |
A reacting surface. More... | |
class | MultiJac |
Class MultiJac evaluates the Jacobian of a system of equations defined by a residual function supplied by an instance of class OneDim. More... | |
class | MultiNewton |
Newton iterator for multi-domain, one-dimensional problems. More... | |
class | OneDim |
Container class for multiple-domain 1D problems. More... | |
class | Refiner |
Refine Domain1D grids so that profiles satisfy adaptation tolerances. More... | |
class | Sim1D |
One-dimensional simulations. More... | |
class | StFlow |
This class represents 1D flow domains that satisfy the one-dimensional similarity solution for chemically-reacting, axisymmetric, flows. More... | |
class | AxiStagnFlow |
A class for axisymmetric stagnation flows. More... | |
class | FreeFlame |
A class for freely-propagating premixed flames. More... | |
class | LineBroadener |
Base class for classes implementing line shapes of various types. More... | |
class | LorentzianProfile |
The line shape for pure collisional broadening. More... | |
class | GaussianProfile |
A Gaussian line profile. More... | |
class | Voigt |
A Voigt profile is the convolution of a Lorentzian and a Gaussian profile. More... | |
class | Rotor |
Class Rotor represents a non-rigid quantum-mechanical rotor. More... | |
class | Adsorbate |
An adsorbed surface species. More... | |
class | ConstDensityThermo |
Overloads the virtual methods of class ThermoPhase to implement the incompressible equation of state. More... | |
class | DebyeHuckel |
Class DebyeHuckel represents a dilute liquid electrolyte phase which obeys the Debye Huckel formulation for nonideality. More... | |
class | EdgePhase |
A thermodynamic phase representing a one dimensional edge between two surfaces. More... | |
class | Elements |
Object containing the elements that make up species in a phase. More... | |
class | FixedChemPotSSTP |
Class FixedChemPotSSTP represents a stoichiometric (fixed composition) incompressible substance. More... | |
class | GeneralSpeciesThermo |
A species thermodynamic property manager for a phase. More... | |
class | GibbsExcessVPSSTP |
class | HMWSoln |
Class HMWSoln represents a dilute or concentrated liquid electrolyte phase which obeys the Pitzer formulation for nonideality. More... | |
class | IdealGasPhase |
Class IdealGasPhase represents low-density gases that obey the ideal gas equation of state. More... | |
class | IdealMolalSoln |
This phase is based upon the mixing-rule assumption that all molality-based activity coefficients are equal to one. More... | |
class | IdealSolidSolnPhase |
Class IdealSolidSolnPhase represents a condensed phase ideal solution compound. More... | |
class | IdealSolnGasVPSS |
An ideal solution or an ideal gas approximation of a phase. More... | |
class | IonsFromNeutralVPSSTP |
class | LatticePhase |
A simple thermodynamic model for a bulk phase, assuming a lattice of solid atoms. More... | |
class | LatticeSolidPhase |
A phase that is comprised of a fixed additive combination of other lattice phases. More... | |
class | MargulesVPSSTP |
MargulesVPSSTP is a derived class of GibbsExcessVPSSTP that employs the Margules approximation for the excess gibbs free energy. More... | |
class | MetalPhase |
Class MetalPhase represents electrons in a metal. More... | |
class | MetalSHEelectrons |
Class MetalSHEelectrons represents electrons within a metal, adjacent to an aqueous electrolyte, that are consistent with the SHE reference electrode. More... | |
class | MineralEQ3 |
Class MineralEQ3 represents a stoichiometric (fixed composition) incompressible substance based on EQ3's parameterization. More... | |
class | MixedSolventElectrolyte |
MixedSolventElectrolyte is a derived class of GibbsExcessVPSSTP that employs the DH and local Marguless approximations for the excess gibbs free energy. More... | |
class | MixtureFugacityTP |
This is a filter class for ThermoPhase that implements some preparatory steps for efficiently handling mixture of gases that whose standard states are defined as ideal gases, but which describe also non-ideal solutions. More... | |
class | MolalityVPSSTP |
class | MolarityIonicVPSSTP |
class | Mu0Poly |
The Mu0Poly class implements an interpolation of the Gibbs free energy based on a piecewise constant heat capacity approximation. More... | |
class | Nasa9Poly1 |
The NASA 9 polynomial parameterization for one temperature range. More... | |
class | NasaPoly1 |
The NASA polynomial parameterization for one temperature range. More... | |
class | PDSS |
Virtual base class for a species with a pressure dependent standard state. More... | |
class | PDSS_ConstVol |
Class for pressure dependent standard states that use a constant volume model. More... | |
class | PDSS_HKFT |
Class for pressure dependent standard states corresponding to ionic solutes in electrolyte water. More... | |
class | PDSS_IdealGas |
Derived class for pressure dependent standard states of an ideal gas species. More... | |
class | PDSS_IonsFromNeutral |
Derived class for pressure dependent standard states of an ideal gas species. More... | |
class | PDSS_SSVol |
Class for pressure dependent standard states that uses a standard state volume model of some sort. More... | |
class | PDSS_Water |
Class for the liquid water pressure dependent standard state. More... | |
class | Phase |
Base class for phases of matter. More... | |
class | PhaseCombo_Interaction |
PhaseCombo_Interaction is a derived class of GibbsExcessVPSSTP that employs the Margules approximation for the excess gibbs free energy while eliminating the entropy of mixing term. More... | |
class | PseudoBinaryVPSSTP |
class | PureFluidPhase |
This phase object consists of a single component that can be a gas, a liquid, a mixed gas-liquid fluid, or a fluid beyond its critical point. More... | |
class | RedlichKisterVPSSTP |
RedlichKisterVPSSTP is a derived class of GibbsExcessVPSSTP that employs the Redlich-Kister approximation for the excess gibbs free energy. More... | |
class | RedlichKwongMFTP |
This class can handle either an ideal solution or an ideal gas approximation of a phase. More... | |
class | SemiconductorPhase |
Class SemiconductorPhase represents electrons and holes in a semiconductor. More... | |
class | SimpleThermo |
class | SingleSpeciesTP |
The SingleSpeciesTP class is a filter class for ThermoPhase. More... | |
class | SpeciesThermo |
Pure Virtual base class for the species thermo manager classes. More... | |
class | UnknownSpeciesThermoModel |
Throw a named error for an unknown or missing species thermo model. More... | |
class | SpeciesThermoFactory |
Factory to build instances of classes that manage the standard-state thermodynamic properties of a set of species. More... | |
class | SpeciesThermoInterpType |
Pure Virtual Base class for the thermodynamic manager for an individual species' reference state. More... | |
class | STITbyPDSS |
Class for the thermodynamic manager for an individual species' reference state which uses the PDSS base class to satisfy the requests. More... | |
class | UnknownSpeciesThermo |
Unknown species thermo manager string error. More... | |
class | SpeciesThermoDuo |
This species thermo manager requires that all species have one of two parameterizations. More... | |
class | StatMech |
Statistical mechanics. More... | |
class | StoichSubstance |
Class StoichSubstance represents a stoichiometric (fixed composition) incompressible substance. More... | |
class | StoichSubstanceSSTP |
Class StoichSubstanceSSTP represents a stoichiometric (fixed composition) incompressible substance. More... | |
class | electrodeElectron |
Class electrodeElectron represents an electron in a metal using the Standard hydrogen reference electrode. More... | |
class | SurfPhase |
A simple thermodynamic model for a surface phase, assuming an ideal solution model. More... | |
class | UnknownThermoPhaseModel |
Specific error to be thrown if the type of Thermo manager is unrecognized. More... | |
class | ThermoFactory |
Factory class for thermodynamic property managers. More... | |
class | ThermoPhase |
Base class for a phase with thermodynamic properties. More... | |
class | VPSSMgr |
Virtual base class for the classes that manage the calculation of standard state properties for all the species in a phase. More... | |
class | VPSSMgr_ConstVol |
Constant Molar Volume e VPSS species thermo manager class. More... | |
class | VPSSMgr_General |
Class that handles the calculation of standard state thermo properties for a set of species belonging to a single phase in a completely general but slow way. More... | |
class | VPSSMgr_IdealGas |
A VPSSMgr where all species in the phase obey an ideal gas equation of state. More... | |
class | VPSSMgr_Water_ConstVol |
Handles the calculation of standard state thermo properties for real water and a set of species which have a constant molar volume pressure dependence. More... | |
class | VPSSMgr_Water_HKFT |
Manages standard state thermo properties for real water and a set of species which have the HKFT equation of state. More... | |
class | VPStandardStateTP |
This is a filter class for ThermoPhase that implements some prepatory steps for efficiently handling a variable pressure standard state for species. More... | |
class | WaterProps |
The WaterProps class is used to house several approximation routines for properties of water. More... | |
class | WaterPropsIAPWS |
Class for calculating the equation of state of water. More... | |
class | WaterPropsIAPWSphi |
Low level class for the real description of water. More... | |
class | WaterSSTP |
Class for single-component water. More... | |
class | AqueousTransport |
Class AqueousTransport implements mixture-averaged transport properties for brine phases. More... | |
class | DustyGasTransport |
Class DustyGasTransport implements the Dusty Gas model for transport in porous media. More... | |
class | GasTransport |
Class GasTransport implements some functions and properties that are shared by the MixTransport and MultiTransport classes. More... | |
class | LiquidTranInteraction |
Base class to handle transport property evaluation in a mixture. More... | |
class | LTI_MoleFracs |
Simple mole fraction weighting of transport properties. More... | |
class | LTI_MassFracs |
Simple mass fraction weighting of transport properties. More... | |
class | LTI_Log_MoleFracs |
Mixing rule using logarithms of the mole fractions. More... | |
class | LTI_Pairwise_Interaction |
Transport properties that act like pairwise interactions as in binary diffusion coefficients. More... | |
class | LTI_StefanMaxwell_PPN |
Stefan Maxwell Diffusion Coefficients can be solved for given ion conductivity, mobility ratios, and self diffusion coeffs. More... | |
class | LTI_MoleFracs_ExpT |
Simple mole fraction weighting of transport properties. More... | |
class | LiquidTransport |
Class LiquidTransport implements models for transport properties for liquid phases. More... | |
class | LiquidTransportData |
Class LiquidTransportData holds transport parameters for a specific liquid-phase species. More... | |
class | LiquidTransportParams |
Class LiquidTransportParams holds transport model parameters relevant to transport in mixtures. More... | |
class | LTPspecies |
Class LTPspecies holds transport parameters for a specific liquid-phase species. More... | |
class | LTPspecies_Const |
Class LTPspecies_Const holds transport parameters for a specific liquid-phase species (LTPspecies) when the transport property is just a constant value. More... | |
class | LTPspecies_Arrhenius |
Class LTPspecies_Arrhenius holds transport parameters for a specific liquid-phase species (LTPspecies) when the transport property is expressed in Arrhenius form. More... | |
class | LTPspecies_Poly |
Class LTPspecies_Poly holds transport parameters for a specific liquid-phase species (LTPspecies) when the transport property is expressed as a polynomial in temperature. More... | |
class | LTPspecies_ExpT |
Class LTPspecies_ExpT holds transport parameters for a specific liquid- phase species (LTPspecies) when the transport property is expressed as an exponential in temperature. More... | |
class | MixTransport |
Class MixTransport implements mixture-averaged transport properties for ideal gas mixtures. More... | |
class | MultiTransport |
Class MultiTransport implements multicomponent transport properties for ideal gas mixtures. More... | |
class | PecosTransport |
Class PecosTransport implements mixture-averaged transport properties for ideal gas mixtures. More... | |
class | SimpleTransport |
Class SimpleTransport implements mixture-averaged transport properties for liquid phases. More... | |
class | SolidTransport |
Class SolidTransport implements transport properties for solids. More... | |
class | SolidTransportData |
Class SolidTransportData holds transport parameters for a specific solid-phase species. More... | |
class | Transport |
Base class for transport property managers. More... | |
class | TransportFactory |
Factory class for creating new instances of classes derived from Transport. More... | |
class | NotImplemented |
Error class to indicate an unimplemented method. More... | |
class | TransportParams |
Base structure to hold transport model parameters. More... | |
class | GasTransportParams |
This structure holds transport model parameters relevant to transport in ideal gases with a kinetic theory of gases derived transport model. More... | |
class | WaterTransport |
Transport Parameters for pure water. More... | |
class | ConstPressureReactor |
Class ConstPressureReactor is a class for constant-pressure reactors. More... | |
class | MassFlowController |
A class for mass flow controllers. More... | |
class | PressureController |
A class for flow controllers where the flow rate is equal to the flow rate of a "master" mass flow controller plus a correction proportional to the pressure difference between the inlet and outlet. More... | |
class | Valve |
Supply a mass flow rate that is a function of the pressure drop across the valve. More... | |
class | FlowDevice |
Base class for 'flow devices' (valves, pressure regulators, etc.) connecting reactors. More... | |
class | FlowReactor |
Adiabatic flow in a constant-area duct. More... | |
class | IdealGasConstPressureReactor |
Class ConstPressureReactor is a class for constant-pressure reactors. More... | |
class | IdealGasReactor |
Class IdealGasReactor is a class for stirred reactors that is specifically optimized for ideal gases. More... | |
class | Reactor |
Class Reactor is a general-purpose class for stirred reactors. More... | |
class | ReactorBase |
Base class for stirred reactors. More... | |
class | ReactorNet |
A class representing a network of connected reactors. More... | |
class | Wall |
Represents a wall between between two ReactorBase objects. More... | |
Typedefs | |
typedef std::map< std::string, doublereal > | compositionMap |
Map connecting a string name with a double. More... | |
typedef std::vector< double > | vector_fp |
Turn on the use of stl vectors for the basic array type within cantera Vector of doubles. More... | |
typedef std::vector< int > | vector_int |
Vector of ints. More... | |
typedef std::vector < std::vector< size_t > > | grouplist_t |
A grouplist is a vector of groups of species. More... | |
typedef boost::mutex | mutex_t |
typedef boost::mutex::scoped_lock | ScopedLock |
typedef ThermoPhase | thermo_t |
typedef for the ThermoPhase class More... | |
typedef int | VelocityBasis |
The diffusion fluxes must be referenced to a particular reference fluid velocity. More... | |
Enumerations | |
enum | flow_t { NetFlow, OneWayFlow } |
enum | BEulerMethodType { BEulerFixedStep, BEulerVarStep } |
enum | MethodType { BDF_Method, Adams_Method } |
Specifies the method used to integrate the system of equations. More... | |
enum | IterType { Newton_Iter, Functional_Iter } |
Specifies the method used for iteration. More... | |
enum | ResidEval_Type_Enum { Base_ResidEval = 0, JacBase_ResidEval, JacDelta_ResidEval, Base_ShowSolution, Base_LaggedSolutionComponents } |
Differentiates the type of residual evaluations according to functionality. More... | |
enum | IonSolnType_enumType { cIonSolnType_PASSTHROUGH = 2000, cIonSolnType_SINGLEANION, cIonSolnType_SINGLECATION, cIonSolnType_MULTICATIONANION } |
enums for molten salt ion solution types More... | |
enum | SSVolume_Model_enumType { cSSVOLUME_CONSTANT = 0, cSSVOLUME_TPOLY, cSSVOLUME_DENSITY_TPOLY } |
Types of general formulations for the specification of the standard state volume. More... | |
enum | PDSS_enumType { cPDSS_UNDEF = 100, cPDSS_IDEALGAS, cPDSS_CONSTVOL, cPDSS_SSVOL, cPDSS_MOLAL_CONSTVOL, cPDSS_WATER, cPDSS_MOLAL_HKFT, cPDSS_IONSFROMNEUTRAL } |
Types of PDSS's. More... | |
enum | VPSSMgr_enumType { cVPSSMGR_UNDEF = 1000, cVPSSMGR_IDEALGAS, cVPSSMGR_CONSTVOL, cVPSSMGR_PUREFLUID, cVPSSMGR_WATER_CONSTVOL, cVPSSMGR_WATER_HKFT, cVPSSMGR_GENERAL } |
enum for VPSSMgr types that are responsible for calculating the species standard state and reference-state thermodynamic properties. More... | |
enum | LiquidTranMixingModel { LTI_MODEL_NOTSET =-1, LTI_MODEL_NONE, LTI_MODEL_SOLVENT, LTI_MODEL_MOLEFRACS, LTI_MODEL_MASSFRACS, LTI_MODEL_LOG_MOLEFRACS, LTI_MODEL_PAIRWISE_INTERACTION, LTI_MODEL_STEFANMAXWELL_PPN, LTI_MODEL_STOKES_EINSTEIN, LTI_MODEL_MOLEFRACS_EXPT } |
Composition dependence type for liquid mixture transport properties. More... | |
enum | TransportPropertyType { TP_UNKNOWN = -1, TP_VISCOSITY = 0, TP_IONCONDUCTIVITY, TP_MOBILITYRATIO, TP_SELFDIFFUSION, TP_THERMALCOND, TP_DIFFUSIVITY, TP_HYDRORADIUS, TP_ELECTCOND, TP_DEFECTCONC, TP_DEFECTDIFF } |
Enumeration of the types of transport properties that can be handled by the variables in the various Transport classes. More... | |
enum | LTPTemperatureDependenceType { LTP_TD_NOTSET =-1, LTP_TD_CONSTANT, LTP_TD_ARRHENIUS, LTP_TD_POLY, LTP_TD_EXPT } |
Temperature dependence type for pure (liquid) species properties. More... | |
Functions | |
cthreadId_t | getThisThreadId () |
void | checkFinite (const double tmp) |
Check to see that a number is finite (not NaN, +Inf or -Inf) More... | |
static Application * | app () |
Return a pointer to the application object. More... | |
void | setLogger (Logger *logwriter) |
Install a logger. More... | |
void | writelog (const std::string &msg) |
Write a message to the screen. More... | |
void | writelogf (const char *fmt,...) |
Write a formatted message to the screen. More... | |
void | writelogendl () |
Write an end of line character to the screen and flush output. More... | |
void | error (const std::string &msg) |
Write an error message and quit. More... | |
void | warn_deprecated (const std::string &method, const std::string &extra="") |
Print a warning indicating that method is deprecated. More... | |
void | suppress_deprecation_warnings () |
Globally disable printing of deprecation warnings. More... | |
void | beginLogGroup (const std::string &title, int loglevel=-99) |
Create a new group for log messages. More... | |
void | addLogEntry (const std::string &tag, const std::string &value) |
Add an entry to an HTML log file. More... | |
void | addLogEntry (const std::string &tag, doublereal value) |
Add an entry to an HTML log file. More... | |
void | addLogEntry (const std::string &tag, int value) |
Add an entry to an HTML log file. More... | |
void | addLogEntry (const std::string &msg) |
Add an entry to an HTML log file. More... | |
void | endLogGroup (const std::string &title="") |
Close the current group of log messages. More... | |
void | write_logfile (const std::string &file="log.html") |
Write the HTML log file. More... | |
void | appdelete () |
Delete and free all memory associated with the application. More... | |
void | thread_complete () |
Delete and free memory allocated per thread in multithreaded applications. More... | |
XML_Node * | get_XML_File (const std::string &file, int debug=0) |
Return a pointer to the XML tree for a Cantera input file. More... | |
void | close_XML_File (const std::string &file) |
Close an XML File. More... | |
int | nErrors () |
Return the number of errors that have been encountered so far. More... | |
void | popError () |
Discard the last error message. More... | |
string | lastErrorMessage () |
Retrieve the last error message in a string. More... | |
void | showErrors (std::ostream &f) |
Prints all of the error messages to an ostream. More... | |
void | showErrors () |
Prints all of the error messages using writelog. More... | |
void | setError (const std::string &r, const std::string &msg) |
Set an error condition in the application class without throwing an exception. More... | |
void | addDirectory (const std::string &dir) |
Add a directory to the data file search path. More... | |
std::string | findInputFile (const std::string &name) |
Find an input file. More... | |
doublereal | toSI (const std::string &unit) |
Return the conversion factor to convert unit std::string 'unit' to SI units. More... | |
doublereal | actEnergyToSI (const std::string &unit) |
Return the conversion factor to convert activation energy unit std::string 'unit' to Kelvin. More... | |
string | canteraRoot () |
Returns root directory where Cantera is installed. More... | |
static void | split_at_pound (const std::string &src, std::string &file, std::string &id) |
split a string at a '#' sign. Used to separate a file name from an id string. More... | |
XML_Node * | get_XML_Node (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 by the file part of the file_ID string. More... | |
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 by the file part of the file_ID string. More... | |
void | writePlotFile (const std::string &fname, const std::string &fmt, const std::string &plotTitle, const std::vector< std::string > &names, const Array2D &data) |
Write a Plotting file. More... | |
void | outputTEC (std::ostream &s, const std::string &title, const std::vector< std::string > &names, const Array2D &data) |
Write a Tecplot data file. More... | |
void | outputExcel (std::ostream &s, const std::string &title, const std::vector< std::string > &names, const Array2D &data) |
Write an Excel spreadsheet in 'csv' form. More... | |
std::string | fp2str (const double x, const std::string &fmt="%g") |
Convert a double into a c++ string. More... | |
std::string | int2str (const int n, const std::string &fmt="%d") |
Convert an int to a string using a format converter. More... | |
std::string | int2str (const size_t n) |
Convert an unsigned integer to a string. More... | |
std::string | lowercase (const std::string &s) |
Cast a copy of a string to lower case. More... | |
static int | firstChar (const std::string &s) |
Return the position of the first printable character in the string. More... | |
static int | lastChar (const std::string &s) |
Return the position of the last printable character in the string. More... | |
std::string | stripws (const std::string &s) |
Strip the leading and trailing white space from a string. More... | |
std::string | stripnonprint (const std::string &s) |
Strip non-printing characters wherever they are. More... | |
compositionMap | parseCompString (const std::string &ss, const std::vector< std::string > &names) |
Parse a composition string into a map consisting of individual key:composition pairs. More... | |
void | split (const std::string &ss, std::vector< std::string > &w) |
Parse a composition string into individual key:composition pairs. More... | |
int | fillArrayFromString (const std::string &str, doublereal *const a, const char delim= ' ') |
Interpret a string as a list of floats, and convert it to a vector of floats. More... | |
std::string | getBaseName (const std::string &fullPath) |
Get the file name without the path or extension. More... | |
int | intValue (const std::string &val) |
Translate a string into one integer value. More... | |
doublereal | fpValue (const std::string &val) |
Translate a string into one doublereal value. More... | |
doublereal | fpValueCheck (const std::string &val) |
Translate a string into one doublereal value, with error checking. More... | |
std::string | logfileName (const std::string &infile) |
Generate a logfile name based on an input file name. More... | |
std::string | wrapString (const std::string &s, const int len=70) |
Line wrap a string via a copy operation. More... | |
std::string | parseSpeciesName (const std::string &nameStr, std::string &phaseName) |
Parse a name string, separating out the phase name from the species name. More... | |
int | stripLTWScstring (char str[]) |
Routine strips off white space from a c character string. More... | |
doublereal | strSItoDbl (const std::string &strSI) |
Interpret one or two token string as a single double. More... | |
static std::string::size_type | findFirstWS (const std::string &val) |
Find the first white space in a string. More... | |
static std::string::size_type | findFirstNotOfWS (const std::string &val) |
Find the first non-white space in a string. More... | |
void | tokenizeString (const std::string &oval, std::vector< std::string > &v) |
This function separates a string up into tokens according to the location of white space. More... | |
void | copyString (const std::string &source, char *dest, size_t length) |
Copy the contents of a std::string into a char array of a given length. More... | |
static string::size_type | findUnbackslashed (const std::string &s, const char q, std::string::size_type istart=0) |
Find the first position of a character, q, in string, s, which is not immediately preceded by the backslash character. More... | |
XML_Node * | findXMLPhase (XML_Node *root, const std::string &phaseName) |
Search an XML_Node tree for a named phase XML_Node. More... | |
int | _equilflag (const char *xy) |
map property strings to integers More... | |
doublereal | equilibrate (MultiPhase &s, const char *XY, doublereal rtol=1.0e-9, int maxsteps=5000, int maxiter=100, int loglevel=-99) |
Equilibrate a MultiPhase object. More... | |
int | equilibrate (thermo_t &s, const char *XY, int solver=-1, doublereal rtol=1.0e-9, int maxsteps=VCS_MAXSTEPS, int maxiter=100, int loglevel=-99) |
Equilibrate a ThermoPhase object. More... | |
static string | coeffString (bool first, doublereal nu, string sym) |
Used to print reaction equations. More... | |
int | new_equilibrate (thermo_t &s, const char *XY, int solver, doublereal rtol, int maxsteps, int maxiter, int loglevel) |
int | vcs_equilibrate (thermo_t &s, const char *XY, int estimateEquil=0, int printLvl=0, int solver=-1, doublereal rtol=1.0e-9, int maxsteps=VCS_MAXSTEPS, int maxiter=100, int loglevel=-99) |
Set a single-phase chemical solution to chemical equilibrium. More... | |
int | vcs_equilibrate (MultiPhase &s, const char *XY, int estimateEquil=0, int printLvl=0, int solver=2, doublereal rtol=1.0e-9, int maxsteps=VCS_MAXSTEPS, int maxiter=100, int loglevel=-99) |
Set a multi-phase chemical solution to chemical equilibrium. More... | |
int | vcs_equilibrate_1 (MultiPhase &s, int ixy, int estimateEquil=0, int printLvl=0, int solver=2, doublereal rtol=1.0e-9, int maxsteps=VCS_MAXSTEPS, int maxiter=100, int loglevel=-99) |
Set a multi-phase chemical solution to chemical equilibrium. More... | |
int | vcs_determine_PhaseStability (MultiPhase &s, int iphase, double &funcStab, int printLvl, int loglevel) |
Determine the phase stability of a single phase given the current conditions in a MultiPhase object. More... | |
std::ostream & | operator<< (std::ostream &s, const Cantera::Group &g) |
void | checkRxnElementBalance (Kinetics &kin, const ReactionData &rdata, doublereal errorTolerance=1.0e-3) |
This function will check a specific reaction to see if the elements balance. More... | |
bool | getReagents (const XML_Node &rxn, Kinetics &kin, int rp, std::string default_phase, std::vector< size_t > &spnum, vector_fp &stoich, vector_fp &order, const ReactionRules &rules) |
Get the reactants or products of a reaction. More... | |
static void | getArrhenius (const XML_Node &node, int &labeled, doublereal &A, doublereal &b, doublereal &E) |
getArrhenius() parses the xml element called Arrhenius. More... | |
static void | getStick (const XML_Node &node, Kinetics &kin, ReactionData &r, doublereal &A, doublereal &b, doublereal &E) |
getStick() processes the XML element called Stick that specifies the sticking coefficient reaction. More... | |
static void | getCoverageDependence (const XML_Node &node, thermo_t &surfphase, ReactionData &rdata) |
static void | getFalloff (const XML_Node &f, ReactionData &rdata) |
Get falloff parameters for a reaction. More... | |
static void | getEfficiencies (const XML_Node &eff, Kinetics &kin, ReactionData &rdata, const ReactionRules &rules) |
Get the enhanced collision efficiencies. More... | |
void | getRateCoefficient (const XML_Node &kf, Kinetics &kin, ReactionData &rdata, const ReactionRules &rules) |
Read the rate coefficient data from the XML file. More... | |
doublereal | isDuplicateReaction (std::map< int, doublereal > &r1, std::map< int, doublereal > &r2) |
This function returns a ratio if two reactions are duplicates of one another, and 0.0 otherwise. More... | |
bool | installReactionArrays (const XML_Node &p, Kinetics &kin, std::string default_phase, bool check_for_duplicates=false) |
Install information about reactions into the kinetics object, kin. More... | |
bool | importKinetics (const XML_Node &phase, std::vector< ThermoPhase * > th, Kinetics *kin) |
Import a reaction mechanism for a phase or an interface. More... | |
bool | buildSolutionFromXML (XML_Node &root, const std::string &id, const std::string &nm, ThermoPhase *th, Kinetics *k) |
Build a single-phase ThermoPhase object with associated kinetics mechanism. More... | |
string | reactionLabel (size_t i, size_t kr, size_t nr, const std::vector< size_t > &slist, const Kinetics &s) |
static doublereal | calc_damping (doublereal *x, doublereal *dx, size_t dim, int *) |
static doublereal | calcWeightedNorm (const doublereal[], const doublereal dx[], size_t) |
static doublereal | calc_damping (doublereal x[], doublereal dxneg[], size_t dim, int *label) |
ostream & | operator<< (std::ostream &s, const BandMatrix &m) |
Utility routine to print out the matrix. More... | |
static void | print_line (const char *str, int n) |
static void | print_time_step1 (int order, int n_time_step, double time, double delta_t_n, double delta_t_nm1, bool step_failed, int num_failures) |
static void | print_time_step2 (int time_step_num, int order, double time, double time_error_factor, double delta_t_n, double delta_t_np1) |
static void | print_time_fail (bool convFailure, int time_step_num, double time, double delta_t_n, double delta_t_np1, double time_error_factor) |
static void | print_final (double time, int step_failed, int time_step_num, int num_newt_its, int total_linear_solves, int numConvFails, int numTruncFails, int nfe, int nJacEval) |
static void | print_lvl1_Header (int nTimes) |
static void | print_lvl1_summary (int time_step_num, double time, const char *rslt, double delta_t_n, int newt_its, int aztec_its, int bktr_stps, double time_error_factor, const char *comment) |
double | subtractRD (doublereal a, doublereal b) |
This routine subtracts two numbers for one another. More... | |
DAE_Solver * | newDAE_Solver (const std::string &itype, ResidJacEval &f) |
Factor method for choosing a DAE solver. More... | |
int | solve (DenseMatrix &A, double *b) |
Solve Ax = b. Array b is overwritten on exit with x. More... | |
int | solve (DenseMatrix &A, DenseMatrix &b) |
Solve Ax = b for multiple right-hand-side vectors. More... | |
void | multiply (const DenseMatrix &A, const double *const b, double *const prod) |
Multiply A*b and return the result in prod . Uses BLAS routine DGEMV. More... | |
void | increment (const DenseMatrix &A, const double *const b, double *const prod) |
Multiply A*b and add it to the result in prod . Uses BLAS routine DGEMV. More... | |
int | invert (DenseMatrix &A, size_t nn=npos) |
invert A. A is overwritten with A^-1. More... | |
static bool | isConstant (Func1 &f) |
static bool | isZero (Func1 &f) |
static bool | isOne (Func1 &f) |
static bool | isTimesConst (Func1 &f) |
static bool | isExp (Func1 &f) |
static bool | isPow (Func1 &f) |
Func1 & | newSumFunction (Func1 &f1, Func1 &f2) |
Func1 & | newDiffFunction (Func1 &f1, Func1 &f2) |
Func1 & | newProdFunction (Func1 &f1, Func1 &f2) |
Func1 & | newRatioFunction (Func1 &f1, Func1 &f2) |
Func1 & | newCompositeFunction (Func1 &f1, Func1 &f2) |
Func1 & | newTimesConstFunction (Func1 &f, doublereal c) |
Func1 & | newPlusConstFunction (Func1 &f, doublereal c) |
doublereal | linearInterp (doublereal x, const vector_fp &xpts, const vector_fp &fpts) |
Linearly interpolate a function defined on a discrete grid. More... | |
doublereal | polyfit (int n, doublereal *x, doublereal *y, doublereal *w, int maxdeg, int &ndeg, doublereal eps, doublereal *r) |
Fits a polynomial function to a set of data points. More... | |
static void | print_line (const char *str, int n) |
Print a line of a single repeated character string. More... | |
Integrator * | newIntegrator (const std::string &itype) |
static void | print_funcEval (FILE *fp, doublereal xval, doublereal fval, int its) |
Print out a form for the current function evaluation. More... | |
static doublereal | calcWeightedNorm (const doublereal[], const doublereal dx[], size_t) |
void | drawline () |
static void | r_drawline () |
static void | sim1D_drawline () |
void | importSolution (size_t points, doublereal *oldSoln, IdealGasPhase &oldmech, size_t size_new, doublereal *newSoln, IdealGasPhase &newmech) |
Import a previous solution to use as an initial estimate. More... | |
static void | st_drawline () |
Nucleus * | HydrogenNucleus () |
Nucleus * | DeuteriumNucleus () |
Nucleus * | TritiumNucleus () |
Nucleus * | He3Nucleus () |
Nucleus * | He4Nucleus () |
Nucleus * | C12nucleus () |
Nucleus * | C13nucleus () |
Nucleus * | N14nucleus () |
Nucleus * | N15nucleus () |
Nucleus * | O16nucleus () |
Nucleus * | O17nucleus () |
Nucleus * | O18nucleus () |
Nucleus * | F19nucleus () |
static int | interp_est (const std::string &estString) |
Utility function to assign an integer value from a string for the ElectrolyteSpeciesType field. More... | |
doublereal | LookupWtElements (const std::string &ename) |
Function to look up an atomic weight This function looks up the argument string in the database above and returns the associated molecular weight. More... | |
static double | factorOverlap (const std::vector< std::string > &elnamesVN, const std::vector< double > &elemVectorN, const size_t nElementsN, const std::vector< std::string > &elnamesVI, const std::vector< double > &elemVectorI, const size_t nElementsI) |
Return the factor overlap. More... | |
void | installMu0ThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const XML_Node *Mu0Node_ptr) |
Install a Mu0 polynomial thermodynamic reference state. More... | |
static doublereal | JoyceDixon (doublereal r) |
static void | getSpeciesThermoTypes (std::vector< XML_Node * > &spDataNodeList, int &has_nasa, int &has_shomate, int &has_simple, int &has_other) |
Examine the types of species thermo parameterizations, and return a flag indicating the type of reference state thermo manager that will be needed in order to evaluate them all. More... | |
static void | installNasaThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const XML_Node *f0ptr, const XML_Node *f1ptr) |
Install a NASA polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
static doublereal | LookupGe (const std::string &elemName, ThermoPhase *th_ptr) |
Look up the elemental reference state entropies. More... | |
static doublereal | convertDGFormation (size_t k, ThermoPhase *th_ptr) |
Convert delta G formulation. More... | |
static void | installMinEQ3asShomateThermoFromXML (const std::string &speciesName, ThermoPhase *th_ptr, SpeciesThermo &sp, size_t k, const XML_Node *MinEQ3node) |
Install a NASA96 polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
static void | installShomateThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const XML_Node *f0ptr, const XML_Node *f1ptr) |
Install a Shomate polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
static void | installSimpleThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const XML_Node &f) |
Install a Simple thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
static void | installNasa9ThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const std::vector< XML_Node * > &tp) |
Install a NASA9 polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
static void | installStatMechThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, int k, const std::vector< XML_Node * > &tp) |
Install a stat mech based property solver for species k into a SpeciesThermo instance. More... | |
static void | installAdsorbateThermoFromXML (const std::string &speciesName, SpeciesThermo &sp, size_t k, const XML_Node &f) |
Install a Adsorbate polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance. More... | |
SpeciesThermo * | newSpeciesThermoMgr (int type, SpeciesThermoFactory *f=0) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it. More... | |
SpeciesThermo * | newSpeciesThermoMgr (std::string &stype, SpeciesThermoFactory *f=0) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it. More... | |
SpeciesThermo * | newSpeciesThermoMgr (std::vector< XML_Node * > spDataNodeList, SpeciesThermoFactory *f=0) |
Function to return SpeciesThermo manager. More... | |
std::string | eosTypeString (int ieos, int length=100) |
Translate the eosType id into a string. More... | |
ThermoPhase * | newPhase (XML_Node &phase) |
Create a new ThermoPhase object and initializes it according to the XML tree. More... | |
ThermoPhase * | newPhase (const std::string &infile, std::string id) |
Create and Initialize a ThermoPhase object from an XML input file. More... | |
static void | formSpeciesXMLNodeList (std::vector< XML_Node * > &spDataNodeList, std::vector< std::string > &spNamesList, std::vector< int > &spRuleList, const std::vector< XML_Node * > spArray_names, const std::vector< XML_Node * > spArray_dbases, const vector_int sprule) |
Gather a vector of pointers to XML_Nodes for a phase. More... | |
bool | importPhase (XML_Node &phase, ThermoPhase *th, SpeciesThermoFactory *spfactory=0) |
Import a phase information into an empty thermophase object. More... | |
bool | installSpecies (size_t k, const XML_Node &s, thermo_t &p, SpeciesThermo *spthermo_ptr, int rule, XML_Node *phaseNode_ptr=0, VPSSMgr *vpss_ptr=0, SpeciesThermoFactory *factory=0) |
Install a species into a ThermoPhase object, which defines the phase thermodynamics and speciation. More... | |
const XML_Node * | speciesXML_Node (const std::string &kname, const XML_Node *phaseSpeciesData) |
Search an XML tree for species data. More... | |
static void | getVPSSMgrTypes (std::vector< XML_Node * > &spDataNodeList, int &has_nasa_idealGas, int &has_nasa_constVol, int &has_shomate_idealGas, int &has_shomate_constVol, int &has_simple_idealGas, int &has_simple_constVol, int &has_water, int &has_tpx, int &has_hptx, int &has_other) |
Examine the types of species thermo parameterizations, and return a flag indicating the type of parameterization needed by the species. More... | |
VPSSMgr * | newVPSSMgr (VPSSMgr_enumType type, VPStandardStateTP *vp_ptr, VPSSMgrFactory *f=0) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it. More... | |
VPSSMgr * | newVPSSMgr (VPStandardStateTP *vp_ptr, XML_Node *phaseNode_ptr, std::vector< XML_Node * > &spDataNodeList, VPSSMgrFactory *f=0) |
Function to return VPSSMgr manager. More... | |
static void | getArrhenius (const XML_Node &node, doublereal &A, doublereal &b, doublereal &E) |
Parses the xml element called Arrhenius. More... | |
doublereal | quadInterp (doublereal x0, doublereal *x, doublereal *y) |
doublereal | Frot (doublereal tr, doublereal sqtr) |
The Parker temperature correction to the rotational collision number. More... | |
static void | err (const std::string &r) |
Transport * | newTransportMgr (const std::string &transportModel="", thermo_t *thermo=0, int loglevel=0, TransportFactory *f=0, int ndim=1) |
Create a new transport manager instance. More... | |
Transport * | newDefaultTransportMgr (thermo_t *thermo, int loglevel=0, TransportFactory *f=0) |
Create a new transport manager instance. More... | |
std::ostream & | operator<< (std::ostream &s, const Array2D &m) |
Output the current contents of the Array2D object. More... | |
void | operator*= (Array2D &m, doublereal a) |
Overload the times equals operator for multiplication of a matrix and a scalar. More... | |
void | operator+= (Array2D &x, const Array2D &y) |
Overload the plus equals operator for addition of one matrix with another. More... | |
void | writelog (const std::string &msg, int loglevel) |
Write a message to the log only if loglevel > 0. More... | |
template<class T > | |
T | clip (const T &value, const T &lower, const T &upper) |
Clip value such that lower <= value <= upper. More... | |
template<class V > | |
doublereal | dot4 (const V &x, const V &y) |
Templated Inner product of two vectors of length 4. More... | |
template<class V > | |
doublereal | dot5 (const V &x, const V &y) |
Templated Inner product of two vectors of length 5. More... | |
template<class V > | |
doublereal | dot6 (const V &x, const V &y) |
Templated Inner product of two vectors of length 6. More... | |
template<class InputIter , class InputIter2 > | |
doublereal | dot (InputIter x_begin, InputIter x_end, InputIter2 y_begin) |
Function that calculates a templated inner product. More... | |
template<class InputIter , class OutputIter , class S > | |
void | scale (InputIter begin, InputIter end, OutputIter out, S scale_factor) |
Multiply elements of an array by a scale factor. More... | |
template<class InputIter , class OutputIter , class S > | |
void | increment_scale (InputIter begin, InputIter end, OutputIter out, S scale_factor) |
template<class InputIter , class OutputIter > | |
void | multiply_each (OutputIter x_begin, OutputIter x_end, InputIter y_begin) |
Multiply each entry in x by the corresponding entry in y. More... | |
template<class InputIter > | |
void | resize_each (int m, InputIter begin, InputIter end) |
Invoke method 'resize' with argument m for a sequence of objects (templated version) More... | |
template<class InputIter > | |
doublereal | absmax (InputIter begin, InputIter end) |
The maximum absolute value (templated version) More... | |
template<class InputIter , class OutputIter > | |
void | normalize (InputIter begin, InputIter end, OutputIter out) |
Normalize the values in a sequence, such that they sum to 1.0 (templated version) More... | |
template<class InputIter , class OutputIter > | |
void | divide_each (OutputIter x_begin, OutputIter x_end, InputIter y_begin) |
Templated divide of each element of x by the corresponding element of y. More... | |
template<class InputIter , class OutputIter > | |
void | sum_each (OutputIter x_begin, OutputIter x_end, InputIter y_begin) |
Increment each entry in x by the corresponding entry in y. More... | |
template<class InputIter , class OutputIter , class IndexIter > | |
void | scatter_copy (InputIter begin, InputIter end, OutputIter result, IndexIter index) |
Copies a contiguous range in a sequence to indexed positions in another sequence. More... | |
template<class InputIter , class RandAccessIter , class IndexIter > | |
void | scatter_mult (InputIter mult_begin, InputIter mult_end, RandAccessIter data, IndexIter index) |
Multiply selected elements in an array by a contiguous sequence of multipliers. More... | |
template<class InputIter , class OutputIter , class IndexIter > | |
void | scatter_divide (InputIter begin, InputIter end, OutputIter result, IndexIter index) |
Divide selected elements in an array by a contiguous sequence of divisors. More... | |
template<class InputIter > | |
doublereal | sum_xlogx (InputIter begin, InputIter end) |
Compute
\[ \sum_k x_k \log x_k. \] . More... | |
template<class InputIter1 , class InputIter2 > | |
doublereal | sum_xlogQ (InputIter1 begin, InputIter1 end, InputIter2 Q_begin) |
Compute
\[ \sum_k x_k \log Q_k. \] . More... | |
template<class OutputIter > | |
void | scale (int N, double alpha, OutputIter x) |
Scale a templated vector by a constant factor. More... | |
template<class D , class R > | |
R | poly6 (D x, R *c) |
Templated evaluation of a polynomial of order 6. More... | |
template<class D , class R > | |
R | poly8 (D x, R *c) |
Templated evaluation of a polynomial of order 8. More... | |
template<class D , class R > | |
R | poly10 (D x, R *c) |
Templated evaluation of a polynomial of order 10. More... | |
template<class D , class R > | |
R | poly5 (D x, R *c) |
Templated evaluation of a polynomial of order 5. More... | |
template<class D , class R > | |
R | poly4 (D x, R *c) |
Evaluates a polynomial of order 4. More... | |
template<class D , class R > | |
R | poly3 (D x, R *c) |
Templated evaluation of a polynomial of order 3. More... | |
template<class D > | |
void | deepStdVectorPointerCopy (const std::vector< D * > &fromVec, std::vector< D * > &toVec) |
Templated deep copy of a std vector of pointers. More... | |
template<class T > | |
void | copyn (size_t n, const T &x, T &y) |
Templated function that copies the first n entries from x to y. More... | |
template<class T > | |
void | divide_each (T &x, const T &y) |
Divide each element of x by the corresponding element of y. More... | |
template<class T > | |
void | multiply_each (T &x, const T &y) |
Multiply each element of x by the corresponding element of y. More... | |
template<class T , class S > | |
void | scale (T &x, S scale_factor) |
Multiply each element of x by scale_factor. More... | |
template<class T > | |
doublereal | dot_product (const T &x, const T &y) |
Return the templated dot product of two objects. More... | |
template<class T > | |
doublereal | dot_ratio (const T &x, const T &y) |
Returns the templated dot ratio of two objects. More... | |
template<class T > | |
void | add_each (T &x, const T &y) |
Returns a templated addition operation of two objects. More... | |
template<class InputIter , class S > | |
doublereal | _dot_ratio (InputIter x_begin, InputIter x_end, InputIter y_begin, S start_value) |
Templated dot ratio class. More... | |
template<class T > | |
T | absmax (const std::vector< T > &v) |
Finds the entry in a vector with maximum absolute value, and return this value. More... | |
template<class T > | |
std::ostream & | operator<< (std::ostream &os, const std::vector< T > &v) |
Write a vector to a stream. More... | |
std::ostream & | operator<< (std::ostream &s, Cantera::MultiPhase &x) |
Function to output a MultiPhase description to a stream. More... | |
size_t | BasisOptimize (int *usedZeroedSpecies, bool doFormRxn, MultiPhase *mphase, std::vector< size_t > &orderVectorSpecies, std::vector< size_t > &orderVectorElements, vector_fp &formRxnMatrix) |
Choose the optimum basis of species for the equilibrium calculations. More... | |
size_t | ElemRearrange (size_t nComponents, const vector_fp &elementAbundances, MultiPhase *mphase, std::vector< size_t > &orderVectorSpecies, std::vector< size_t > &orderVectorElements) |
Handles the potential rearrangement of the constraint equations represented by the Formula Matrix. More... | |
Interface * | importInterface (const std::string &infile, const std::string &id, std::vector< Cantera::ThermoPhase * > phases) |
Import an instance of class Interface from a specification in an input file. More... | |
Kinetics * | newKineticsMgr (XML_Node &phase, std::vector< ThermoPhase * > th, KineticsFactory *f=0) |
Create a new kinetics manager. More... | |
Kinetics * | newKineticsMgr (const std::string &model, KineticsFactory *f=0) |
Create a new kinetics manager. More... | |
static doublereal | ppow (doublereal x, doublereal order) |
static std::string | fmt (const std::string &r, size_t n) |
template<class InputIter , class Vec1 , class Vec2 > | |
static void | _multiply (InputIter begin, InputIter end, const Vec1 &input, Vec2 &output) |
template<class InputIter , class Vec1 , class Vec2 > | |
static void | _incrementSpecies (InputIter begin, InputIter end, const Vec1 &input, Vec2 &output) |
template<class InputIter , class Vec1 , class Vec2 > | |
static void | _decrementSpecies (InputIter begin, InputIter end, const Vec1 &input, Vec2 &output) |
template<class InputIter , class Vec1 , class Vec2 > | |
static void | _incrementReactions (InputIter begin, InputIter end, const Vec1 &input, Vec2 &output) |
template<class InputIter , class Vec1 , class Vec2 > | |
static void | _decrementReactions (InputIter begin, InputIter end, const Vec1 &input, Vec2 &output) |
template<class InputIter > | |
static void | _writeIncrementSpecies (InputIter begin, InputIter end, const std::string &r, std::map< size_t, std::string > &out) |
template<class InputIter > | |
static void | _writeDecrementSpecies (InputIter begin, InputIter end, const std::string &r, std::map< size_t, std::string > &out) |
template<class InputIter > | |
static void | _writeIncrementReaction (InputIter begin, InputIter end, const std::string &r, std::map< size_t, std::string > &out) |
template<class InputIter > | |
static void | _writeDecrementReaction (InputIter begin, InputIter end, const std::string &r, std::map< size_t, std::string > &out) |
template<class InputIter > | |
static void | _writeMultiply (InputIter begin, InputIter end, const std::string &r, std::map< size_t, std::string > &out) |
void | ct_dgemv (ctlapack::storage_t storage, ctlapack::transpose_t trans, int m, int n, doublereal alpha, const doublereal *a, int lda, const doublereal *x, int incX, doublereal beta, doublereal *y, int incY) |
void | ct_dgbsv (int n, int kl, int ku, int nrhs, doublereal *a, int lda, integer *ipiv, doublereal *b, int ldb, int &info) |
void | ct_dgelss (size_t m, size_t n, size_t nrhs, doublereal *a, size_t lda, doublereal *b, size_t ldb, doublereal *s, doublereal rcond, size_t &rank, doublereal *work, int &lwork, int &info) |
void | ct_dgbtrf (size_t m, size_t n, size_t kl, size_t ku, doublereal *a, size_t lda, integer *ipiv, int &info) |
void | ct_dgbtrs (ctlapack::transpose_t trans, size_t n, size_t kl, size_t ku, size_t nrhs, doublereal *a, size_t lda, integer *ipiv, doublereal *b, size_t ldb, int &info) |
void | ct_dgetrf (size_t m, size_t n, doublereal *a, size_t lda, integer *ipiv, int &info) |
void | ct_dgetrs (ctlapack::transpose_t trans, size_t n, size_t nrhs, doublereal *a, size_t lda, integer *ipiv, doublereal *b, size_t ldb, int &info) |
void | ct_dgetri (int n, doublereal *a, int lda, integer *ipiv, doublereal *work, int lwork, int &info) |
void | ct_dscal (int n, doublereal da, doublereal *dx, int incx) |
void | ct_dgeqrf (size_t m, size_t n, doublereal *a, size_t lda, doublereal *tau, doublereal *work, size_t lwork, int &info) |
void | ct_dormqr (ctlapack::side_t rlside, ctlapack::transpose_t trans, size_t m, size_t n, size_t k, doublereal *a, size_t lda, doublereal *tau, doublereal *c, size_t ldc, doublereal *work, size_t lwork, int &info) |
void | ct_dtrtrs (ctlapack::upperlower_t uplot, ctlapack::transpose_t trans, const char *diag, size_t n, size_t nrhs, doublereal *a, size_t lda, doublereal *b, size_t ldb, int &info) |
doublereal | ct_dtrcon (const char *norm, ctlapack::upperlower_t uplot, const char *diag, size_t n, doublereal *a, size_t lda, doublereal *work, int *iwork, int &info) |
void | ct_dpotrf (ctlapack::upperlower_t uplot, size_t n, doublereal *a, size_t lda, int &info) |
void | ct_dpotrs (ctlapack::upperlower_t uplot, size_t n, size_t nrhs, doublereal *a, size_t lda, doublereal *b, size_t ldb, int &info) |
doublereal | ct_dgecon (const char norm, size_t n, doublereal *a, size_t lda, doublereal anorm, doublereal *work, int *iwork, int &info) |
doublereal | ct_dgbcon (const char norm, size_t n, size_t kl, size_t ku, doublereal *a, size_t ldab, int *ipiv, doublereal anorm, doublereal *work, int *iwork, int &info) |
doublereal | ct_dlange (const char norm, size_t m, size_t n, doublereal *a, size_t lda, doublereal *work) |
doublereal | hz_to_wnum (doublereal freq) |
convert from Hz to wavenmbers More... | |
doublereal | wnum_to_J (doublereal w) |
Convert from wavenumbers to Joules. More... | |
doublereal | J_to_wnum (doublereal e) |
doublereal | wnum_to_eV (doublereal w) |
doublereal | eV_to_wnum (doublereal e) |
ThermoPhase * | newThermoPhase (const std::string &model, ThermoFactory *f=0) |
Create a new thermo manager instance. More... | |
ReactorBase * | newReactor (const std::string &model, ReactorFactory *f=0) |
Variables | |
static mutex_t | dir_mutex |
Mutex for input directory access. More... | |
static mutex_t | app_mutex |
Mutex for creating singletons within the application object. More... | |
static mutex_t | xml_mutex |
Mutex for controlling access to XML file storage. More... | |
static mutex_t | msg_mutex |
Mutex for access to string messages. More... | |
static const char * | stars = "***********************************************************************\n" |
const int | g_DEBUG_MODE = 0 |
Definition of whether the DEBUG_MODE environment is turned on within Cantera. More... | |
int | BasisOptimize_print_lvl = 0 |
External int that is used to turn on debug printing for the BasisOptimze program. More... | |
static int | ntypes = 6 |
static string | _types [] = {"none", "GasKinetics", "GRI30", "Interface", "Edge", "AqueousKinetics"} |
static int | _itypes [] = {0, cGasKinetics, cGRI30, cInterfaceKinetics, cEdgeKinetics, cAqueousKinetics} |
const double | DampFactor = 4 |
Dampfactor is the factor by which the damping factor is reduced by when a reduction in step length is warranted. More... | |
const int | NDAMP = 10 |
Number of damping steps that are carried out before the solution is deemed a failure. More... | |
const string | dashedline |
static struct awData | aWTable [] |
aWTable is a vector containing the atomic weights database. More... | |
const doublereal | JD_const1 = 1.0/sqrt(8.0) |
const doublereal | JD_const2 = 3.0/16.0 - sqrt(3.0)/9.0 |
static int | ntypes = 26 |
Define the number of ThermoPhase types for use in this factory routine. More... | |
static string | _types [] |
Define the string name of the ThermoPhase types that are handled by this factory routine. More... | |
static int | _itypes [] |
Define the integer id of the ThermoPhase types that are handled by this factory routine. More... | |
const doublereal | T_c = 647.096 |
Critical Temperature value (kelvin) More... | |
static const doublereal | P_c = 22.064E6 |
Critical Pressure (Pascals) More... | |
const doublereal | Rho_c = 322. |
Value of the Density at the critical point (kg m-3) More... | |
static const doublereal | M_water = 18.015268 |
Molecular Weight of water that is consistent with the paper (kg kmol-1) More... | |
static const doublereal | Rgas = 8.314371E3 |
Gas constant that is quoted in the paper. More... | |
const doublereal | Min_C_Internal = 0.001 |
Constant to compare dimensionless heat capacities against zero. More... | |
const int | DeltaDegree = 6 |
static int | ntypes = 6 |
static string | _types [] |
static int | _itypes [] |
const doublereal | Pi = 3.14159265358979323846 |
Pi. More... | |
const doublereal | SqrtPi = std::sqrt(Pi) |
sqrt(Pi) More... | |
const doublereal | OneThird = 1.0/3.0 |
1/3 More... | |
const doublereal | FiveSixteenths = 5.0/16.0 |
5/16 More... | |
const doublereal | SqrtTen = std::sqrt(10.0) |
sqrt(10) More... | |
const doublereal | SqrtEight = std::sqrt(8.0) |
sqrt(8) More... | |
const doublereal | SqrtTwo = std::sqrt(2.0) |
sqrt(2) More... | |
const doublereal | SmallNumber = 1.e-300 |
smallest number to compare to zero. More... | |
const doublereal | BigNumber = 1.e300 |
largest number to compare to inf. More... | |
const doublereal | MaxExp = 690.775527898 |
largest x such that exp(x) is valid More... | |
const doublereal | Undef = -999.1234 |
Fairly random number to be used to initialize variables against to see if they are subsequently defined. More... | |
const doublereal | Tiny = 1.e-20 |
Small number to compare differences of mole fractions against. More... | |
const size_t | npos = static_cast<size_t>(-1) |
index returned by functions to indicate "no position" More... | |
int | ChemEquil_print_lvl = 0 |
const int | cGRI_30_Kinetics = cGasKinetics + 1 |
const int | NONE = 0 |
const int | cDirect = 0 |
const int | cKrylov = 1 |
const int | FourierFuncType = 1 |
const int | PolyFuncType = 2 |
const int | ArrheniusFuncType = 3 |
const int | GaussianFuncType = 4 |
const int | SumFuncType = 20 |
const int | DiffFuncType = 25 |
const int | ProdFuncType = 30 |
const int | RatioFuncType = 40 |
const int | PeriodicFuncType = 50 |
const int | CompositeFuncType = 60 |
const int | TimesConstantFuncType = 70 |
const int | PlusConstantFuncType = 80 |
const int | SinFuncType = 100 |
const int | CosFuncType = 102 |
const int | ExpFuncType = 104 |
const int | PowFuncType = 106 |
const int | ConstFuncType = 110 |
const int | DIAG = 1 |
const int | DENSE = 2 |
const int | NOJAC = 4 |
const int | JAC = 8 |
const int | GMRES =16 |
const int | BAND =32 |
const int | c_NONE = 0 |
const int | c_GE_ZERO = 1 |
const int | c_GT_ZERO = 2 |
const int | c_LE_ZERO = -1 |
const int | c_LT_ZERO = -2 |
const int | cFlowType = 50 |
const int | cConnectorType = 100 |
const int | cSurfType = 102 |
const int | cInletType = 104 |
const int | cSymmType = 105 |
const int | cOutletType = 106 |
const int | cEmptyType = 107 |
const int | cOutletResType = 108 |
const int | cPorousType = 109 |
const int | LeftInlet = 1 |
const int | RightInlet = -1 |
const size_t | c_offset_U = 0 |
const size_t | c_offset_V = 1 |
const size_t | c_offset_T = 2 |
const size_t | c_offset_L = 3 |
const size_t | c_offset_Y = 4 |
const int | c_Mixav_Transport = 0 |
const int | c_Multi_Transport = 1 |
const int | c_Soret = 2 |
const int | cEST_solvent = 0 |
Electrolyte species type. More... | |
const int | cEST_chargedSpecies = 1 |
const int | cEST_weakAcidAssociated = 2 |
const int | cEST_strongAcidAssociated = 3 |
const int | cEST_polarNeutral = 4 |
const int | cEST_nonpolarNeutral = 5 |
const int | cHMWSoln0 = 45010 |
eosTypes returned for this ThermoPhase Object More... | |
const int | cHMWSoln1 = 45011 |
const int | cHMWSoln2 = 45012 |
const int | cDebyeHuckel0 = 46010 |
eosTypes returned for this ThermoPhase Object More... | |
const int | cDebyeHuckel1 = 46011 |
const int | cDebyeHuckel2 = 46012 |
const int | cNone = 0 |
This generic id is used as the default in virtual base classes that employ id's. More... | |
const int | cNASA = 1 |
const int | cShomate = 2 |
const int | cNASA96 = 3 |
const int | cHarmonicOsc = 4 |
const int | cIdealGas = 1 |
Equation of state types: More... | |
const int | cIncompressible = 2 |
const int | cSurf = 3 |
A surface phase. Used by class SurfPhase. More... | |
const int | cMetal = 4 |
A metal phase. More... | |
const int | cStoichSubstance = 5 |
const int | cSemiconductor = 7 |
const int | cMineralEQ3 = 8 |
const int | cMetalSHEelectrons = 9 |
const int | cLatticeSolid = 20 |
const int | cLattice = 21 |
const int | cPureFluid = 10 |
const int | cEdge = 6 |
An edge between two 2D surfaces. More... | |
const int | cFixedChemPot = 70 |
Stoichiometric compound with a constant chemical potential. More... | |
const int | cIdealSolidSolnPhase = 5009 |
Constant partial molar volume solution IdealSolidSolnPhase.h. More... | |
const int | cHMW = 40 |
HMW - Strong electrolyte using the Pitzer formulation. More... | |
const int | cDebyeHuckel = 50 |
DebyeHuckel - Weak electrolyte using various Debye-Huckel formulations. More... | |
const int | cIdealMolalSoln = 60 |
IdealMolalSoln - molality based solution with molality-based act coeffs of 1. More... | |
const int | cIdealSolnGasVPSS = 500 |
const int | cIdealSolnGasVPSS_iscv = 501 |
const int | cMixtureFugacityTP = 700 |
Fugacity Models. More... | |
const int | cRedlichKwongMFTP = 701 |
const int | cMargulesVPSSTP = 301 |
const int | cRedlichKisterVPSSTP = 303 |
const int | cMolarityIonicVPSSTP = 401 |
const int | cMixedSolventElectrolyte = 402 |
const int | cPhaseCombo_Interaction = 305 |
const int | cIonsFromNeutral = 2000 |
const int | cVPSS_IdealGas = 1001 |
Variable Pressure Standard State ThermoPhase objects. More... | |
const int | cVPSS_ConstVol = 1002 |
const int | cVPSS_PureFluid = 1010 |
const int | cVPSS_HMW = 1040 |
const int | cVPSS_DebyeHuckel = 1050 |
const int | cVPSS_MolalSoln = 1060 |
const int | cGasKinetics = 2 |
const int | cGRI30 = 3 |
const int | cInterfaceKinetics = 4 |
const int | cLineKinetics = 5 |
const int | cEdgeKinetics = 6 |
const int | cSolidKinetics = 7 |
const int | cAqueousKinetics = 8 |
const int | PHSCALE_PITZER = 0 |
Scale to be used for the output of single-ion activity coefficients is that used by Pitzer. More... | |
const int | PHSCALE_NBS = 1 |
Scale to be used for evaluation of single-ion activity coefficients is that used by the NBS standard for evaluation of the pH variable. More... | |
const int | cElectron = 0 |
const int | cHole = 1 |
const VelocityBasis | VB_MASSAVG = -1 |
Diffusion velocities are based on the mass averaged velocity. More... | |
const VelocityBasis | VB_MOLEAVG = -2 |
Diffusion velocities are based on the mole averaged velocities. More... | |
const VelocityBasis | VB_SPECIES_0 = 0 |
Diffusion velocities are based on the relative motion wrt species 0. More... | |
const VelocityBasis | VB_SPECIES_1 = 1 |
Diffusion velocities are based on the relative motion wrt species 1. More... | |
const VelocityBasis | VB_SPECIES_2 = 2 |
Diffusion velocities are based on the relative motion wrt species 2. More... | |
const VelocityBasis | VB_SPECIES_3 = 3 |
Diffusion velocities are based on the relative motion wrt species 3. More... | |
const int | MFC_Type = 1 |
const int | PressureController_Type = 2 |
const int | Valve_Type = 3 |
const int | ReservoirType = 1 |
const int | ReactorType = 2 |
const int | FlowReactorType = 3 |
const int | ConstPressureReactorType = 4 |
const int | IdealGasReactorType = 5 |
const int | IdealGasConstPressureReactorType = 6 |
Variations of the Gas Constant | |
Cantera uses the MKS system of units. The unit for moles is defined to be the kmol. | |
const doublereal | Avogadro = 6.02214129e26 |
Avogadro's Number [number/kmol]. More... | |
const doublereal | GasConstant = 8314.4621 |
Universal Gas Constant. [J/kmol/K]. More... | |
const doublereal | logGasConstant = std::log(GasConstant) |
const doublereal | OneAtm = 1.01325e5 |
One atmosphere [Pa]. More... | |
const doublereal | OneBar = 1.0E5 |
const doublereal | GasConst_cal_mol_K = GasConstant / 4184.0 |
Universal gas constant in cal/mol/K. More... | |
const doublereal | Boltzmann = GasConstant / Avogadro |
Boltzmann's constant [J/K]. More... | |
const doublereal | Planck = 6.62607009e-34 |
Planck's constant. [J-s]. More... | |
const doublereal | Planck_bar = Planck / (2 * Pi) |
const doublereal | logBoltz_Planck = std::log(Boltzmann / Planck) |
log(k/h) More... | |
const doublereal | StefanBoltz = 5.670373e-8 |
Stefan-Boltzmann constant. More... | |
Electron Properties | |
const doublereal | ElectronCharge = 1.602176565e-19 |
const doublereal | ElectronMass = 9.10938291e-31 |
const doublereal | Faraday = ElectronCharge * Avogadro |
Electromagnetism | |
Cantera uses the MKS unit system. | |
const doublereal | lightSpeed = 299792458.0 |
Speed of Light (m/s). More... | |
const doublereal | permeability_0 = 4.0e-7*Pi |
Permeability of free space \( \mu_0 \) in N/A^2. More... | |
const doublereal | epsilon_0 = 1.0 / (lightSpeed*lightSpeed*permeability_0) |
Permittivity of free space \( \epsilon_0 \) in F/m. More... | |
Thermodynamic Equilibrium Constraints | |
Integer numbers representing pairs of thermodynamic variables which are held constant during equilibration. | |
const int | TV = 100 |
const int | HP = 101 |
const int | SP = 102 |
const int | PV = 103 |
const int | TP = 104 |
const int | UV = 105 |
const int | ST = 106 |
const int | SV = 107 |
const int | UP = 108 |
const int | VH = 109 |
const int | TH = 110 |
const int | SH = 111 |
const int | PX = 112 |
const int | TX = 113 |
const int | VT = -100 |
const int | PH = -101 |
const int | PS = -102 |
const int | VP = -103 |
const int | PT = -104 |
const int | VU = -105 |
const int | TS = -106 |
const int | VS = -107 |
const int | PU = -108 |
const int | HV = -109 |
const int | HT = -110 |
const int | HS = -111 |
const int | XP = -112 |
const int | XT = -113 |
Reaction Types | |
const int | ELEMENTARY_RXN = 1 |
A reaction with a rate coefficient that depends only on temperature. More... | |
const int | THREE_BODY_RXN = 2 |
A reaction that requires a third-body collision partner. More... | |
const int | FALLOFF_RXN = 4 |
The general form for an association or dissociation reaction, with a pressure-dependent rate. More... | |
const int | PLOG_RXN = 5 |
A pressure-dependent rate expression consisting of several Arrhenius rate expressions evaluated at different pressures. More... | |
const int | CHEBYSHEV_RXN = 6 |
A general pressure-dependent reaction where k(T,P) is defined in terms of a bivariate Chebyshev polynomial. More... | |
const int | CHEMACT_RXN = 8 |
A chemical activation reaction. More... | |
const int | SURFACE_RXN = 20 |
A reaction occurring on a surface. More... | |
const int | EDGE_RXN = 22 |
A reaction occurring at a one-dimensional interface between two surface phases. More... | |
const int | GLOBAL_RXN = 30 |
A global reaction. More... | |
Rate Coefficient Types | |
These types define the supported rate coefficient types for elementary reactions. Any of these may also be used as the high and low-pressure limits of falloff and chemical activation reactions. Note that not all of these are currently implemented!
| |
const int | ARRHENIUS_REACTION_RATECOEFF_TYPE = 1 |
const int | LANDAUTELLER_REACTION_RATECOEFF_TYPE = 2 |
const int | TSTRATE_REACTION_RATECOEFF_TYPE = 3 |
const int | SURF_ARRHENIUS_REACTION_RATECOEFF_TYPE = 4 |
const int | ARRHENIUS_SUM_REACTION_RATECOEFF_TYPE = 5 |
const int | EXCHANGE_CURRENT_REACTION_RATECOEFF_TYPE = 6 |
const int | PLOG_REACTION_RATECOEFF_TYPE = 7 |
const int | CHEBYSHEV_REACTION_RATECOEFF_TYPE = 8 |
Falloff Function Types | |
const int | SIMPLE_FALLOFF = 100 |
const int | TROE3_FALLOFF = 110 |
const int | TROE4_FALLOFF = 111 |
const int | SRI3_FALLOFF = 112 |
const int | SRI5_FALLOFF = 113 |
const int | WF_FALLOFF = 114 |
CONSTANTS - Models for the Standard State of IdealSolidSolnPhase's | |
const int | cIdealSolidSolnPhase0 = 5010 |
const int | cIdealSolidSolnPhase1 = 5011 |
const int | cIdealSolidSolnPhase2 = 5012 |
CONSTANTS | |
Models for the Standard State of an IdealSolnPhase | |
const int | cIdealSolnGasPhaseG = 6009 |
const int | cIdealSolnGasPhase0 = 6010 |
const int | cIdealSolnGasPhase1 = 6011 |
const int | cIdealSolnGasPhase2 = 6012 |
CONSTANTS - Specification of the Molality convention | |
const int | cAC_CONVENTION_MOLAR = 0 |
Standard state uses the molar convention. More... | |
const int | cAC_CONVENTION_MOLALITY = 1 |
Standard state uses the molality convention. More... | |
CONSTANTS - Specification of the SS convention | |
const int | cSS_CONVENTION_TEMPERATURE = 0 |
Standard state uses the molar convention. More... | |
const int | cSS_CONVENTION_VPSS = 1 |
Standard state uses the molality convention. More... | |
const int | cSS_CONVENTION_SLAVE = 2 |
Standard state thermodynamics is obtained from slave ThermoPhase objects. More... | |
const int | LVISC_CONSTANT = 0 |
const int | LVISC_WILKES = 1 |
const int | LVISC_MIXTUREAVG = 2 |
const int | LDIFF_MIXDIFF_UNCORRECTED = 0 |
const int | LDIFF_MIXDIFF_FLUXCORRECTED = 1 |
const int | LDIFF_MULTICOMP_STEFANMAXWELL = 2 |
Namespace for the Cantera kernel.
Namespace for classes implementing zero-dimensional reactor networks.
Namespace for spectroscopic functions and classes.
typedef std::map<std::string, doublereal> compositionMap |
typedef std::vector<double> vector_fp |
typedef std::vector<int> vector_int |
typedef std::vector<std::vector<size_t> > grouplist_t |
typedef ThermoPhase thermo_t |
typedef for the ThermoPhase class
Definition at line 1684 of file ThermoPhase.h.
enum MethodType |
Specifies the method used to integrate the system of equations.
Not all methods are supported by all integrators.
Enumerator | |
---|---|
BDF_Method |
Backward Differentiation. |
Adams_Method |
Adams. |
Definition at line 32 of file Integrator.h.
enum IterType |
Specifies the method used for iteration.
Not all methods are supported by all integrators.
Enumerator | |
---|---|
Newton_Iter |
Newton Iteration. |
Functional_Iter |
Functional Iteration. |
Definition at line 41 of file Integrator.h.
enum ResidEval_Type_Enum |
Differentiates the type of residual evaluations according to functionality.
Definition at line 24 of file ResidJacEval.h.
enum IonSolnType_enumType |
enums for molten salt ion solution types
Types identify how complicated the solution is. If there is just mixing on one of the sublattices but not the other, then the math is considerably simpler.
Definition at line 33 of file IonsFromNeutralVPSSTP.h.
Types of general formulations for the specification of the standard state volume.
Definition at line 102 of file mix_defs.h.
enum PDSS_enumType |
Types of PDSS's.
Definition at line 119 of file mix_defs.h.
enum VPSSMgr_enumType |
enum for VPSSMgr types that are responsible for calculating the species standard state and reference-state thermodynamic properties.
Definition at line 133 of file mix_defs.h.
Composition dependence type for liquid mixture transport properties.
Types of temperature dependencies:
* <transport model="Liquid"> * <viscosity> * <compositionDependence model="logMoleFractions"> * <interaction> * <speciesA> LiCl(L) </speciesA> * <speciesB> KCl(L) </speciesB> * <Eij units="J/kmol"> -1.0 </Eij> * <Sij units="J/kmol/K"> 1.0E-1 </Sij> * -or- <Sij> * <floatArray units="J/kmol/K"> 1.0E-1, 0.001 0.01 </floatArray> * </Sij> * -same form for Hij,Aij,Bij- * </interaction> * </compositionDependence> * </viscosity> * <speciesDiffusivity> * <compositionDependence model="pairwiseInteraction"> * <interaction> * <speciesA> Li+ </speciesA> * <speciesB> K+ </speciesB> * <Dij units="m2/s"> 1.5 </Dij> * </interaction> * <interaction> * <speciesA> K+ </speciesA> * <speciesB> Cl- </speciesB> * <Dij units="m2/s"> 1.0 </Dij> * </interaction> * <interaction> * <speciesA> Li+ </speciesA> * <speciesB> Cl- </speciesB> * <Dij units="m2/s"> 1.2 </Dij> * </interaction> * </compositionDependence> * </speciesDiffusivity> * <thermalConductivity> * <compositionDependence model="massFractions"/> * </thermalConductivity> * <hydrodynamicRadius> * <compositionDependence model="none"/> * </hydrodynamicRadius> * </transport> *
Definition at line 73 of file LiquidTranInteraction.h.
Enumeration of the types of transport properties that can be handled by the variables in the various Transport classes.
Not all of these are handled by each class and each class should handle exceptions where the transport property is not handled.
Transport properties currently on the list
0 - viscosity 1 - Ionic conductivity 2 - Mobility Ratio 3 - Self Diffusion coefficient 4 - Thermal conductivity 5 - species diffusivity 6 - hydrodynamic radius 7 - electrical conductivity
Definition at line 32 of file LTPspecies.h.
Temperature dependence type for pure (liquid) species properties.
Types of temperature dependencies: 0 - Independent of temperature 1 - extended arrhenius form 2 - polynomial in temperature form 3 - exponential temperature polynomial
Definition at line 54 of file LTPspecies.h.
void checkFinite | ( | const double | tmp | ) |
Check to see that a number is finite (not NaN, +Inf or -Inf)
Definition at line 33 of file checkFinite.cpp.
Referenced by NonlinearSolver::beuler_jac(), NonlinearSolver::computeResidWts(), BEulerInt::dampStep(), NonlinearSolver::doCauchyPointSolve(), RootFind::func(), NonlinearSolver::residErrorNorm(), NonlinearSolver::scaleMatrix(), and VCS_SOLVE::vcs_deltag().
|
static |
Return a pointer to the application object.
Definition at line 27 of file global.cpp.
Referenced by addDirectory(), addLogEntry(), beginLogGroup(), close_XML_File(), endLogGroup(), error(), findInputFile(), get_XML_File(), lastErrorMessage(), nErrors(), popError(), setError(), setLogger(), showErrors(), suppress_deprecation_warnings(), thread_complete(), warn_deprecated(), write_logfile(), writelog(), and writelogendl().
void setLogger | ( | Logger * | logwriter | ) |
Install a logger.
Called by the language interfaces to install an appropriate logger. The logger is used for the writelog() function
logwriter | Pointer to a logger object |
Definition at line 34 of file global.cpp.
References app(), Logger::error(), and Application::setLogger().
void writelog | ( | const std::string & | msg | ) |
Write a message to the screen.
The string may be of any length, and may contain end-of-line characters. This method is used throughout Cantera to write log messages. It can also be called by user programs. The advantage of using writelog over writing directly to the standard output is that messages written with writelog will display correctly even when Cantera is used from MATLAB or other application that do not have a standard output stream.
msg | c++ string to be written to the screen |
Definition at line 43 of file global.cpp.
References app(), and Application::writelog().
Referenced by Bdry1D::_getInitialSoln(), ReactorNet::addReactor(), InterfaceKinetics::applyButlerVolmerCorrection(), BasisOptimize(), NasaThermo::checkContinuity(), ctml::ck2cti(), ctml::ct2ctml(), MultiNewton::dampStep(), ChemEquil::dampStep(), ElemRearrange(), ChemEquil::equilibrate(), ChemEquil::equilResidual(), ChemEquil::estimateElementPotentials(), ChemEquil::estimateEP_Brinkley(), ctml::get_CTML_Tree(), ctml::getFloatArray(), ctml::getFloatCurrent(), ctml::getFloats(), FlowReactor::getInitialConditions(), ctml::getInteger(), ChemEquil::initialize(), ReactorNet::initialize(), PureFluidPhase::initThermo(), NasaThermo::install(), SimpleThermo::install(), ShomateThermo::install(), RedlichKwongMFTP::NicholsSolve(), LogPrintCtrl::pr_de(), LogPrintCtrl::pr_de_c10(), print_stringTrunc(), Sim1D::refine(), Sim1D::restore(), StFlow::restore(), Domain1D::restore(), ChemEquil::setInitialMoles(), Inlet1D::showSolution(), StFlow::showSolution(), Surf1D::showSolution(), ReactingSurf1D::showSolution(), Domain1D::showSolution(), MultiNewton::solve(), RootFind::solve(), OneDim::timeStep(), writelog(), writelogf(), and OneDim::writeStats().
void writelogendl | ( | ) |
Write an end of line character to the screen and flush output.
Definition at line 66 of file global.cpp.
References app(), and Application::writelogendl().
Referenced by RedlichKwongMFTP::NicholsSolve().
void error | ( | const std::string & | msg | ) |
Write an error message and quit.
The default behavior is to write to the standard error stream, and then call exit(). Note that no end-of-line character is appended to the message, and so if one is desired it must be included in the string. Note that this default behavior will terminate the application Cantera is invoked from (MATLAB, Excel, etc.) If this is not desired, then derive a class and reimplement this method.
msg | Error message to be written to cerr. |
Definition at line 71 of file global.cpp.
References app(), and Application::logerror().
Referenced by NonlinearSolver::calcSolnToResNormVector(), ReactorNet::evalJacobian(), NonlinearSolver::print_solnDelta_norm_contrib(), NonlinearSolver::residErrorNorm(), BEulerInt::soln_error_norm(), NonlinearSolver::solnErrorNorm(), and BEulerInt::time_error_norm().
void warn_deprecated | ( | const std::string & | method, |
const std::string & | extra = "" |
||
) |
Print a warning indicating that method is deprecated.
Additional information (removal version, alternatives) can be specified in extra. Deprecation warnings are printed once per method per invocation of the application.
Definition at line 76 of file global.cpp.
References app(), and Application::warn_deprecated().
Referenced by AqueousKinetics::AqueousKinetics(), Application::Messages::beginLogGroup(), CVodesIntegrator::CVodesIntegrator(), Elements::Elements(), InterfaceKinetics::getActivationEnergies(), ctml::getFloats(), ConstDensityThermo::getParameters(), StoichSubstance::getParameters(), MineralEQ3::getParameters(), StoichSubstanceSSTP::getParameters(), MetalSHEelectrons::getParameters(), FixedChemPotSSTP::getParameters(), SingleSpeciesTP::getParameters(), IdealMolalSoln::getParameters(), LatticePhase::getParameters(), DebyeHuckel::getParameters(), ThermoPhase::getParameters(), HMWSoln::getParameters(), GRI_30_Kinetics::GRI_30_Kinetics(), Adsorbate::install(), LineBroadener::LineBroadener(), LogPrintCtrl::LogPrintCtrl(), Nasa9Poly1::modifyParameters(), NasaPoly1::modifyParameters(), Nasa9PolyMultiTempRegion::modifyParameters(), ShomatePoly::modifyParameters(), STITbyPDSS::modifyParameters(), ShomatePoly2::modifyParameters(), PrintCtrl::PrintCtrl(), Adsorbate::reportParameters(), StatMech::reportParameters(), Mu0Poly::reportParameters(), NasaPoly2::reportParameters(), NasaPoly1::reportParameters(), Nasa9Poly1::reportParameters(), Nasa9PolyMultiTempRegion::reportParameters(), ShomatePoly::reportParameters(), STITbyPDSS::reportParameters(), ShomatePoly2::reportParameters(), GeneralSpeciesThermo::reportParams(), NasaThermo::reportParams(), PDSS_HKFT::reportParams(), ShomateThermo::reportParams(), Rotor::Rotor(), Domain1D::setBounds(), SolidTransport::setParameters(), DustyGasTransport::setParameters(), ConstDensityThermo::setParameters(), SurfPhase::setParameters(), StoichSubstance::setParameters(), MineralEQ3::setParameters(), StoichSubstanceSSTP::setParameters(), MetalSHEelectrons::setParameters(), electrodeElectron::setParameters(), FixedChemPotSSTP::setParameters(), SingleSpeciesTP::setParameters(), IdealMolalSoln::setParameters(), LatticePhase::setParameters(), DebyeHuckel::setParameters(), ThermoPhase::setParameters(), HMWSoln::setParameters(), StFlow::setState(), Domain1D::setTolerances(), Domain1D::setTolerancesSS(), Domain1D::setTolerancesTS(), VPSSMgr::standardVolumes(), stripLTWScstring(), WF93::WF93(), and Application::Messages::write_logfile().
void suppress_deprecation_warnings | ( | ) |
Globally disable printing of deprecation warnings.
Used primarily to prevent certain tests from failing.
Definition at line 81 of file global.cpp.
References app(), and Application::suppress_deprecation_warnings().
void beginLogGroup | ( | const std::string & | title, |
int | loglevel = -99 |
||
) |
Create a new group for log messages.
Usually this is called upon entering the function, with the title parameter equal to the name of the function or method. Subsequent messages written with addLogEntry will appear grouped under this heading, until endLogGroup() is called.
title | String name of the LogGroup |
loglevel | loglevel of the group. |
Definition at line 90 of file global.cpp.
References app(), and Application::beginLogGroup().
Referenced by vcs_MultiPhaseEquil::determine_PhaseStability(), equilibrate(), ChemEquil::equilibrate(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), vcs_MultiPhaseEquil::equilibrate_TP(), vcs_MultiPhaseEquil::equilibrate_TV(), ChemEquil::equilResidual(), ChemEquil::estimateElementPotentials(), MultiPhaseEquil::setInitialMoles(), ChemEquil::setInitialMoles(), MultiPhaseEquil::stepComposition(), vcs_determine_PhaseStability(), vcs_equilibrate(), and vcs_equilibrate_1().
void addLogEntry | ( | const std::string & | tag, |
const std::string & | value | ||
) |
Add an entry to an HTML log file.
Entries appear in the form "tag:value".
tag | tag |
value | string value |
Definition at line 95 of file global.cpp.
References Application::addLogEntry(), and app().
Referenced by vcs_MultiPhaseEquil::determine_PhaseStability(), equilibrate(), ChemEquil::equilibrate(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), vcs_MultiPhaseEquil::equilibrate_TP(), vcs_MultiPhaseEquil::equilibrate_TV(), ChemEquil::equilResidual(), ChemEquil::estimateElementPotentials(), ChemEquil::estimateEP_Brinkley(), MultiPhaseEquil::setInitialMoles(), ChemEquil::setInitialMoles(), MultiPhaseEquil::stepComposition(), vcs_determine_PhaseStability(), vcs_equilibrate(), and vcs_equilibrate_1().
void addLogEntry | ( | const std::string & | tag, |
doublereal | value | ||
) |
Add an entry to an HTML log file.
Entries appear in the form "tag:value".
tag | tag |
value | double value |
Definition at line 100 of file global.cpp.
References Application::addLogEntry(), and app().
void addLogEntry | ( | const std::string & | tag, |
int | value | ||
) |
Add an entry to an HTML log file.
Entries appear in the form "tag:value".
tag | tag |
value | integer value |
Definition at line 105 of file global.cpp.
References Application::addLogEntry(), and app().
void addLogEntry | ( | const std::string & | msg | ) |
Add an entry to an HTML log file.
Entries appear in the form "msg".
msg | Message to be added |
Definition at line 110 of file global.cpp.
References Application::addLogEntry(), and app().
void endLogGroup | ( | const std::string & | title = "" | ) |
Close the current group of log messages.
This is typically called just before leaving a function or method, to close the group of messages that were output from this function. Subsequent messages written with addLogEntry() will appear at the next-higher level in the outline, unless beginLogGroup() is called first to create a new group.
title | Name of the log group. It defaults to the most recent log group created. |
Definition at line 115 of file global.cpp.
References app(), and Application::endLogGroup().
Referenced by vcs_MultiPhaseEquil::determine_PhaseStability(), equilibrate(), ChemEquil::equilibrate(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), vcs_MultiPhaseEquil::equilibrate_TP(), vcs_MultiPhaseEquil::equilibrate_TV(), ChemEquil::equilResidual(), ChemEquil::estimateElementPotentials(), MultiPhaseEquil::setInitialMoles(), ChemEquil::setInitialMoles(), MultiPhaseEquil::stepComposition(), vcs_determine_PhaseStability(), vcs_equilibrate(), and vcs_equilibrate_1().
void write_logfile | ( | const std::string & | file = "log.html" | ) |
Write the HTML log file.
Log entries are stored in memory in an XML tree until this function is called, which writes the tree to a file and clears the entries stored in memory. The output file will have the name specified in the 'file' argument. If this argument has no extension, the extension '.html' will be appended. Also, if the file already exists, an integer will be appended to the name so that no existing log file will be overwritten. WITH_HTML_LOGS must be defined.
file | Name of the file to be written |
Definition at line 120 of file global.cpp.
References app(), and Application::write_logfile().
void appdelete | ( | ) |
Delete and free all memory associated with the application.
Delete all global data. It should be called at the end of the application if leak checking is to be done.
Definition at line 132 of file global.cpp.
void thread_complete | ( | ) |
Delete and free memory allocated per thread in multithreaded applications.
Delete the memory allocated per thread by Cantera. It should be called from within the thread just before the thread terminates. If your version of Cantera has not been specifically compiled for thread safety this function does nothing.
Definition at line 139 of file global.cpp.
References app(), and Application::thread_complete().
XML_Node * get_XML_File | ( | const std::string & | file, |
int | debug = 0 |
||
) |
Return a pointer to the XML tree for a Cantera input file.
This routine will find the file and read the XML file into an XML tree structure. Then, a pointer will be returned. If the file has already been processed, then just the pointer will be returned.
file | String containing the relative or absolute file name |
debug | Debug flag |
Definition at line 144 of file global.cpp.
References app(), and Application::get_XML_File().
Referenced by Elements::addElementsFromXML(), Phase::addElementsFromXML(), electrodeElectron::electrodeElectron(), FixedChemPotSSTP::FixedChemPotSSTP(), get_XML_NameID(), get_XML_Node(), IdealSolnGasVPSS::IdealSolnGasVPSS(), Interface::Interface(), MetalSHEelectrons::MetalSHEelectrons(), MineralEQ3::MineralEQ3(), newPhase(), RedlichKwongMFTP::RedlichKwongMFTP(), StoichSubstanceSSTP::StoichSubstanceSSTP(), and SurfPhase::SurfPhase().
void close_XML_File | ( | const std::string & | file | ) |
Close an XML File.
Close a file that is opened by this application object
file | String containing the relative or absolute file name |
Definition at line 151 of file global.cpp.
References app(), and Application::close_XML_File().
void popError | ( | ) |
Discard the last error message.
Cantera saves a stack of exceptions that it has caught in the Application class. This routine eliminates the last exception to be added to that stack.
Definition at line 161 of file global.cpp.
References app(), and Application::popError().
Referenced by SpeciesThermoFactory::newSpeciesThermo(), and VPSSMgrFactory::newVPSSMgr().
std::string lastErrorMessage | ( | ) |
Retrieve the last error message in a string.
This routine will retrieve the last error message and return it in the return string.
Definition at line 166 of file global.cpp.
References app(), and Application::lastErrorMessage().
Referenced by equilibrate(), vcs_determine_PhaseStability(), and vcs_equilibrate_1().
void showErrors | ( | std::ostream & | f | ) |
Prints all of the error messages to an ostream.
Write out all of the saved error messages to the ostream f using the function Logger::writelog. Cantera saves a stack of exceptions that it has caught in the Application class. This routine writes out all of the error messages to the ostream and then clears them from internal storage.
f | ostream which will receive the error messages |
Definition at line 171 of file global.cpp.
References app(), and Application::getErrors().
Referenced by TransportFactory::getSolidTransportData().
void showErrors | ( | ) |
Prints all of the error messages using writelog.
Print all of the error messages using function writelog. Cantera saves a stack of exceptions that it has caught in the Application class. This routine writes out all of the error messages and then clears them from internal storage.
Definition at line 176 of file global.cpp.
References app(), and Application::logErrors().
void setError | ( | const std::string & | r, |
const std::string & | msg | ||
) |
Set an error condition in the application class without throwing an exception.
This routine adds an error message to the end of the stack of errors that Cantera accumulates in the Application class.
r | Procedure name which is generating the error condition |
msg | Descriptive message of the error condition. |
Definition at line 181 of file global.cpp.
References Application::addError(), and app().
Referenced by XML_NoChild::XML_NoChild(), and XML_TagMismatch::XML_TagMismatch().
doublereal toSI | ( | const std::string & | unit | ) |
Return the conversion factor to convert unit std::string 'unit' to SI units.
unit | String containing the units |
Definition at line 196 of file global.cpp.
Referenced by ctml::getFloatArray(), ctml::getFloatCurrent(), ctml::getFloatDefaultUnits(), ctml::getFloats(), ctml::getMatrixValues(), MineralEQ3::initThermoXML(), DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), and strSItoDbl().
doublereal actEnergyToSI | ( | const std::string & | unit | ) |
Return the conversion factor to convert activation energy unit std::string 'unit' to Kelvin.
unit | String containing the activation energy units |
Definition at line 207 of file global.cpp.
Referenced by ctml::getFloatArray(), ctml::getFloatCurrent(), and ctml::getFloatDefaultUnits().
|
static |
split a string at a '#' sign. Used to separate a file name from an id string.
src | Original string to be split up. This is unchanged. |
file | Output string representing the first part of the string, which is the filename. |
id | Output string representing the last part of the string, which is the id. |
Definition at line 237 of file global.cpp.
References npos.
Referenced by get_XML_NameID(), and get_XML_Node().
XML_Node * get_XML_Node | ( | 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 by the file part of the file_ID string.
Searches are based on the ID attribute of the XML element only.
file_ID | This is a concatenation of two strings separated by the "#" character. The string before the pound character is the file name of an xml file to carry out the search. The string after the # character is the ID attribute of the xml element to search for. The string is interpreted as a file string if no # character is in the string. |
root | If the file string is empty, searches for the xml element with matching ID attribute are carried out from this XML node. |
Definition at line 249 of file global.cpp.
References XML_Node::findID(), get_XML_File(), and split_at_pound().
Referenced by IonsFromNeutralVPSSTP::constructPhaseXML(), importPhase(), IonsFromNeutralVPSSTP::initThermoXML(), installReactionArrays(), and Interface::Interface().
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 by the file part of the file_ID string.
Searches are based on the XML element name and the ID attribute of the XML element. An exact match of both is usually required. However, the ID attribute may be set to "", in which case the first xml element with the correct element name will be returned.
nameTarget | This is the XML element name to look for. |
file_ID | This is a concatenation of two strings separated by the "#" character. The string before the pound character is the file name of an xml file to carry out the search. The string after the # character is the ID attribute of the xml element to search for. The string is interpreted as a file string if no # character is in the string. |
root | If the file string is empty, searches for the xml element with matching ID attribute are carried out from this XML node. |
Definition at line 271 of file global.cpp.
References XML_Node::findNameID(), get_XML_File(), and split_at_pound().
Referenced by buildSolutionFromXML(), PDSS_ConstVol::constructPDSSFile(), PDSS_IonsFromNeutral::constructPDSSFile(), PDSS_HKFT::constructPDSSFile(), PDSS_SSVol::constructPDSSFile(), electrodeElectron::electrodeElectron(), FixedChemPotSSTP::FixedChemPotSSTP(), IdealSolnGasVPSS::IdealSolnGasVPSS(), VPSSMgr_Water_ConstVol::initThermoXML(), VPSSMgr_ConstVol::initThermoXML(), VPSSMgr_Water_HKFT::initThermoXML(), IdealMolalSoln::initThermoXML(), IdealSolidSolnPhase::initThermoXML(), LatticePhase::initThermoXML(), DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), MetalSHEelectrons::MetalSHEelectrons(), MineralEQ3::MineralEQ3(), newPhase(), RedlichKwongMFTP::RedlichKwongMFTP(), StoichSubstanceSSTP::StoichSubstanceSSTP(), and SurfPhase::SurfPhase().
void writePlotFile | ( | const std::string & | fname, |
const std::string & | fmt, | ||
const std::string & | plotTitle, | ||
const std::vector< std::string > & | names, | ||
const Array2D & | data | ||
) |
Write a Plotting file.
fname | Output file name |
fmt | Either TEC or XL or CSV |
plotTitle | Title of the plot |
names | vector of variable names |
data | N x M data array. data(n,m) is the m^th value of the n^th variable. |
Definition at line 13 of file plots.cpp.
References outputExcel(), and outputTEC().
void outputTEC | ( | std::ostream & | s, |
const std::string & | title, | ||
const std::vector< std::string > & | names, | ||
const Array2D & | data | ||
) |
Write a Tecplot data file.
s | output stream |
title | plot title |
names | vector of variable names |
data | N x M data array. data(n,m) is the m^th value of the n^th variable. |
Definition at line 35 of file plots.cpp.
References Array2D::nColumns(), and Array2D::nRows().
Referenced by writePlotFile().
void outputExcel | ( | std::ostream & | s, |
const std::string & | title, | ||
const std::vector< std::string > & | names, | ||
const Array2D & | data | ||
) |
Write an Excel spreadsheet in 'csv' form.
s | output stream |
title | plot title |
names | vector of variable names |
data | N x M data array. data(n,m) is the m^th value of the n^th variable. |
Definition at line 62 of file plots.cpp.
References Array2D::nColumns(), and Array2D::nRows().
Referenced by writePlotFile().
std::string fp2str | ( | const double | x, |
const std::string & | fmt = "%g" |
||
) |
Convert a double into a c++ string.
x | double to be converted |
fmt | Format to be used (printf style) |
Definition at line 29 of file stringUtils.cpp.
Referenced by XML_Node::addAttribute(), ctml::addFloatArray(), Application::Messages::addLogEntry(), ctml::addNamedFloatArray(), XML_Node::addValue(), InterfaceKinetics::applyButlerVolmerCorrection(), IonsFromNeutralVPSSTP::calcNeutralMoleculeMoleFractions(), NasaThermo::checkContinuity(), GibbsExcessVPSSTP::checkMFSum(), checkRxnElementBalance(), coeffString(), WaterProps::coeffThermalExp_IAPWS(), WaterPropsIAPWS::corr(), MixtureFugacityTP::corr0(), WaterPropsIAPWS::corr1(), PDSS_Water::dthermalExpansionCoeffdT(), WaterSSTP::dthermalExpansionCoeffdT(), ChemEquil::equilibrate(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), vcs_MultiPhaseEquil::equilibrate_TV(), ChemEquil::equilResidual(), FixedChemPotSSTP::FixedChemPotSSTP(), getFalloff(), ctml::getFloatArray(), SRI3::init(), SRI5::init(), ChemEquil::initialize(), PDSS_HKFT::initThermo(), NasaThermo::install(), SimpleThermo::install(), ShomateThermo::install(), installMinEQ3asShomateThermoFromXML(), WaterProps::isothermalCompressibility_IAPWS(), oxygen::ldens(), nitrogen::ldens(), hydrogen::ldens(), methane::ldens(), Heptane::ldens(), CarbonDioxide::ldens(), RedlichKwongMFTP::NicholsSolve(), water::Psat(), oxygen::Psat(), hydrogen::Psat(), nitrogen::Psat(), methane::Psat(), HFC134a::Psat(), Heptane::Psat(), CarbonDioxide::Psat(), Sim1D::refine(), Substance::Set(), Substance::set_TPp(), PDSS_Water::setPressure(), SingleSpeciesTP::setState_HP(), ThermoPhase::setState_HPorUV(), SingleSpeciesTP::setState_SP(), ThermoPhase::setState_SPorSV(), SingleSpeciesTP::setState_SV(), SingleSpeciesTP::setState_UV(), RootFind::solve(), MultiPhaseEquil::stepComposition(), ChemEquil::update(), Substance::update_sat(), MixTransport::update_T(), PecosTransport::update_T(), AqueousTransport::update_T(), SimpleTransport::update_T(), LiquidTransport::update_T(), Reactor::updateState(), and VCS_SOLVE::vcs_nondim_TP().
std::string int2str | ( | const int | n, |
const std::string & | fmt = "%d" |
||
) |
Convert an int to a string using a format converter.
n | int to be converted |
fmt | format converter for an int int the printf command |
Definition at line 40 of file stringUtils.cpp.
Referenced by Application::Messages::addLogEntry(), ReactorNet::addReactor(), Reactor::addSensitivityReaction(), InterfaceKinetics::applyButlerVolmerCorrection(), NonlinearSolver::beuler_jac(), NonlinearSolver::boundStep(), Domain1D::componentName(), MultiNewton::dampStep(), NonlinearSolver::deltaBoundStep(), WaterPropsIAPWS::density(), WaterPropsIAPWS::density_const(), NonlinearSolver::doAffineNewtonSolve(), Elements::elementName(), ChemEquil::equilibrate(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), vcs_MultiPhaseEquil::equilibrate_TV(), PseudoBinaryVPSSTP::err(), MolarityIonicVPSSTP::err(), GibbsExcessVPSSTP::err(), VPStandardStateTP::err(), IonsFromNeutralVPSSTP::err(), RedlichKisterVPSSTP::err(), MixedSolventElectrolyte::err(), SingleSpeciesTP::err(), MargulesVPSSTP::err(), SimpleTransport::err(), PhaseCombo_Interaction::err(), Transport::err(), MolalityVPSSTP::err(), MixtureFugacityTP::err(), LiquidTransport::err(), ThermoPhase::err(), IdealGasReactor::evalEqs(), Reactor::evalEqs(), SquareMatrix::factor(), SquareMatrix::factorQR(), EdgeKinetics::finalize(), InterfaceKinetics::finalize(), XML_Node::findNameIDIndex(), getEfficiencies(), getFalloff(), MultiTransport::getMassFluxes(), MultiTransport::getMultiDiffCoeffs(), getRateCoefficient(), importPhase(), importSolution(), Phase::init(), ReactorNet::initialize(), Rate1< Cantera::SurfaceArrhenius >::install(), GeneralSpeciesThermo::install(), GeneralSpeciesThermo::install_STIT(), rxninfo::installReaction(), LatticeSolidPhase::installSlavePhases(), CVodeInt::integrate(), CVodesIntegrator::integrate(), invert(), Sim1D::newtonSolve(), VPSSMgrFactory::newVPSSMgr(), polyfit(), NonlinearSolver::print_solnDelta_norm_contrib(), HMWSoln::printCoeffs(), solveProb::printFinal(), solveSP::printFinal(), solveProb::printIteration(), solveSP::printIteration(), WaterPropsIAPWS::psat(), SquareMatrix::rcond(), BandMatrix::rcond(), SquareMatrix::rcondQR(), NonlinearSolver::residErrorNorm(), Sim1D::restore(), StFlow::restore(), Domain1D::restore(), Domain1D::setBounds(), MolalityVPSSTP::setpHScale(), Domain1D::setTolerances(), Sim1D::setValue(), NonlinearSolver::solnErrorNorm(), SquareMatrix::solve(), MultiNewton::solve(), solve(), SquareMatrix::solveQR(), solveSP::solveSurfProb(), Kinetics::speciesPhaseIndex(), MultiNewton::step(), CVodeInt::step(), CVodesIntegrator::step(), InterfaceKinetics::updateKc(), DustyGasTransport::updateMultiDiffCoeffs(), IdealGasReactor::updateState(), Reactor::updateState(), Sim1D::value(), VCSnonideal::vcs_Cantera_to_vprob(), vcs_determine_PhaseStability(), vcs_equilibrate_1(), VCS_SOLVE::vcs_printSpeciesChemPot(), Application::Messages::write_logfile(), OneDim::writeStats(), and XML_Error::XML_Error().
std::string int2str | ( | const size_t | n | ) |
Convert an unsigned integer to a string.
n | int to be converted |
Definition at line 51 of file stringUtils.cpp.
std::string lowercase | ( | const std::string & | s | ) |
Cast a copy of a string to lower case.
s | Input string |
Definition at line 58 of file stringUtils.cpp.
Referenced by PDSS_HKFT::constructPDSSXML(), PDSS_IonsFromNeutral::constructPDSSXML(), IonsFromNeutralVPSSTP::constructPhaseXML(), HMWSoln::constructPhaseXML(), LiquidTranInteraction::init(), SimpleTransport::initLiquid(), VPSSMgr_Water_HKFT::initThermoXML(), MolarityIonicVPSSTP::initThermoXML(), IdealSolnGasVPSS::initThermoXML(), RedlichKwongMFTP::initThermoXML(), RedlichKisterVPSSTP::initThermoXML(), MixedSolventElectrolyte::initThermoXML(), MargulesVPSSTP::initThermoXML(), IonsFromNeutralVPSSTP::initThermoXML(), PhaseCombo_Interaction::initThermoXML(), IdealSolidSolnPhase::initThermoXML(), LatticePhase::initThermoXML(), DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), interp_est(), HMWSoln::interp_est(), TransportFactory::newLTP(), SpeciesThermoFactory::newSpeciesThermoManager(), HMWSoln::readXMLBinarySalt(), RedlichKisterVPSSTP::readXMLBinarySpecies(), MixedSolventElectrolyte::readXMLBinarySpecies(), MargulesVPSSTP::readXMLBinarySpecies(), PhaseCombo_Interaction::readXMLBinarySpecies(), RedlichKwongMFTP::readXMLCrossFluid(), HMWSoln::readXMLLambdaNeutral(), HMWSoln::readXMLMunnnNeutral(), HMWSoln::readXMLPsiCommonAnion(), HMWSoln::readXMLPsiCommonCation(), RedlichKwongMFTP::readXMLPureFluid(), HMWSoln::readXMLThetaAnion(), HMWSoln::readXMLThetaCation(), HMWSoln::readXMLZetaCation(), and VPSSMgrFactory::VPSSMgr_StringConversion().
|
static |
Return the position of the first printable character in the string.
s | input string |
Definition at line 74 of file stringUtils.cpp.
Referenced by stripws().
|
static |
Return the position of the last printable character in the string.
s | input string |
Definition at line 92 of file stringUtils.cpp.
Referenced by stripws().
std::string stripws | ( | const std::string & | s | ) |
Strip the leading and trailing white space from a string.
The command isprint() is used to determine printable characters.
s | Input string |
Definition at line 103 of file stringUtils.cpp.
References firstChar(), and lastChar().
Referenced by Elements::addUniqueElement(), Phase::addUniqueElement(), XML_Node::addValue(), ctml::ck2cti(), ctml::ct2ctml(), fpValueCheck(), intValue(), parseCompString(), parseSpeciesName(), XML_Reader::parseTag(), ctml::pypath(), and XML_Reader::readValue().
std::string stripnonprint | ( | const std::string & | s | ) |
Strip non-printing characters wherever they are.
s | Input string |
Definition at line 110 of file stringUtils.cpp.
Referenced by Application::addDataDirectory().
compositionMap parseCompString | ( | const std::string & | ss, |
const std::vector< std::string > & | names | ||
) |
Parse a composition string into a map consisting of individual key:composition pairs.
Elements present in names but not in the composition string will have a value of 0. Elements present in the composition string but not in names will generate an exception. The composition is a double. Example:
Input is
"ice:1 snow:2" names = ["fire", "ice", "snow"]
Output is x["fire"] = 0 x["ice"] = 1 x["snow"] = 2
ss | original string consisting of multiple key:composition pairs on multiple lines |
names | valid names for elements in the composition map |
Definition at line 123 of file stringUtils.cpp.
References fpValueCheck(), npos, and stripws().
Referenced by SurfPhase::setCoveragesByName(), Phase::setMassFractionsByName(), MolalityVPSSTP::setMolalitiesByName(), Phase::setMoleFractionsByName(), MultiPhase::setMolesByName(), ThermoPhase::setState_TPX(), and ThermoPhase::setState_TPY().
void split | ( | const std::string & | ss, |
std::vector< std::string > & | w | ||
) |
Parse a composition string into individual key:composition pairs.
ss | original string consisting of multiple key:composition pairs on multiple lines |
w | Output vector consisting of single key:composition items in each index. |
Definition at line 161 of file stringUtils.cpp.
References npos.
int fillArrayFromString | ( | const std::string & | str, |
doublereal *const | a, | ||
const char | delim = ' ' |
||
) |
Interpret a string as a list of floats, and convert it to a vector of floats.
str | String input vector |
a | Output pointer to a vector of floats |
delim | character delimiter. Defaults to a space |
Definition at line 182 of file stringUtils.cpp.
References fpValueCheck().
std::string getBaseName | ( | const std::string & | fullPath | ) |
Get the file name without the path or extension.
fullPath | Input file name consisting of the full file name |
Definition at line 204 of file stringUtils.cpp.
Referenced by ctml::get_CTML_Tree(), and logfileName().
int intValue | ( | const std::string & | val | ) |
Translate a string into one integer value.
No error checking is done on the conversion. The c stdlib function atoi() is used.
val | String value of the integer |
Definition at line 221 of file stringUtils.cpp.
References stripws().
Referenced by importPhase(), and Sim1D::restore().
doublereal fpValue | ( | const std::string & | val | ) |
Translate a string into one doublereal value.
No error checking is done on the conversion.
val | String value of the double |
Definition at line 226 of file stringUtils.cpp.
Referenced by Elements::addElement(), Phase::addElement(), Elements::addUniqueElement(), Phase::addUniqueElement(), fpValueCheck(), getEfficiencies(), getFalloff(), ctml::getFloatCurrent(), ctml::getFloats(), getRateCoefficient(), getReagents(), DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), installAdsorbateThermoFromXML(), installMu0ThermoFromXML(), installNasa9ThermoFromXML(), installNasaThermoFromXML(), installShomateThermoFromXML(), installSimpleThermoFromXML(), installStatMechThermoFromXML(), and PecosTransport::read_blottner_transport_table().
doublereal fpValueCheck | ( | const std::string & | val | ) |
Translate a string into one doublereal value, with error checking.
fpValueCheck is a wrapper around the C++ stringstream double parser. It does quite a bit more error checking than atof() or strtod(), and is quite a bit more restrictive.
First it interprets both E, e, d, and D as exponents. stringstreams only interpret e or E as an exponent character.
It only accepts a string as well formed if it consists as a single token. Multiple words will raise an exception. It will raise a CanteraError for NAN and inf entries as well, in contrast to atof() or strtod(). The user needs to know that a serious numerical issue has occurred.
It does not accept hexadecimal numbers.
It always use the C locale, regardless of any locale settings.
val | String representation of the number |
Definition at line 235 of file stringUtils.cpp.
References fpValue(), and stripws().
Referenced by Elements::addUniqueElement(), Phase::addUniqueElement(), PDSS_HKFT::constructPDSSXML(), PDSS_IonsFromNeutral::constructPDSSXML(), HMWSoln::constructPhaseXML(), fillArrayFromString(), XML_Node::fp_value(), ctml::getFloatArray(), ctml::getMatrixValues(), HMWSoln::initThermoXML(), installSpecies(), parseCompString(), HMWSoln::readXMLBinarySalt(), HMWSoln::readXMLPsiCommonAnion(), HMWSoln::readXMLPsiCommonCation(), LatticeSolidPhase::setParametersFromXML(), and strSItoDbl().
std::string logfileName | ( | const std::string & | infile | ) |
Generate a logfile name based on an input file name.
It tries to find the basename. Then, it appends a .log to it.
infile | Input file name |
Definition at line 277 of file stringUtils.cpp.
References getBaseName().
std::string wrapString | ( | const std::string & | s, |
const int | len = 70 |
||
) |
Line wrap a string via a copy operation.
s | Input string to be line wrapped |
len | Length at which to wrap. The default is 70. |
Definition at line 284 of file stringUtils.cpp.
std::string parseSpeciesName | ( | const std::string & | nameStr, |
std::string & | phaseName | ||
) |
Parse a name string, separating out the phase name from the species name.
Name strings must not contain these internal characters "; \n \t ," Only one colon is allowed, the one separating the phase name from the species name. Therefore, names may not include a colon.
[in] | nameStr | Name string containing the phase name and the species name separated by a colon. The phase name is optional. example: "silane:SiH4" |
[out] | phaseName | Name of the phase, if specified. If not specified, a blank string is returned. |
Definition at line 303 of file stringUtils.cpp.
References npos, and stripws().
Referenced by Phase::speciesIndex().
int stripLTWScstring | ( | char | str[] | ) |
Routine strips off white space from a c character string.
This routine strips off blanks and tabs (only leading and trailing characters) in 'str'. On return, it returns the number of characters still included in the string (excluding the null character).
Comments are excluded -> All instances of the comment character, '!', are replaced by NULL character thereby terminating the string.
str | On output 'str' contains the same characters as on input except the leading and trailing white space and comments have been removed. |
Definition at line 329 of file stringUtils.cpp.
References warn_deprecated().
doublereal strSItoDbl | ( | const std::string & | strSI | ) |
Interpret one or two token string as a single double.
This is similar to atof(). However, the second token is interpreted as an MKS units string and a conversion factor to MKS is applied.
Example: "1.0 atm" results in the number 1.01325e5.
strSI | string to be converted. One or two tokens |
Definition at line 370 of file stringUtils.cpp.
References fpValueCheck(), tokenizeString(), and toSI().
Referenced by PDSS_HKFT::constructPDSSXML(), and installMinEQ3asShomateThermoFromXML().
|
static |
Find the first white space in a string.
Returns the location of the first white space character in a string
val | Input string to be parsed |
Definition at line 394 of file stringUtils.cpp.
References npos.
Referenced by tokenizeString().
|
static |
Find the first non-white space in a string.
Returns the location of the first non-white space character in a string
val | Input string to be parsed |
Definition at line 419 of file stringUtils.cpp.
References npos.
Referenced by tokenizeString().
void tokenizeString | ( | const std::string & | oval, |
std::vector< std::string > & | v | ||
) |
This function separates a string up into tokens according to the location of white space.
White space includes the new line character. tokens are stripped of leading and trailing white space.
The separate tokens are returned in a string vector, v.
oval | String to be broken up |
v | Output vector of tokens. |
Definition at line 436 of file stringUtils.cpp.
References findFirstNotOfWS(), findFirstWS(), and npos.
Referenced by ctml::getStringArray(), and strSItoDbl().
void copyString | ( | const std::string & | source, |
char * | dest, | ||
size_t | length | ||
) |
Copy the contents of a std::string into a char array of a given length.
Definition at line 460 of file stringUtils.cpp.
|
static |
Find the first position of a character, q, in string, s, which is not immediately preceded by the backslash character.
s | Input string |
q | Search for this character |
istart | Defaults to 0 |
Definition at line 132 of file xml.cpp.
References npos.
Referenced by XML_Reader::findQuotedString().
XML_Node * findXMLPhase | ( | XML_Node * | root, |
const std::string & | phaseName | ||
) |
Search an XML_Node tree for a named phase XML_Node.
Search for a phase Node matching a name.
root | Starting XML_Node* pointer for the search |
phaseName | Name of the phase to search for |
Definition at line 1104 of file xml.cpp.
References XML_Node::children(), XML_Node::id(), XML_Node::name(), and XML_Node::nChildren().
Referenced by PDSS_ConstVol::constructPDSSFile(), PDSS_IdealGas::constructPDSSFile(), PDSS_IonsFromNeutral::constructPDSSFile(), PDSS_HKFT::constructPDSSFile(), PDSS_Water::constructPDSSFile(), PDSS_SSVol::constructPDSSFile(), IonsFromNeutralVPSSTP::constructPhaseFile(), HMWSoln::constructPhaseFile(), DebyeHuckel::DebyeHuckel(), HMWSoln::HMWSoln(), IdealMolalSoln::IdealMolalSoln(), IdealSolidSolnPhase::IdealSolidSolnPhase(), ThermoPhase::initThermoFile(), LatticePhase::LatticePhase(), MargulesVPSSTP::MargulesVPSSTP(), MixedSolventElectrolyte::MixedSolventElectrolyte(), MolarityIonicVPSSTP::MolarityIonicVPSSTP(), PhaseCombo_Interaction::PhaseCombo_Interaction(), RedlichKisterVPSSTP::RedlichKisterVPSSTP(), and WaterSSTP::WaterSSTP().
int _equilflag | ( | const char * | xy | ) |
map property strings to integers
Definition at line 29 of file ChemEquil.cpp.
Referenced by equilibrate(), ChemEquil::equilibrate(), and vcs_equilibrate().
|
static |
Used to print reaction equations.
Given a stoichiometric coefficient 'nu' and a chemical symbol 'sym', return a string for this species in the reaction.
first | if this is false, then a " + " string will be added to the beginning of the string. |
nu | Stoichiometric coefficient. May be positive or negative. The absolute value will be used in the string. |
sym | Species chemical symbol. |
Definition at line 27 of file MultiPhaseEquil.cpp.
References fp2str().
Referenced by MultiPhaseEquil::reactionString().
int vcs_determine_PhaseStability | ( | MultiPhase & | s, |
int | iphase, | ||
double & | funcStab, | ||
int | printLvl, | ||
int | loglevel | ||
) |
Determine the phase stability of a single phase given the current conditions in a MultiPhase object.
s | The MultiPhase object to be set to an equilibrium state |
iphase | Phase index within the multiphase object to be tested for stability. |
funcStab | Function value that tests equilibrium. > 0 indicates stable < 0 indicates unstable |
printLvl | Determines the amount of printing that gets sent to stdout from the vcs package (Note, you may have to compile with debug flags to get some printing). |
loglevel | Controls amount of diagnostic output. loglevel = 0 suppresses diagnostics, and increasingly-verbose messages are written as loglevel increases. The messages are written to a file in HTML format for viewing in a web browser. |
Definition at line 234 of file vcs_equilibrate.cpp.
References addLogEntry(), beginLogGroup(), vcs_MultiPhaseEquil::determine_PhaseStability(), endLogGroup(), MultiPhase::init(), int2str(), lastErrorMessage(), and vcs_MultiPhaseEquil::reportCSV().
bool Cantera::getReagents | ( | const XML_Node & | rxn, |
Kinetics & | kin, | ||
int | rp, | ||
std::string | default_phase, | ||
std::vector< size_t > & | spnum, | ||
vector_fp & | stoich, | ||
vector_fp & | order, | ||
const ReactionRules & | rules | ||
) |
Get the reactants or products of a reaction.
The information is returned in the spnum, stoich, and order vectors. The length of the vectors is the number of different types of reactants or products found for the reaction.
[in] | rxn | xml node pointing to the reaction element in the xml tree. |
[in] | kin | Reference to the kinetics object to install the information into. |
[in] | rp | 1 -> Go get the reactants for a reaction; -1 -> Go get the products for a reaction |
[in] | default_phase | Name for the default phase to loop up species in. |
[out] | spnum | vector of species numbers found. Length is number of reactants or products. |
[out] | stoich | stoichiometric coefficient of the reactant or product. Length is number of reactants or products. |
[out] | order | Order of the reactant and product in the reaction rate expression. |
[in] | rules | If rules.skipUndeclaredSpecies is set and we fail to find a species we simply return false, allowing the calling routine to skip this reaction and continue. Otherwise, we will throw an error. |
Definition at line 148 of file importKinetics.cpp.
References XML_Node::child(), fpValue(), XML_Node::getChildren(), ctml::getPairs(), XML_Node::hasChild(), Kinetics::kineticsSpeciesIndex(), and npos.
Referenced by rxninfo::installReaction().
|
static |
getArrhenius() parses the xml element called Arrhenius.
The Arrhenius expression is
\[ k = A T^(b) exp (-E_a / RT). \]
Definition at line 256 of file importKinetics.cpp.
References GasConstant, and ctml::getFloat().
Referenced by getRateCoefficient(), and LTPspecies_Arrhenius::LTPspecies_Arrhenius().
|
static |
getStick() processes the XML element called Stick that specifies the sticking coefficient reaction.
This routine will translate the sticking coefficient value into a "normal" rate constant for the surface reaction.
Output is the normal Arrhenius expressions for a surface reaction rate constant.
A - units such that rate of rxn has kmol/m^2/s when A is multiplied by activity concentrations of reactants in the normal manner. n - unitless E - Units 1/Kelvin
Definition at line 293 of file importKinetics.cpp.
References cEdge, cSurf, ThermoPhase::eosType(), GasConstant, ctml::getFloat(), Kinetics::kineticsSpeciesIndex(), Kinetics::kineticsSpeciesName(), Phase::molecularWeights(), Pi, ReactionData::reactants, ReactionData::rorder, Phase::speciesIndex(), Kinetics::speciesPhase(), Kinetics::speciesPhaseIndex(), ThermoPhase::standardConcentration(), and Kinetics::thermo().
Referenced by getRateCoefficient().
|
static |
Get falloff parameters for a reaction.
This routine reads the falloff XML node and extracts parameters into a vector of doubles
<falloff type="Troe"> 0.5 73.2 5000. 9999. </falloff>
Definition at line 399 of file importKinetics.cpp.
References ReactionData::falloffParameters, ReactionData::falloffType, fp2str(), fpValue(), ctml::getStringArray(), and int2str().
Referenced by getRateCoefficient().
|
static |
Get the enhanced collision efficiencies.
It is assumed that the reaction mechanism is homogeneous, so that all species belong to phase(0) of 'kin'.
Definition at line 445 of file importKinetics.cpp.
References ReactionData::default_3b_eff, fpValue(), ctml::getPairs(), Phase::id(), int2str(), Kinetics::kineticsSpeciesIndex(), npos, ReactionData::number, Kinetics::thermo(), and ReactionData::thirdBodyEfficiencies.
Referenced by getRateCoefficient().
|
static |
This function calculates a damping factor for the Newton iteration update vector, dxneg, to insure that all site and bulk fractions, x, remain bounded between zero and one.
dxneg[] = negative of the update vector.
The constant "APPROACH" sets the fraction of the distance to the boundary that the step can take. If the full step would not force any fraction outside of 0-1, then Newton's method is allowed to operate normally.
Definition at line 652 of file solveSP.cpp.
std::ostream & operator<< | ( | std::ostream & | s, |
const BandMatrix & | m | ||
) |
Utility routine to print out the matrix.
s | ostream to print the matrix out to |
m | Matrix to be printed |
Definition at line 315 of file BandMatrix.cpp.
References BandMatrix::nColumns(), and BandMatrix::nRows().
|
inline |
This routine subtracts two numbers for one another.
This routine subtracts 2 numbers. If the difference is less than 1.0E-14 times the magnitude of the smallest number, then diff returns an exact zero. It also returns an exact zero if the difference is less than 1.0E-300.
returns: a - b
This routine is used in numerical differencing schemes in order to avoid roundoff errors resulting in creating Jacobian terms. Note: This is a slow routine. However, jacobian errors may cause loss of convergence. Therefore, in practice this routine has proved cost-effective.
a | Value of a |
b | value of b |
Definition at line 500 of file BEulerInt.cpp.
Referenced by BEulerInt::beuler_jac(), and NonlinearSolver::beuler_jac().
DAE_Solver * newDAE_Solver | ( | const std::string & | itype, |
ResidJacEval & | f | ||
) |
Factor method for choosing a DAE solver.
itype | String identifying the type (IDA is the only option) |
f | Residual function to be solved by the DAE algorithm |
Definition at line 22 of file DAE_solvers.cpp.
int solve | ( | DenseMatrix & | A, |
double * | b | ||
) |
Solve Ax = b. Array b is overwritten on exit with x.
The solve class uses the LAPACK routine dgetrf to invert the m xy n matrix.
The factorization has the form A = P * L * U where P is a permutation matrix, L is lower triangular with unit diagonal elements (lower trapezoidal if m > n), and U is upper triangular (upper trapezoidal if m < n).
The system is then solved using the LAPACK routine dgetrs
A | Dense matrix to be factored |
b | rhs to be solved. |
Definition at line 134 of file DenseMatrix.cpp.
References int2str(), DenseMatrix::ipiv(), DenseMatrix::m_printLevel, DenseMatrix::m_useReturnErrorCode, Array2D::nColumns(), Array2D::nRows(), Array2D::ptrColumn(), and writelogf().
Referenced by ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), ChemEquil::estimateEP_Brinkley(), AqueousTransport::stefan_maxwell_solve(), and LiquidTransport::stefan_maxwell_solve().
int solve | ( | DenseMatrix & | A, |
DenseMatrix & | b | ||
) |
Solve Ax = b for multiple right-hand-side vectors.
A | Dense matrix to be factored |
b | Dense matrix of rhs's. Each column is a rhs |
Definition at line 180 of file DenseMatrix.cpp.
References int2str(), DenseMatrix::ipiv(), DenseMatrix::m_printLevel, DenseMatrix::m_useReturnErrorCode, Array2D::nColumns(), Array2D::nRows(), Array2D::ptrColumn(), and writelogf().
void multiply | ( | const DenseMatrix & | A, |
const double *const | b, | ||
double *const | prod | ||
) |
Multiply A*b
and return the result in prod
. Uses BLAS routine DGEMV.
\[ prod_i = sum^N_{j = 1}{A_{ij} b_j} \]
A | input Dense Matrix A with M rows and N columns |
b | input vector b with length N |
prod | output output vector prod length = M |
Definition at line 233 of file DenseMatrix.cpp.
References Array2D::nColumns(), Array2D::nRows(), and Array2D::ptrColumn().
Referenced by DustyGasTransport::getMolarFluxes(), MultiPhaseEquil::MultiPhaseEquil(), MultiPhaseEquil::stepComposition(), PecosTransport::thermalConductivity(), GasTransport::viscosity(), PecosTransport::viscosity(), and AqueousTransport::viscosity().
void increment | ( | const DenseMatrix & | A, |
const double *const | b, | ||
double *const | prod | ||
) |
Multiply A*b
and add it to the result in prod
. Uses BLAS routine DGEMV.
\[ prod_i += sum^N_{j = 1}{A_{ij} b_j} \]
A | input Dense Matrix A with M rows and N columns |
b | input vector b with length N |
prod | output output vector prod length = M |
Definition at line 240 of file DenseMatrix.cpp.
References Array2D::nRows(), and Array2D::ptrColumn().
Referenced by DustyGasTransport::getMolarFluxes().
int invert | ( | DenseMatrix & | A, |
size_t | nn = npos |
||
) |
invert A. A is overwritten with A^-1.
A | Invert the matrix A and store it back in place |
nn | Size of A. This defaults to -1, which means that the number of rows is used as the default size of n |
Definition at line 247 of file DenseMatrix.cpp.
References int2str(), DenseMatrix::ipiv(), DenseMatrix::m_printLevel, DenseMatrix::m_useReturnErrorCode, npos, Array2D::nRows(), Array2D::ptrColumn(), and writelogf().
Referenced by MultiTransport::getMultiDiffCoeffs(), and DustyGasTransport::updateMultiDiffCoeffs().
doublereal Cantera::linearInterp | ( | doublereal | x, |
const vector_fp & | xpts, | ||
const vector_fp & | fpts | ||
) |
Linearly interpolate a function defined on a discrete grid.
Vector xpts contains a monotonic sequence of grid points, and vector fpts contains function values defined at these points. The value returned is the linear interpolate at point x. If x is outside the range of xpts, the value of fpts at the nearest end is returned.
x | value of the x coordinate |
xpts | value of the grid points |
fpts | value of the interpolant at the grid points |
Definition at line 40 of file funcs.cpp.
Referenced by StFlow::_finalize(), and Sim1D::setProfile().
doublereal polyfit | ( | int | n, |
doublereal * | x, | ||
doublereal * | y, | ||
doublereal * | w, | ||
int | maxdeg, | ||
int & | ndeg, | ||
doublereal | eps, | ||
doublereal * | r | ||
) |
Fits a polynomial function to a set of data points.
Given a collection of points X(I) and a set of values Y(I) which correspond to some function or measurement at each of the X(I), subroutine DPOLFT computes the weighted least-squares polynomial fits of all degrees up to some degree either specified by the user or determined by the routine. The fits thus obtained are in orthogonal polynomial form. Subroutine DP1VLU may then be called to evaluate the fitted polynomials and any of their derivatives at any point. The subroutine DPCOEF may be used to express the polynomial fits as powers of (X-C) for any specified point C.
n | The number of data points. |
x | A set of grid points on which the data is specified. The array of values of the independent variable. These values may appear in any order and need not all be distinct. There are n of them. |
y | array of corresponding function values. There are n of them |
w | array of positive values to be used as weights. If W[0] is negative, DPOLFT will set all the weights to 1.0, which means unweighted least squares error will be minimized. To minimize relative error, the user should set the weights to: W(I) = 1.0/Y(I)**2, I = 1,...,N . |
maxdeg | maximum degree to be allowed for polynomial fit. MAXDEG may be any non-negative integer less than N. Note – MAXDEG cannot be equal to N-1 when a statistical test is to be used for degree selection, i.e., when input value of EPS is negative. |
ndeg | output degree of the fit computed. |
eps | Specifies the criterion to be used in determining the degree of fit to be computed. (1) If EPS is input negative, DPOLFT chooses the degree based on a statistical F test of significance. One of three possible significance levels will be used: .01, .05 or .10. If EPS=-1.0 , the routine will automatically select one of these levels based on the number of data points and the maximum degree to be considered. If EPS is input as -.01, -.05, or -.10, a significance level of .01, .05, or .10, respectively, will be used. (2) If EPS is set to 0., DPOLFT computes the polynomials of degrees 0 through MAXDEG . (3) If EPS is input positive, EPS is the RMS error tolerance which must be satisfied by the fitted polynomial. DPOLFT will increase the degree of fit until this criterion is met or until the maximum degree is reached. |
r | Output vector containing the first LL+1 Taylor coefficients where LL=ABS(ndeg). P(X) = r[0] + r[1]*(X-C) + ... + r[ndeg] * (X-C)**ndeg ( here C = 0.0) |
Given a collection of points X(I) and a set of values Y(I) which correspond to some function or measurement at each of the X(I), subroutine DPOLFT computes the weighted least-squares polynomial fits of all degrees up to some degree either specified by the user or determined by the routine. The fits thus obtained are in orthogonal polynomial form. Subroutine DP1VLU may then be called to evaluate the fitted polynomials and any of their derivatives at any point. The subroutine DPCOEF may be used to express the polynomial fits as powers of (X-C) for any specified point C.
n | The number of data points. |
x | A set of grid points on which the data is specified. The array of values of the independent variable. These values may appear in any order and need not all be distinct. There are n of them. |
y | array of corresponding function values. There are n of them |
w | array of positive values to be used as weights. If W[0] is negative, DPOLFT will set all the weights to 1.0, which means unweighted least squares error will be minimized. To minimize relative error, the user should set the weights to: W(I) = 1.0/Y(I)**2, I = 1,...,N . |
maxdeg | maximum degree to be allowed for polynomial fit. MAXDEG may be any non-negative integer less than N. Note – MAXDEG cannot be equal to N-1 when a statistical test is to be used for degree selection, i.e., when input value of EPS is negative. |
ndeg | output degree of the fit computed. |
eps | Specifies the criterion to be used in determining the degree of fit to be computed. (1) If EPS is input negative, DPOLFT chooses the degree based on a statistical F test of significance. One of three possible significance levels will be used: .01, .05 or .10. If EPS=-1.0 , the routine will automatically select one of these levels based on the number of data points and the maximum degree to be considered. If EPS is input as -.01, -.05, or -.10, a significance level of .01, .05, or .10, respectively, will be used. (2) If EPS is set to 0., DPOLFT computes the polynomials of degrees 0 through MAXDEG . (3) If EPS is input positive, EPS is the RMS error tolerance which must be satisfied by the fitted polynomial. DPOLFT will increase the degree of fit until this criterion is met or until the maximum degree is reached. |
r | Output vector containing the first ndeg+1 Taylor coefficients P(X) = r[0] + r[1]*(X-C) + ... + r[ndeg] * (X-C)**ndeg ( here C = 0.0) |
Definition at line 122 of file funcs.cpp.
References int2str().
Referenced by TransportFactory::fitProperties().
|
static |
Print a line of a single repeated character string.
str | Character string |
n | Iteration length |
Definition at line 44 of file NonlinearSolver.cpp.
Referenced by NonlinearSolver::print_solnDelta_norm_contrib(), NonlinearSolver::residErrorNorm(), NonlinearSolver::solnErrorNorm(), and NonlinearSolver::solve_nonlinear_problem().
|
static |
Print out a form for the current function evaluation.
fp | Pointer to the FILE object |
xval | Current value of x |
fval | Current value of f |
its | Current iteration value |
Definition at line 43 of file RootFind.cpp.
Referenced by RootFind::solve().
void importSolution | ( | size_t | points, |
doublereal * | oldSoln, | ||
IdealGasPhase & | oldmech, | ||
size_t | size_new, | ||
doublereal * | newSoln, | ||
IdealGasPhase & | newmech | ||
) |
Import a previous solution to use as an initial estimate.
The previous solution may have been computed using a different reaction mechanism. Species in the old and new mechanisms are matched by name, and any species in the new mechanism that were not in the old one are set to zero. The new solution is created with the same number of grid points as in the old solution.
Definition at line 21 of file StFlow.cpp.
References Phase::getMassFractions(), int2str(), npos, Phase::nSpecies(), Phase::setMassFractions(), Phase::speciesIndex(), and Phase::speciesName().
|
static |
Utility function to assign an integer value from a string for the ElectrolyteSpeciesType field.
estString | input string that will be interpreted |
Definition at line 596 of file DebyeHuckel.cpp.
References cEST_solvent, and lowercase().
Referenced by DebyeHuckel::initThermoXML(), and HMWSoln::initThermoXML().
double LookupWtElements | ( | const std::string & | ename | ) |
Function to look up an atomic weight This function looks up the argument string in the database above and returns the associated molecular weight.
The data are from the periodic table.
Note: The idea behind this function is to provide a unified source for the element atomic weights. This helps to ensure that mass is conserved.
ename | String, Only the first 3 characters are significant |
CanteraError | If a match is not found, throws a CanteraError |
Definition at line 175 of file Elements.cpp.
References awData::atomicWeight, and aWTable.
Referenced by Phase::addElement(), and Phase::addUniqueElement().
|
static |
Return the factor overlap.
elnamesVN | |
elemVectorN | |
nElementsN | |
elnamesVI | |
elemVectorI | |
nElementsI |
Definition at line 905 of file IonsFromNeutralVPSSTP.cpp.
Referenced by IonsFromNeutralVPSSTP::initThermoXML().
|
static |
Examine the types of species thermo parameterizations, and return a flag indicating the type of reference state thermo manager that will be needed in order to evaluate them all.
spDataNodeList | This vector contains a list of species XML nodes that will be in the phase |
has_nasa | Return int that indicates whether the phase has a NASA polynomial form for one of its species |
has_shomate | Return int that indicates whether the phase has a SHOMATE polynomial form for one of its species |
has_simple | Return int that indicates whether the phase has a SIMPLE polynomial form for one of its species |
has_other | Return int that indicates whether the phase has a form for one of its species that is not one of the ones listed above. |
Definition at line 53 of file SpeciesThermoFactory.cpp.
References XML_Node::attrib(), XML_Node::child(), and XML_Node::hasChild().
Referenced by SpeciesThermoFactory::newSpeciesThermo().
|
static |
Install a NASA polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a NASA block is found in the XML input.
speciesName | String name of the species |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
f0ptr | Ptr to the first XML_Node for the first NASA polynomial |
f1ptr | Ptr to the first XML_Node for the first NASA polynomial |
Definition at line 205 of file SpeciesThermoFactory.cpp.
References XML_Node::child(), fpValue(), ctml::getFloatArray(), XML_Node::hasAttrib(), SpeciesThermo::install(), NASA, and OneAtm.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Look up the elemental reference state entropies.
elemName | String name of the element |
th_ptr | Pointer to the thermophase. |
Definition at line 286 of file SpeciesThermoFactory.cpp.
References Phase::elementIndex(), ENTROPY298_UNKNOWN, Phase::entropyElement298(), and npos.
Referenced by convertDGFormation().
|
static |
Convert delta G formulation.
Calculates the sum of the elemental reference state entropies
k | species index |
th_ptr | Pointer to the ThermoPhase |
Definition at line 308 of file SpeciesThermoFactory.cpp.
References Phase::elementName(), LookupGe(), Phase::nAtoms(), and Phase::nElements().
Referenced by installMinEQ3asShomateThermoFromXML().
|
static |
Install a NASA96 polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a MinEQ3node block is found in the XML input.
speciesName | String name of the species |
th_ptr | Pointer to the ThermoPhase object |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
MinEQ3node | Ptr to the first XML_Node for the first MinEQ3 parameterization |
Definition at line 341 of file SpeciesThermoFactory.cpp.
References convertDGFormation(), fp2str(), ctml::getFloatDefaultUnits(), SpeciesThermo::install(), SHOMATE, and strSItoDbl().
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Install a Shomate polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a Shomate block is found in the XML input.
speciesName | String name of the species |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
f0ptr | Ptr to the first XML_Node for the first NASA polynomial |
f1ptr | Ptr to the first XML_Node for the first NASA polynomial |
Definition at line 428 of file SpeciesThermoFactory.cpp.
References XML_Node::child(), fpValue(), ctml::getFloatArray(), XML_Node::hasAttrib(), SpeciesThermo::install(), OneAtm, and SHOMATE.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Install a Simple thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a SimpleThermo block is found
speciesName | String name of the species |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
f | XML_Node for the SimpleThermo block |
Definition at line 504 of file SpeciesThermoFactory.cpp.
References fpValue(), ctml::getFloat(), SpeciesThermo::install(), OneAtm, and SIMPLE.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Install a NASA9 polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a NASA9 block is found in the XML input.
speciesName | String name of the species |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
tp | Vector of XML Nodes that make up the parameterization |
Definition at line 534 of file SpeciesThermoFactory.cpp.
References XML_Node::child(), DATA_PTR, fpValue(), ctml::getFloatArray(), XML_Node::hasChild(), SpeciesThermo::install_STIT(), XML_Node::name(), and OneAtm.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Install a stat mech based property solver for species k into a SpeciesThermo instance.
Definition at line 588 of file SpeciesThermoFactory.cpp.
References XML_Node::child(), fpValue(), ctml::getFloatArray(), XML_Node::hasChild(), XML_Node::name(), OneAtm, and STAT.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
|
static |
Install a Adsorbate polynomial thermodynamic property parameterization for species k into a SpeciesThermo instance.
This is called by method installThermoForSpecies if a Adsorbate block is found in the XML input.
speciesName | String name of the species |
sp | SpeciesThermo object that will receive the NASA polynomial object |
k | Species index within the phase |
f | XML Node that contains the parameterization |
Definition at line 639 of file SpeciesThermoFactory.cpp.
References ADSORBATE, XML_Node::child(), fpValue(), ctml::getFloat(), ctml::getFloatArray(), XML_Node::hasAttrib(), XML_Node::hasChild(), and OneAtm.
Referenced by SpeciesThermoFactory::installThermoForSpecies().
SpeciesThermo * newSpeciesThermoMgr | ( | int | type, |
SpeciesThermoFactory * | f = 0 |
||
) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it.
This utility program will look through species nodes. It will discover what each species needs for its species property managers. Then, it will malloc and return the proper species property manager to use.
These functions allow using a different factory class that derives from SpeciesThermoFactory.
type | Species thermo type. |
f | Pointer to a SpeciesThermoFactory. optional parameter. Defaults to NULL. |
Definition at line 778 of file SpeciesThermoFactory.cpp.
References SpeciesThermoFactory::newSpeciesThermo().
Referenced by importPhase(), and VPSSMgrFactory::newVPSSMgr().
SpeciesThermo * newSpeciesThermoMgr | ( | std::string & | stype, |
SpeciesThermoFactory * | f = 0 |
||
) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it.
This utility program is a basic factory operation for spawning a new species reference-state thermo manager
These functions allows for using a different factory class that derives from SpeciesThermoFactory. However, no applications of this have been done yet.
stype | String specifying the species thermo type |
f | Pointer to a SpeciesThermoFactory. optional parameter. Defaults to NULL. |
Definition at line 786 of file SpeciesThermoFactory.cpp.
References SpeciesThermoFactory::newSpeciesThermoManager().
SpeciesThermo * newSpeciesThermoMgr | ( | std::vector< XML_Node * > | spDataNodeList, |
SpeciesThermoFactory * | f = 0 |
||
) |
Function to return SpeciesThermo manager.
This utility program will look through species nodes. It will discover what each species needs for its species property managers. Then, it will malloc and return the proper species reference state manager to use.
These functions allow using a different factory class that derives from SpeciesThermoFactory.
spDataNodeList | This vector contains a list of species XML nodes that will be in the phase |
f | Pointer to a SpeciesThermoFactory. optional parameter. Defaults to NULL. |
Definition at line 795 of file SpeciesThermoFactory.cpp.
References SpeciesThermoFactory::newSpeciesThermo().
|
static |
Gather a vector of pointers to XML_Nodes for a phase.
spDataNodeList | Output vector of pointer to XML_Nodes which contain the species XML_Nodes for the species in the current phase. |
spNamesList | Output Vector of strings, which contain the names of the species in the phase |
spRuleList | Output Vector of ints, which contain the value of sprule for each species in the phase |
spArray_names | Vector of pointers to the XML_Nodes which contains the names of the species in the phase |
spArray_dbases | Input vector of pointers to species data bases. We search each data base for the required species names |
sprule | Input vector of sprule values |
Definition at line 278 of file ThermoFactory.cpp.
References XML_Node::child(), XML_Node::getChildren(), ctml::getStringArray(), and XML_Node::nChildren().
Referenced by importPhase().
|
static |
Examine the types of species thermo parameterizations, and return a flag indicating the type of parameterization needed by the species.
spDataNodeList | Species Data XML node. This node contains a list of species XML nodes underneath it. |
has_nasa_idealGas | Boolean indicating that one species has a NASA ideal gas standard state |
has_nasa_constVol | Boolean indicating that one species has a NASA ideal solution standard state |
has_shomate_idealGas | Boolean indicating that one species has a shomate ideal gas standard state |
has_shomate_constVol | Boolean indicating that one species has a shomate ideal solution standard state |
has_simple_idealGas | Boolean indicating that one species has a simple ideal gas standard state |
has_simple_constVol | Boolean indicating that one species has a simple ideal solution standard state |
has_water | Boolean indicating that one species has a water standard state |
has_tpx | Boolean indicating that one species has a tpx standard state |
has_hptx | Boolean indicating that one species has a htpx standard state |
has_other | Boolean indicating that one species has different standard state than the ones listed above |
Definition at line 68 of file VPSSMgrFactory.cpp.
References XML_Node::attrib(), XML_Node::child(), and XML_Node::hasChild().
Referenced by VPSSMgrFactory::newVPSSMgr().
VPSSMgr * newVPSSMgr | ( | VPSSMgr_enumType | type, |
VPStandardStateTP * | vp_ptr, | ||
VPSSMgrFactory * | f = 0 |
||
) |
Create a new species thermo manager instance, by specifying the type and (optionally) a pointer to the factory to use to create it.
This utility program will look through species nodes. It will discover what each species needs for its species property managers. Then, it will malloc and return the proper species property manager to use.
These functions allow using a different factory class that derives from SpeciesThermoFactory.
type | Species thermo type. |
vp_ptr | Variable pressure standard state ThermoPhase object that will be the owner. |
f | Pointer to a SpeciesThermoFactory. optional parameter. Defaults to NULL. |
Definition at line 339 of file VPSSMgrFactory.cpp.
References VPSSMgrFactory::newVPSSMgr().
Referenced by importPhase().
VPSSMgr * newVPSSMgr | ( | VPStandardStateTP * | vp_ptr, |
XML_Node * | phaseNode_ptr, | ||
std::vector< XML_Node * > & | spDataNodeList, | ||
VPSSMgrFactory * | f = 0 |
||
) |
Function to return VPSSMgr manager.
This utility program will look through species nodes. It will discover what each species needs for its species property managers. Then, it will alloc and return the proper species property manager to use.
These functions allow using a different factory class that derives from SpeciesThermoFactory.
vp_ptr | Variable pressure standard state ThermoPhase object that will be the owner. |
phaseNode_ptr | Pointer to the ThermoPhase phase XML Node |
spDataNodeList | This vector contains a list of species XML nodes that will be in the phase |
f | Pointer to a SpeciesThermoFactory. optional parameter. Defaults to NULL. |
Definition at line 349 of file VPSSMgrFactory.cpp.
References VPSSMgrFactory::newVPSSMgr().
Referenced by VPSSMgrFactory::newVPSSMgr().
|
static |
Parses the xml element called Arrhenius.
The Arrhenius expression is
\[ k = A T^(b) exp (-E_a / RT) \]
node | XML_Node to be read |
A | Output pre-exponential factor. The units are variable. |
b | output temperature power |
E | Output activation energy in units of Kelvin |
Definition at line 41 of file LTPspecies.cpp.
References ctml::getFloat().
|
inline |
The Parker temperature correction to the rotational collision number.
tr | Reduced temperature \( \epsilon/kT \) |
sqtr | square root of tr. |
Definition at line 32 of file MultiTransport.cpp.
Referenced by MultiTransport::initGas(), and MultiTransport::updateThermal_T().
|
inline |
Output the current contents of the Array2D object.
Example of usage: s << m << endl;
s | Reference to the ostream to write to |
m | Object of type Array2D that you are querying |
Definition at line 400 of file Array.h.
References Array2D::nColumns(), and Array2D::nRows().
|
inline |
Overload the times equals operator for multiplication of a matrix and a scalar.
Scaled every element of the matrix by the scalar input
m | Matrix |
a | scalar |
Definition at line 422 of file Array.h.
References Array2D::begin(), Array2D::end(), and scale().
|
inline |
Overload the plus equals operator for addition of one matrix with another.
Adds each element of the second matrix into the first matrix
x | First matrix |
y | Second matrix, which is a const |
Definition at line 436 of file Array.h.
References Array2D::begin(), Array2D::end(), and sum_each().
|
inline |
Write a message to the log only if loglevel > 0.
Definition at line 154 of file global.h.
References writelog().
|
inline |
Clip value such that lower <= value <= upper.
Definition at line 324 of file global.h.
Referenced by ThermoPhase::setState_HPorUV(), and ThermoPhase::setState_SPorSV().
|
inline |
Templated Inner product of two vectors of length 4.
If either x or y has length greater than 4, only the first 4 elements will be used.
x | first reference to the templated class V |
y | second reference to the templated class V |
Definition at line 67 of file utilities.h.
Referenced by MixTransport::updateCond_T(), AqueousTransport::updateCond_T(), GasTransport::updateDiff_T(), PecosTransport::updateDiff_T(), AqueousTransport::updateDiff_T(), GasTransport::updateSpeciesViscosities(), and AqueousTransport::updateSpeciesViscosities().
|
inline |
Templated Inner product of two vectors of length 5.
If either x or y has length greater than 4, only the first 4 elements will be used.
x | first reference to the templated class V |
y | second reference to the templated class V |
Definition at line 85 of file utilities.h.
Referenced by MixTransport::updateCond_T(), AqueousTransport::updateCond_T(), GasTransport::updateDiff_T(), PecosTransport::updateDiff_T(), AqueousTransport::updateDiff_T(), GasTransport::updateSpeciesViscosities(), and AqueousTransport::updateSpeciesViscosities().
|
inline |
Templated Inner product of two vectors of length 6.
If either x or y has length greater than 4, only the first 4 elements will be used.
x | first reference to the templated class V |
y | second reference to the templated class V |
Definition at line 103 of file utilities.h.
|
inline |
Function that calculates a templated inner product.
This inner product is templated twice. The output variable is hard coded to return a doublereal.
template<class InputIter, class InputIter2>
x_begin | Iterator pointing to the beginning, belonging to the iterator class InputIter. |
x_end | Iterator pointing to the end, belonging to the iterator class InputIter. |
y_begin | Iterator pointing to the beginning of y, belonging to the iterator class InputIter2. |
Definition at line 131 of file utilities.h.
Referenced by IdealSolnGasVPSS::calcDensity(), RedlichKwongMFTP::calcDensity(), IdealSolidSolnPhase::calcDensity(), ChemEquil::equilibrate(), Phase::mean_Y(), and Phase::setMoleFractions_NoNorm().
|
inline |
Multiply elements of an array by a scale factor.
begin | Iterator pointing to the beginning, belonging to the iterator class InputIter. |
end | Iterator pointing to the end, belonging to the iterator class InputIter. |
out | Iterator pointing to the beginning of out, belonging to the iterator class OutputIter. This is the output variable for this routine. |
scale_factor | input scale factor belonging to the class S. |
Definition at line 154 of file utilities.h.
Referenced by ChemEquil::equilibrate(), ChemEquil::estimateElementPotentials(), Phase::getConcentrations(), SurfPhase::getCp_R(), SurfPhase::getEnthalpy_RT(), SurfPhase::getEntropy_R(), VPSSMgr_General::getGibbs_ref(), VPSSMgr::getGibbs_ref(), MixtureFugacityTP::getGibbs_ref(), IdealGasPhase::getGibbs_ref(), SurfPhase::getGibbs_RT(), DustyGasTransport::getMolarFluxes(), Phase::getMoleFractions(), IdealSolnGasVPSS::getPartialMolarCp(), RedlichKwongMFTP::getPartialMolarCp(), IdealGasPhase::getPartialMolarCp(), IdealSolnGasVPSS::getPartialMolarEnthalpies(), RedlichKwongMFTP::getPartialMolarEnthalpies(), IdealSolidSolnPhase::getPartialMolarEnthalpies(), LatticePhase::getPartialMolarEnthalpies(), IdealGasPhase::getPartialMolarEnthalpies(), IdealSolnGasVPSS::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarEntropies(), IdealGasPhase::getPartialMolarEntropies(), IdealSolnGasVPSS::getPartialMolarIntEnergies(), RedlichKwongMFTP::getPartialMolarIntEnergies(), ConstDensityThermo::getPureGibbs(), MixtureFugacityTP::getPureGibbs(), IdealGasPhase::getPureGibbs(), VPSSMgr::getStandardChemPotentials(), LatticePhase::getStandardChemPotentials(), IdealGasPhase::getStandardChemPotentials(), operator*=(), scale(), Phase::setMassFractions(), and VCS_SOLVE::vcs_elabcheck().
|
inline |
Multiply elements of an array, y, by a scale factor, f and add the result to an existing array, x. This is essentially a templated daxpy_ operation.
The template arguments are: template<class InputIter, class OutputIter, class S>
Simple Code Example of the functionality;
Example of the function call to implement the simple code example
It is templated with three parameters. The first template is the iterator, InputIter, which controls access to y[]. The second template is the iterator OutputIter, which controls access to y[]. The third iterator is S, which is f.
begin | InputIter Iterator for beginning of y[] |
end | inputIter Iterator for end of y[] |
out | OutputIter Iterator for beginning of x[] |
scale_factor | Scale Factor to multiply y[i] by |
Definition at line 192 of file utilities.h.
|
inline |
Multiply each entry in x by the corresponding entry in y.
The template arguments are: template<class InputIter, class OutputIter>
Simple code Equivalent:
Example of function call usage to implement the simple code example:
x_begin | Iterator pointing to the beginning of the vector x, belonging to the iterator class InputIter. |
x_end | Iterator pointing to the end of the vector x, belonging to the iterator class InputIter. The difference between end and begin determines the loop length |
y_begin | Iterator pointing to the beginning of the vector y, belonging to the iterator class outputIter. |
Definition at line 227 of file utilities.h.
Referenced by GasKinetics::getFwdRateConstants(), AqueousKinetics::getFwdRateConstants(), InterfaceKinetics::getFwdRateConstants(), InterfaceKinetics::getRevRateConstants(), and InterfaceKinetics::updateROP().
|
inline |
Invoke method 'resize' with argument m for a sequence of objects (templated version)
The template arguments are: template<class InputIter>
Simple code Equivalent:
Example of function call usage to implement the simple code example:
m | Integer specifying the size that each object should be resized to. |
begin | Iterator pointing to the beginning of the sequence of object, belonging to the iterator class InputIter. |
end | Iterator pointing to the end of the sequence of objects, belonging to the iterator class InputIter. The difference between end and begin determines the loop length |
Definition at line 263 of file utilities.h.
|
inline |
The maximum absolute value (templated version)
The template arguments are: template<class InputIter>
Simple code Equivalent:
Example of function call usage to implement the simple code example:
begin | Iterator pointing to the beginning of the x vector, belonging to the iterator class InputIter. |
end | Iterator pointing to the end of the x vector, belonging to the iterator class InputIter. The difference between end and begin determines the loop length |
Definition at line 295 of file utilities.h.
References amax().
|
inline |
Normalize the values in a sequence, such that they sum to 1.0 (templated version)
The template arguments are: template<class InputIter, class OutputIter>
Simple Equivalent:
Example of function call usage:
begin | Iterator pointing to the beginning of the x vector, belonging to the iterator class InputIter. |
end | Iterator pointing to the end of the x vector, belonging to the iterator class InputIter. The difference between end and begin determines the loop length |
out | Iterator pointing to the beginning of the output vector, belonging to the iterator class OutputIter. |
Definition at line 334 of file utilities.h.
|
inline |
Templated divide of each element of x by the corresponding element of y.
The template arguments are: template<class InputIter, class OutputIter>
Simple Equivalent:
Example of code usage:
x_begin | Iterator pointing to the beginning of the x vector, belonging to the iterator class OutputIter. |
x_end | Iterator pointing to the end of the x vector, belonging to the iterator class OutputIter. The difference between end and begin determines the number of inner iterations. |
y_begin | Iterator pointing to the beginning of the yvector, belonging to the iterator class InputIter. |
Definition at line 369 of file utilities.h.
Referenced by DustyGasTransport::getMolarFluxes().
|
inline |
Increment each entry in x by the corresponding entry in y.
The template arguments are: template<class InputIter, class OutputIter>
x_begin | Iterator pointing to the beginning of the x vector, belonging to the iterator class OutputIter. |
x_end | Iterator pointing to the end of the x vector, belonging to the iterator class OutputIter. The difference between end and begin determines the number of inner iterations. |
y_begin | Iterator pointing to the beginning of the yvector, belonging to the iterator class InputIter. |
Definition at line 390 of file utilities.h.
Referenced by operator+=().
|
inline |
Copies a contiguous range in a sequence to indexed positions in another sequence.
The template arguments are: template<class InputIter, class OutputIter, class IndexIter>
Example:
This routine is templated 3 times. InputIter is an iterator for the source vector OutputIter is an iterator for the destination vector IndexIter is an iterator for the index into the destination vector.
begin | Iterator pointing to the beginning of the source vector, belonging to the iterator class InputIter. |
end | Iterator pointing to the end of the source vector, belonging to the iterator class InputIter. The difference between end and begin determines the number of inner iterations. |
result | Iterator pointing to the beginning of the output vector, belonging to the iterator class outputIter. |
index | Iterator pointing to the beginning of the index vector, belonging to the iterator class IndexIter. |
Definition at line 430 of file utilities.h.
|
inline |
Multiply selected elements in an array by a contiguous sequence of multipliers.
The template arguments are: template<class InputIter, class RandAccessIter, class IndexIter>
Example:
mult_begin | Iterator pointing to the beginning of the multiplier vector, belonging to the iterator class InputIter. |
mult_end | Iterator pointing to the end of the multiplier vector, belonging to the iterator class InputIter. The difference between end and begin determines the number of inner iterations. |
data | Iterator pointing to the beginning of the output vector, belonging to the iterator class RandAccessIter, that will be selectively multiplied. |
index | Iterator pointing to the beginning of the index vector, belonging to the iterator class IndexIter. |
Definition at line 466 of file utilities.h.
|
inline |
Divide selected elements in an array by a contiguous sequence of divisors.
The template arguments are: template<class InputIter, class OutputIter, class IndexIter>
Example:
begin | Iterator pointing to the beginning of the source vector, belonging to the iterator class InputIter. |
end | Iterator pointing to the end of the source vector, belonging to the iterator class InputIter. The difference between end and begin determines the number of inner iterations. |
result | Iterator pointing to the beginning of the output vector, belonging to the iterator class outputIter. |
index | Iterator pointing to the beginning of the index vector, belonging to the iterator class IndexIter. |
Definition at line 501 of file utilities.h.
|
inline |
Compute
\[ \sum_k x_k \log x_k. \]
.
The template arguments are: template<class InputIter>
A small number (1.0E-20) is added before taking the log. This templated class does the indicated sun. The template must be an iterator.
begin | Iterator pointing to the beginning, belonging to the iterator class InputIter. |
end | Iterator pointing to the end, belonging to the iterator class InputIter. |
Definition at line 524 of file utilities.h.
References Tiny.
Referenced by Phase::sum_xlogx().
|
inline |
Compute
\[ \sum_k x_k \log Q_k. \]
.
The template arguments are: template<class InputIter1, class InputIter2>
This class is templated twice. The first template, InputIter1 is the iterator that points to $x_k$. The second iterator InputIter2, point to $Q_k$. A small number (1.0E-20) is added before taking the log.
begin | Iterator pointing to the beginning, belonging to the iterator class InputIter1. |
end | Iterator pointing to the end, belonging to the iterator class InputIter1. |
Q_begin | Iterator pointing to the beginning of Q_k, belonging to the iterator class InputIter2. |
Definition at line 552 of file utilities.h.
References Tiny.
Referenced by Phase::sum_xlogQ().
|
inline |
Scale a templated vector by a constant factor.
The template arguments are: template<class OutputIter>
This function is essentially a wrapper around the stl function scale(). The function is has one template parameter, OutputIter. OutputIter is a templated iterator that points to the vector to be scaled.
N | Length of the vector |
alpha | scale factor - double |
x | Templated Iterator to the start of the vector to be scaled. |
Definition at line 577 of file utilities.h.
References scale().
R Cantera::poly6 | ( | D | x, |
R * | c | ||
) |
Templated evaluation of a polynomial of order 6.
x | Value of the independent variable - First template parameter |
c | Pointer to the polynomial - Second template parameter |
Definition at line 589 of file utilities.h.
Referenced by MultiTransport::updateThermal_T().
R Cantera::poly8 | ( | D | x, |
R * | c | ||
) |
Templated evaluation of a polynomial of order 8.
x | Value of the independent variable - First template parameter |
c | Pointer to the polynomial - Second template parameter |
Definition at line 601 of file utilities.h.
Referenced by MultiTransport::updateThermal_T().
R Cantera::poly10 | ( | D | x, |
R * | c | ||
) |
Templated evaluation of a polynomial of order 10.
x | Value of the independent variable - First template parameter |
c | Pointer to the polynomial - Second template parameter |
Definition at line 613 of file utilities.h.
R Cantera::poly5 | ( | D | x, |
R * | c | ||
) |
Templated evaluation of a polynomial of order 5.
x | Value of the independent variable - First template parameter |
c | Pointer to the polynomial - Second template parameter |
Definition at line 626 of file utilities.h.
R Cantera::poly4 | ( | D | x, |
R * | c | ||
) |
Evaluates a polynomial of order 4.
x | Value of the independent variable. |
c | Pointer to the polynomial coefficient array. |
Definition at line 638 of file utilities.h.
Referenced by NasaThermo::cp_R(), and TransportFactory::fitProperties().
R Cantera::poly3 | ( | D | x, |
R * | c | ||
) |
Templated evaluation of a polynomial of order 3.
x | Value of the independent variable - First template parameter |
c | Pointer to the polynomial - Second template parameter |
Definition at line 650 of file utilities.h.
Referenced by TransportFactory::fitProperties().
void Cantera::deepStdVectorPointerCopy | ( | const std::vector< D * > & | fromVec, |
std::vector< D * > & | toVec | ||
) |
Templated deep copy of a std vector of pointers.
Performs a deep copy of a std vectors of pointers to an object. This template assumes that that the templated object has a functioning copy constructor. It also assumes that pointers are zero when they are not malloced.
fromVec | Vector of pointers to a templated class. This will be deep-copied to the other vector |
toVec | Vector of pointers to a templated class. This will be overwritten and on return will be a copy of the fromVec |
Definition at line 667 of file utilities.h.
|
inline |
Templated function that copies the first n entries from x to y.
The templated type is the type of x and y
n | Number of elements to copy from x to y |
x | The object x, of templated type const T& |
y | The object y, of templated type T& |
Definition at line 35 of file vec_functions.h.
|
inline |
Divide each element of x by the corresponding element of y.
This function replaces x[n] by x[n]/y[n], for 0 <= n < x.size()
x | Numerator object of the division operation with template type T At the end of the calculation, it contains the result. |
y | Denominator object of the division template type T |
Definition at line 49 of file vec_functions.h.
|
inline |
Multiply each element of x by the corresponding element of y.
This function replaces x[n] by x[n]*y[n], for 0 <= n < x.size() This is a templated function with just one template type.
x | First object of the multiplication with template type T At the end of the calculation, it contains the result. |
y | Second object of the multiplication with template type T |
Definition at line 66 of file vec_functions.h.
|
inline |
Multiply each element of x by scale_factor.
This function replaces x[n] by x[n]*scale_factor, for 0 <= n < x.size()
x | First object of the multiplication with template type T At the end of the calculation, it contains the result. |
scale_factor | scale factor with template type S |
Definition at line 81 of file vec_functions.h.
References scale().
|
inline |
Return the templated dot product of two objects.
Returns the sum of x[n]*y[n], for 0 <= n < x.size().
x | First object of the dot product with template type T At the end of the calculation, it contains the result. |
y | Second object of the dot product with template type T |
Definition at line 95 of file vec_functions.h.
|
inline |
Returns the templated dot ratio of two objects.
Returns the sum of x[n]/y[n], for 0 <= n < x.size().
x | First object of the dot product with template type T At the end of the calculation, it contains the result. |
y | Second object of the dot product with template type T |
Definition at line 109 of file vec_functions.h.
References _dot_ratio().
|
inline |
Returns a templated addition operation of two objects.
Replaces x[n] by x[n] + y[n] for 0 <= n < x.size()
x | First object of the addition with template type T At the end of the calculation, it contains the result. |
y | Second object of the addition with template type T |
Definition at line 123 of file vec_functions.h.
|
inline |
Templated dot ratio class.
Calculates the quantity:
S += x[n]/y[n]
The first templated type is the iterator type for x[] and y[]. The second templated type is the type of S.
x_begin | InputIter type, indicating the address of the first element of x |
x_end | InputIter type, indicating the address of the last element of x |
y_begin | InputIter type, indicating the address of the first element of y |
start_value | S type, indicating the type of the accumulation result. |
Definition at line 149 of file vec_functions.h.
Referenced by dot_ratio().
|
inline |
Finds the entry in a vector with maximum absolute value, and return this value.
v | Vector to be queried for maximum value, with template type T |
Definition at line 167 of file vec_functions.h.
|
inline |
Write a vector to a stream.
Definition at line 186 of file vec_functions.h.
|
inline |
Function to output a MultiPhase description to a stream.
Writes out a description of the contents of each phase of the MultiPhase using the report function.
s | ostream |
x | Reference to a MultiPhase |
Definition at line 665 of file MultiPhase.h.
References Phase::name(), MultiPhase::nPhases(), MultiPhase::phase(), MultiPhase::phaseMoles(), and ThermoPhase::report().
|
inline |
Import an instance of class Interface from a specification in an input file.
This is the preferred method to create an Interface instance.
Definition at line 108 of file Interface.h.
|
inline |
Create a new kinetics manager.
Definition at line 86 of file KineticsFactory.h.
|
inline |
Create a new kinetics manager.
Definition at line 98 of file KineticsFactory.h.
|
inline |
work | Must be dimensioned equal to greater than 3N |
iwork | Must be dimensioned equal to or greater than N |
Definition at line 442 of file ctlapack.h.
Referenced by SquareMatrix::rcondQR().
|
inline |
|
inline |
Convert from wavenumbers to Joules.
Definition at line 76 of file rotor.h.
References lightSpeed, and Planck.
Referenced by Rotor::partitionFunction(), and Rotor::relPopulation().
|
static |
Mutex for input directory access.
Definition at line 44 of file application.cpp.
Referenced by Application::addDataDirectory(), and Application::findInputFile().
|
static |
Mutex for creating singletons within the application object.
Definition at line 47 of file application.cpp.
Referenced by Application::ApplicationDestroy(), and Application::Instance().
|
static |
Mutex for controlling access to XML file storage.
Definition at line 50 of file application.cpp.
Referenced by Application::close_XML_File(), and Application::get_XML_File().
|
static |
Mutex for access to string messages.
Definition at line 294 of file application.cpp.
Referenced by Application::ThreadMessages::operator->(), and Application::ThreadMessages::removeThreadMessages().
const int g_DEBUG_MODE = 0 |
Definition of whether the DEBUG_MODE environment is turned on within Cantera.
Declaration for whether the Debug mode is turned on within Cantera.
Turn on the mode by using the following compile time syntax
scons debug_verbose=True build
Definition at line 22 of file global.cpp.
int BasisOptimize_print_lvl = 0 |
External int that is used to turn on debug printing for the BasisOptimze program.
Set this to 1 if you want debug printing from BasisOptimize.
Definition at line 14 of file BasisOptimize.cpp.
Referenced by BasisOptimize(), and ElemRearrange().
const doublereal DampFactor = 4 |
Dampfactor is the factor by which the damping factor is reduced by when a reduction in step length is warranted.
Definition at line 1327 of file BEulerInt.cpp.
Referenced by MultiNewton::dampStep(), BEulerInt::dampStep(), and NonlinearSolver::dampStep().
const size_t NDAMP = 10 |
Number of damping steps that are carried out before the solution is deemed a failure.
Definition at line 1328 of file BEulerInt.cpp.
Referenced by NonlinearSolver::dampDogLeg(), MultiNewton::dampStep(), BEulerInt::dampStep(), and NonlinearSolver::dampStep().
const string dashedline |
Definition at line 151 of file MultiNewton.cpp.
|
static |
aWTable is a vector containing the atomic weights database.
The size of the table is given by the initial instantiation.
Definition at line 42 of file Elements.cpp.
Referenced by Elements::LookupWtElements(), and LookupWtElements().
|
static |
Define the number of ThermoPhase types for use in this factory routine.
Definition at line 66 of file ThermoFactory.cpp.
Referenced by eosTypeString(), and ThermoFactory::newThermoPhase().
|
static |
Define the string name of the ThermoPhase types that are handled by this factory routine.
Definition at line 69 of file ThermoFactory.cpp.
Referenced by eosTypeString(), and ThermoFactory::newThermoPhase().
|
static |
Define the integer id of the ThermoPhase types that are handled by this factory routine.
Definition at line 81 of file ThermoFactory.cpp.
Referenced by eosTypeString(), and ThermoFactory::newThermoPhase().
const doublereal T_c = 647.096 |
Critical Temperature value (kelvin)
Definition at line 22 of file WaterPropsIAPWS.cpp.
Referenced by WaterPropsIAPWS::calcDim(), WaterPropsIAPWSphi::check1(), WaterPropsIAPWSphi::check2(), WaterPropsIAPWS::density(), WaterPropsIAPWS::density_const(), WaterPropsIAPWS::densSpinodalSteam(), WaterPropsIAPWS::densSpinodalWater(), WaterPropsIAPWS::dpdrho(), WaterPropsIAPWS::enthalpy(), WaterPropsIAPWS::Gibbs(), WaterPropsIAPWS::helmholtzFE(), WaterPropsIAPWS::intEnergy(), WaterPropsIAPWS::phaseState(), WaterPropsIAPWS::pressure(), WaterPropsIAPWS::psat(), and WaterPropsIAPWS::temperature().
|
static |
Critical Pressure (Pascals)
Definition at line 24 of file WaterPropsIAPWS.cpp.
Referenced by WaterPropsIAPWS::psat().
const doublereal Rho_c = 322. |
Value of the Density at the critical point (kg m-3)
Definition at line 26 of file WaterPropsIAPWS.cpp.
Referenced by WaterPropsIAPWS::calcDim(), WaterPropsIAPWSphi::check1(), WaterPropsIAPWSphi::check2(), WaterPropsIAPWS::coeffThermExp(), WaterPropsIAPWS::density(), WaterPropsIAPWS::density_const(), WaterPropsIAPWS::densSpinodalSteam(), WaterPropsIAPWS::densSpinodalWater(), WaterPropsIAPWS::isothermalCompressibility(), WaterPropsIAPWS::molarVolume(), WaterPropsIAPWS::phaseState(), and WaterPropsIAPWS::pressure().
|
static |
Molecular Weight of water that is consistent with the paper (kg kmol-1)
Definition at line 28 of file WaterPropsIAPWS.cpp.
Referenced by WaterPropsIAPWS::coeffThermExp(), WaterPropsIAPWS::corr1(), WaterPropsIAPWS::density(), WaterPropsIAPWS::density_const(), WaterPropsIAPWS::dpdrho(), WaterPropsIAPWS::molarVolume(), WaterPropsIAPWS::phaseState(), WaterPropsIAPWS::pressure(), and WaterPropsIAPWS::psat().
|
static |
Gas constant that is quoted in the paper.
Definition at line 37 of file WaterPropsIAPWS.cpp.
Referenced by WaterPropsIAPWS::coeffThermExp(), WaterPropsIAPWS::corr1(), WaterPropsIAPWS::cp(), WaterPropsIAPWS::cv(), WaterPropsIAPWS::density(), WaterPropsIAPWS::density_const(), WaterPropsIAPWS::dpdrho(), WaterPropsIAPWS::enthalpy(), WaterPropsIAPWS::entropy(), WaterPropsIAPWS::Gibbs(), WaterPropsIAPWS::helmholtzFE(), WaterPropsIAPWS::intEnergy(), WaterPropsIAPWS::phaseState(), WaterPropsIAPWS::pressure(), and WaterPropsIAPWS::psat().
const doublereal Min_C_Internal = 0.001 |
Constant to compare dimensionless heat capacities against zero.
Definition at line 16 of file L_matrix.h.
|
static |
Definition at line 23 of file ReactorFactory.cpp.
|
static |
Definition at line 29 of file ReactorFactory.cpp.
const doublereal OneThird = 1.0/3.0 |
1/3
Definition at line 128 of file ct_defs.h.
Referenced by NasaThermo::enthalpy_RT(), NasaThermo::entropy_R(), Nasa9Poly1::updateProperties(), NasaPoly1::updateProperties(), and ShomatePoly::updateProperties().
const doublereal FiveSixteenths = 5.0/16.0 |
const doublereal SqrtTen = std::sqrt(10.0) |
sqrt(10)
Definition at line 132 of file ct_defs.h.
Referenced by TransportFactory::getTransportData().
const doublereal SqrtEight = std::sqrt(8.0) |
sqrt(8)
Definition at line 134 of file ct_defs.h.
Referenced by GasTransport::updateViscosity_T(), PecosTransport::updateViscosity_T(), and AqueousTransport::updateViscosity_T().
const doublereal SqrtTwo = std::sqrt(2.0) |
sqrt(2)
Definition at line 136 of file ct_defs.h.
Referenced by GaussianProfile::cumulative(), Voigt::F(), GaussianProfile::profile(), and Voigt::Voigt().
const doublereal SmallNumber = 1.e-300 |
smallest number to compare to zero.
Definition at line 139 of file ct_defs.h.
Referenced by MultiNewton::dampStep(), Troe3::F(), Troe4::F(), SRI3::F(), SRI5::F(), WF93::F(), ConstDensityThermo::getChemPotentials(), MolarityIonicVPSSTP::getChemPotentials(), IdealSolnGasVPSS::getChemPotentials(), IonsFromNeutralVPSSTP::getChemPotentials(), RedlichKwongMFTP::getChemPotentials(), RedlichKisterVPSSTP::getChemPotentials(), MixedSolventElectrolyte::getChemPotentials(), MargulesVPSSTP::getChemPotentials(), PhaseCombo_Interaction::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials(), IdealMolalSoln::getChemPotentials(), LatticePhase::getChemPotentials(), IdealGasPhase::getChemPotentials(), DebyeHuckel::getChemPotentials(), HMWSoln::getChemPotentials(), IdealSolidSolnPhase::getChemPotentials_RT(), PhaseCombo_Interaction::getdlnActCoeffds(), MolarityIonicVPSSTP::getPartialMolarEntropies(), IdealSolnGasVPSS::getPartialMolarEntropies(), IonsFromNeutralVPSSTP::getPartialMolarEntropies(), RedlichKwongMFTP::getPartialMolarEntropies(), RedlichKisterVPSSTP::getPartialMolarEntropies(), MixedSolventElectrolyte::getPartialMolarEntropies(), MargulesVPSSTP::getPartialMolarEntropies(), PhaseCombo_Interaction::getPartialMolarEntropies(), IdealSolidSolnPhase::getPartialMolarEntropies(), IdealMolalSoln::getPartialMolarEntropies(), LatticePhase::getPartialMolarEntropies(), IdealGasPhase::getPartialMolarEntropies(), DebyeHuckel::getPartialMolarEntropies(), HMWSoln::getPartialMolarEntropies(), MolalityVPSSTP::report(), ThermoPhase::report(), ThermoPhase::reportCSV(), PhaseCombo_Interaction::s_update_dlnActCoeff_dlnN(), PhaseCombo_Interaction::s_update_dlnActCoeff_dlnN_diag(), PhaseCombo_Interaction::s_update_lnActCoeff(), Troe3::updateTemp(), and Troe4::updateTemp().
const doublereal BigNumber = 1.e300 |
largest number to compare to inf.
Definition at line 141 of file ct_defs.h.
Referenced by GasKinetics::updateKc().
const doublereal MaxExp = 690.775527898 |
const doublereal Undef = -999.1234 |
Fairly random number to be used to initialize variables against to see if they are subsequently defined.
Definition at line 147 of file ct_defs.h.
Referenced by StFlow::_finalize(), ctml::addFloat(), ctml::addFloatArray(), ctml::addNamedFloatArray(), MultiPhase::equilibrate(), vcs_MultiPhaseEquil::equilibrate_HP(), vcs_MultiPhaseEquil::equilibrate_SP(), ctml::getFloatArray(), ctml::getFloatCurrent(), ctml::getFloats(), StFlow::save(), and StFlow::StFlow().
const doublereal Tiny = 1.e-20 |
Small number to compare differences of mole fractions against.
This number is used for the interconversion of mole fraction and mass fraction quantities when the molecular weight of a species is zero. It's also used for the matrix inversion of transport properties when mole fractions must be positive.
Definition at line 155 of file ct_defs.h.
Referenced by MultiPhaseEquil::computeReactionSteps(), MultiPhaseEquil::getComponents(), ctml::getFloatArray(), ctml::getFloatCurrent(), ctml::getFloats(), Phase::init(), OneDim::initTimeInteg(), MultiPhaseEquil::stepComposition(), sum_xlogQ(), sum_xlogx(), PecosTransport::update_C(), MixTransport::update_C(), MultiTransport::update_C(), AqueousTransport::update_C(), LiquidTransport::update_C(), and DustyGasTransport::updateTransport_C().
const size_t npos = static_cast<size_t>(-1) |
index returned by functions to indicate "no position"
Definition at line 173 of file ct_defs.h.
Referenced by VCS_PROB::addOnePhaseSpecies(), VCS_PROB::addPhaseElements(), Phase::addUniqueElementAfterFreeze(), BasisOptimize(), NonlinearSolver::boundStep(), solveProb::calc_damping(), HMWSoln::calcMolalitiesCropped(), IonsFromNeutralVPSSTP::calcNeutralMoleculeMoleFractions(), MolarityIonicVPSSTP::calcPseudoBinaryMoleFractions(), SquareMatrix::checkColumns(), BandMatrix::checkColumns(), SquareMatrix::checkRows(), BandMatrix::checkRows(), XML_Node::child(), vcs_MultiPhaseEquil::component(), ConstPressureReactor::componentIndex(), FlowReactor::componentIndex(), Reactor::componentIndex(), MultiPhase::elementIndex(), Phase::elementIndex(), ElemRearrange(), ChemEquil::equilibrate(), ChemEquil::estimateEP_Brinkley(), MultiJac::eval(), Inlet1D::eval(), Empty1D::eval(), Symm1D::eval(), Outlet1D::eval(), StFlow::eval(), OutletRes1D::eval(), Surf1D::eval(), Domain1D::eval(), ReactingSurf1D::eval(), Domain1D::evalss(), ReactionPathDiagram::exportToDot(), EdgeKinetics::finalize(), InterfaceKinetics::finalize(), MolalityVPSSTP::findCLMIndex(), findFirstNotOfWS(), findFirstWS(), Application::findInputFile(), XML_Reader::findQuotedString(), findUnbackslashed(), ctml::get_CTML_Tree(), Application::get_XML_File(), MultiPhaseEquil::getComponents(), getEfficiencies(), ctml::getFloatArray(), ctml::getMap(), ctml::getMatrixValues(), IonsFromNeutralVPSSTP::getNeutralMoleculeMoleGrads(), ctml::getPairs(), getReagents(), ImplicitSurfChem::ImplicitSurfChem(), importKinetics(), importSolution(), LiquidTranInteraction::init(), MultiPhase::init(), ChemEquil::initialize(), WaterSSTP::initThermoXML(), IonsFromNeutralVPSSTP::initThermoXML(), IdealMolalSoln::initThermoXML(), DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), installReactionArrays(), LatticeSolidPhase::installSlavePhases(), installSpecies(), invert(), Kinetics::kineticsSpeciesIndex(), Kinetics::kineticsSpeciesName(), LookupGe(), PDSS_HKFT::LookupGe(), MargulesVPSSTP::MargulesVPSSTP(), Phase::massFraction(), NasaThermo::maxTemp(), GeneralSpeciesThermo::maxTemp(), LatticeSolidPhase::maxTemp(), SimpleThermo::maxTemp(), ShomateThermo::maxTemp(), VPSSMgr::maxTemp(), NasaThermo::minTemp(), GeneralSpeciesThermo::minTemp(), LatticeSolidPhase::minTemp(), SimpleThermo::minTemp(), ShomateThermo::minTemp(), VPSSMgr::minTemp(), MixedSolventElectrolyte::MixedSolventElectrolyte(), Phase::moleFraction(), Reactor::nSensParams(), vcs_MultiPhaseEquil::numComponents(), vcs_MultiPhaseEquil::numElemConstraints(), FlowDevice::outletSpeciesMassFlowRate(), parseCompString(), parseSpeciesName(), XML_Reader::parseTag(), PhaseCombo_Interaction::PhaseCombo_Interaction(), Kinetics::phaseIndex(), NonlinearSolver::print_solnDelta_norm_contrib(), solveProb::printFinal(), solveProb::printIteration(), Mu0Poly::processCoeffs(), HMWSoln::readXMLBinarySalt(), RedlichKisterVPSSTP::readXMLBinarySpecies(), MixedSolventElectrolyte::readXMLBinarySpecies(), MargulesVPSSTP::readXMLBinarySpecies(), PhaseCombo_Interaction::readXMLBinarySpecies(), RedlichKwongMFTP::readXMLCrossFluid(), HMWSoln::readXMLLambdaNeutral(), HMWSoln::readXMLMunnnNeutral(), HMWSoln::readXMLPsiCommonAnion(), HMWSoln::readXMLPsiCommonCation(), RedlichKwongMFTP::readXMLPureFluid(), HMWSoln::readXMLThetaAnion(), HMWSoln::readXMLThetaCation(), HMWSoln::readXMLZetaCation(), RedlichKisterVPSSTP::RedlichKisterVPSSTP(), GeneralSpeciesThermo::refPressure(), VPSSMgr::refPressure(), HMWSoln::relative_molal_enthalpy(), MolalityVPSSTP::report(), NonlinearSolver::residErrorNorm(), vcs_VolPhase::resize(), OneDim::resize(), RedlichKisterVPSSTP::resizeNumInteractions(), MixedSolventElectrolyte::resizeNumInteractions(), MargulesVPSSTP::resizeNumInteractions(), PhaseCombo_Interaction::resizeNumInteractions(), StFlow::restore(), Inlet1D::restore(), OutletRes1D::restore(), ReactingSurf1D::restore(), Wall::setKinetics(), MolalityVPSSTP::setMolalitiesByName(), vcs_VolPhase::setMolesFromVCS(), Domain1D::setSteadyTolerances(), Domain1D::setTransientTolerances(), NonlinearSolver::solnErrorNorm(), OneDim::solve(), MultiNewton::solve(), solveProb::solve(), solveSP::solveSP(), Phase::speciesIndex(), MultiPhase::speciesIndex(), Kinetics::speciesPhase(), Kinetics::speciesPhaseIndex(), split(), split_at_pound(), OneDim::ssnorm(), MultiNewton::step(), STITbyPDSS::STITbyPDSS(), tokenizeString(), Unit::toSI(), vcs_VolPhase::transferElementsFM(), InterfaceKinetics::updateKc(), STITbyPDSS::updatePropertiesTemp(), VCS_SOLVE::vcs_basopt(), VCSnonideal::vcs_Cantera_update_vprob(), VCS_SOLVE::vcs_elcorr(), VCS_SOLVE::vcs_elem_rearrange(), VCS_SOLVE::vcs_phaseStabilityTest(), VCS_SOLVE::vcs_popPhaseID(), VCS_PROB::VCS_PROB(), VCS_SOLVE::vcs_RxnStepSizes(), VCS_SOLVE::vcs_solve_TP(), VCSnonideal::vcsUtil_gaussj(), VCSnonideal::vcsUtil_mlequ_preprocess(), XML_Node::write_int(), and Application::Messages::write_logfile().
const int ELEMENTARY_RXN = 1 |
A reaction with a rate coefficient that depends only on temperature.
Example: O + OH <-> O2 + H
Definition at line 26 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), AqueousKinetics::addReaction(), getRateCoefficient(), and rxninfo::installReaction().
const int THREE_BODY_RXN = 2 |
A reaction that requires a third-body collision partner.
Example: O2 + M <-> O + O + M
Definition at line 32 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), getRateCoefficient(), and rxninfo::installReaction().
const int FALLOFF_RXN = 4 |
The general form for an association or dissociation reaction, with a pressure-dependent rate.
Example: CH3 + H (+M) <-> CH4 (+M)
Definition at line 38 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), getRateCoefficient(), rxninfo::installReaction(), and FalloffMgr::pr_to_falloff().
const int PLOG_RXN = 5 |
A pressure-dependent rate expression consisting of several Arrhenius rate expressions evaluated at different pressures.
The final rate is calculated by logarithmically interpolating between the two rates that bracket the current pressure.
Definition at line 46 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), getRateCoefficient(), and rxninfo::installReaction().
const int CHEBYSHEV_RXN = 6 |
A general pressure-dependent reaction where k(T,P) is defined in terms of a bivariate Chebyshev polynomial.
Definition at line 52 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), getRateCoefficient(), and rxninfo::installReaction().
const int CHEMACT_RXN = 8 |
A chemical activation reaction.
For these reactions, the rate falls off as the pressure increases, due to collisional stabilization of a reaction intermediate. Example: Si + SiH4 (+M) <-> Si2H2 + H2 (+M), which competes with Si + SiH4 (+M) <-> Si2H4 (+M).
Definition at line 60 of file reaction_defs.h.
Referenced by GasKinetics::addReaction(), getRateCoefficient(), and rxninfo::installReaction().
const int SURFACE_RXN = 20 |
A reaction occurring on a surface.
Definition at line 65 of file reaction_defs.h.
Referenced by getRateCoefficient(), and rxninfo::installReaction().
const int EDGE_RXN = 22 |
A reaction occurring at a one-dimensional interface between two surface phases.
Definition at line 71 of file reaction_defs.h.
Referenced by getRateCoefficient(), and rxninfo::installReaction().
const int GLOBAL_RXN = 30 |
A global reaction.
These may have non-integral reaction orders, and are not allowed to be reversible.
Definition at line 77 of file reaction_defs.h.
const int cEST_solvent = 0 |
Electrolyte species type.
Definition at line 19 of file electrolytes.h.
Referenced by DebyeHuckel::initThermoXML(), HMWSoln::initThermoXML(), interp_est(), and HMWSoln::interp_est().
const int cHMWSoln0 = 45010 |
eosTypes returned for this ThermoPhase Object
Definition at line 41 of file electrolytes.h.
Referenced by HMWSoln::eosType().
const int cDebyeHuckel0 = 46010 |
eosTypes returned for this ThermoPhase Object
Definition at line 48 of file electrolytes.h.
Referenced by DebyeHuckel::eosType().
const int cNone = 0 |
This generic id is used as the default in virtual base classes that employ id's.
It is used to indicate the lack of an inherited class that would define the id.
Definition at line 13 of file mix_defs.h.
const int cIdealGas = 1 |
Equation of state types:
These types are used in the member function eosType() of the virtual base class ThermoPhase. They are used to distinguish different types of equation of states. Also, they may be used for upcasting from the ThermoPhase class. Their id's should be distinct.
Users who wish to define their own equation of states which derive from ThermoPhase should define a unique id which doesn't conflict with those listed below. The Cantera Kernel however, will not be know about the class and will therefore not be able to initialize the class within its "factory" routines.
Definition at line 37 of file mix_defs.h.
Referenced by IdealGasPhase::eosType(), ThermoFactory::newThermoPhase(), vcs_VolPhase::setPtrThermoPhase(), IdealGasReactor::setThermoMgr(), IdealGasConstPressureReactor::setThermoMgr(), and VCSnonideal::vcs_Cantera_to_vprob().
const int cSurf = 3 |
A surface phase. Used by class SurfPhase.
Definition at line 40 of file mix_defs.h.
Referenced by Kinetics::addPhase(), SurfPhase::eosType(), getStick(), ThermoFactory::newThermoPhase(), vcs_VolPhase::setPtrThermoPhase(), and VCSnonideal::vcs_Cantera_to_vprob().
const int cMetal = 4 |
A metal phase.
Definition at line 43 of file mix_defs.h.
Referenced by MetalPhase::eosType(), ThermoFactory::newThermoPhase(), and vcs_VolPhase::setPtrThermoPhase().
const int cEdge = 6 |
An edge between two 2D surfaces.
Definition at line 58 of file mix_defs.h.
Referenced by Kinetics::addPhase(), EdgePhase::eosType(), getStick(), ThermoFactory::newThermoPhase(), vcs_VolPhase::setPtrThermoPhase(), and VCSnonideal::vcs_Cantera_to_vprob().
const int cFixedChemPot = 70 |
Stoichiometric compound with a constant chemical potential.
Definition at line 61 of file mix_defs.h.
Referenced by FixedChemPotSSTP::eosType(), and ThermoFactory::newThermoPhase().
const int cIdealSolidSolnPhase = 5009 |
Constant partial molar volume solution IdealSolidSolnPhase.h.
Definition at line 64 of file mix_defs.h.
Referenced by ThermoFactory::newThermoPhase(), and vcs_VolPhase::setPtrThermoPhase().
const int cHMW = 40 |
HMW - Strong electrolyte using the Pitzer formulation.
Definition at line 67 of file mix_defs.h.
Referenced by ThermoFactory::newThermoPhase().
const int cDebyeHuckel = 50 |
DebyeHuckel - Weak electrolyte using various Debye-Huckel formulations.
Definition at line 70 of file mix_defs.h.
Referenced by ThermoFactory::newThermoPhase().
const int cIdealMolalSoln = 60 |
IdealMolalSoln - molality based solution with molality-based act coeffs of 1.
Definition at line 73 of file mix_defs.h.
Referenced by ThermoFactory::newThermoPhase().
const int cMixtureFugacityTP = 700 |
Fugacity Models.
Definition at line 79 of file mix_defs.h.
const int cVPSS_IdealGas = 1001 |
Variable Pressure Standard State ThermoPhase objects.
Definition at line 94 of file mix_defs.h.
Referenced by ThermoFactory::newThermoPhase(), and VPSSMgrFactory::newVPSSMgr().
const int PHSCALE_PITZER = 0 |
Scale to be used for the output of single-ion activity coefficients is that used by Pitzer.
This is the internal scale used within the code. One property is that the activity coefficients for the cation and anion of a single salt will be equal. This scale is the one presumed by the formulation of the single-ion activity coefficients described in this report.
Activity coefficients for species k may be altered between scales s1 to s2 using the following formula
\[ ln(\gamma_k^{s2}) = ln(\gamma_k^{s1}) + \frac{z_k}{z_j} \left( ln(\gamma_j^{s2}) - ln(\gamma_j^{s1}) \right) \]
where j is any one species.
Definition at line 855 of file MolalityVPSSTP.h.
Referenced by HMWSoln::applyphScale(), HMWSoln::s_updateScaling_pHScaling(), HMWSoln::s_updateScaling_pHScaling_dP(), HMWSoln::s_updateScaling_pHScaling_dT(), HMWSoln::s_updateScaling_pHScaling_dT2(), and MolalityVPSSTP::setpHScale().
const int PHSCALE_NBS = 1 |
Scale to be used for evaluation of single-ion activity coefficients is that used by the NBS standard for evaluation of the pH variable.
This is not the internal scale used within the code.
Activity coefficients for species k may be altered between scales s1 to s2 using the following formula
\[ ln(\gamma_k^{s2}) = ln(\gamma_k^{s1}) + \frac{z_k}{z_j} \left( ln(\gamma_j^{s2}) - ln(\gamma_j^{s1}) \right) \]
where j is any one species. For the NBS scale, j is equal to the Cl- species and
\[ ln(\gamma_{Cl-}^{s2}) = \frac{-A_{\phi} \sqrt{I}}{1.0 + 1.5 \sqrt{I}} \]
This is the NBS pH scale, which is used in all conventional pH measurements. and is based on the Bates-Guggenheim equations.
Definition at line 880 of file MolalityVPSSTP.h.
Referenced by HMWSoln::applyphScale(), HMWSoln::s_updateScaling_pHScaling(), HMWSoln::s_updateScaling_pHScaling_dP(), HMWSoln::s_updateScaling_pHScaling_dT(), HMWSoln::s_updateScaling_pHScaling_dT2(), and MolalityVPSSTP::setpHScale().
const int cAC_CONVENTION_MOLAR = 0 |
Standard state uses the molar convention.
Definition at line 24 of file ThermoPhase.h.
Referenced by ThermoPhase::activityConvention().
const int cAC_CONVENTION_MOLALITY = 1 |
Standard state uses the molality convention.
Definition at line 26 of file ThermoPhase.h.
Referenced by MolalityVPSSTP::activityConvention(), and LiquidTransport::stefan_maxwell_solve().
const int cSS_CONVENTION_TEMPERATURE = 0 |
Standard state uses the molar convention.
Definition at line 34 of file ThermoPhase.h.
Referenced by importPhase(), MixtureFugacityTP::standardStateConvention(), and PureFluidPhase::standardStateConvention().
const int cSS_CONVENTION_VPSS = 1 |
Standard state uses the molality convention.
Definition at line 36 of file ThermoPhase.h.
Referenced by importPhase(), and VPStandardStateTP::standardStateConvention().
const int cSS_CONVENTION_SLAVE = 2 |
Standard state thermodynamics is obtained from slave ThermoPhase objects.
Definition at line 38 of file ThermoPhase.h.
Referenced by importPhase(), and LatticeSolidPhase::standardStateConvention().