79 for (
size_t e = 0; e < eSize; e++) {
103 double test = -1.0e-10;
104 bool modifiedSoln =
false;
112 if (fabs(sum) < 1.0E-6) {
130 double* aw = &awSpace[0];
132 plogf(
"vcs_prep_oneTime: failed to get memory: global bailout\n");
139 retn =
vcs_basopt(
true, aw, sa, sm, ss, test, &conv);
141 plogf(
"vcs_prep_oneTime:");
142 plogf(
" Determination of number of components failed: %d\n",
144 plogf(
" Global Bailout!\n");
165 plogf(
"vcs_prep_oneTime:");
166 plogf(
" Determination of element reordering failed: %d\n",
168 plogf(
" Global Bailout!\n");
201 for (
size_t e = 0; e < vprob->
ne; e++) {
202 sum += vprob->
gai[e];
205 plogf(
"vcs_wellPosed: Element abundance is close to zero\n");
void vcs_SSPhase()
Calculate the status of single species phases.
int vcs_elem_rearrange(double *const aw, double *const sa, double *const sm, double *const ss)
Rearrange the constraint equations represented by the Formula Matrix so that the operational ones are...
std::vector< size_t > m_phaseID
Mapping from the species number to the phase number.
vector_fp FormulaMatrixCol
Column of the formula matrix, comprising the element composition of the species.
vector_int m_speciesUnknownType
Specifies the species unknown type.
bool m_singleSpecies
If true, this phase consists of a single species.
vector_fp m_SSfeSpecies
Standard state chemical potentials for species K at the current temperature and pressure.
vector_fp m_molNumSpecies_old
Total moles of the species.
std::vector< vcs_VolPhase * > m_VolPhaseList
Array of Phase Structures. Length = number of phases.
double vcs_tmoles()
Calculates the total number of moles of species in all phases.
bool vcs_wellPosed(VCS_PROB *vprob)
In this routine, we check for things that will cause the algorithm to fail.
vector_fp m_feSpecies_new
Dimensionless new free energy for all the species in the mechanism at the new tentative T...
vector_fp m_spSize
total size of the species
size_t m_numRxnRdc
Current number of non-component species in the problem.
size_t m_numSpeciesRdc
Current number of species in the problems.
void setExistence(const int existence)
Set the existence flag in the object.
int vcs_prep()
Prepare the object for solution.
vector_fp m_tPhaseMoles_new
total kmols of species in each phase in the tentative soln vector
std::vector< int > vector_int
Vector of ints.
Header file for the internal object that holds the vcs equilibrium problem (see Class VCS_SOLVE and E...
Header for the object representing each phase within vcs.
#define VCS_SPECIES_TYPE_MOLNUM
Unknown refers to mole number of a single species.
int m_doEstimateEquil
Setting for whether to do an initial estimate.
vector_fp gai
Element abundances for jth element.
Properties of a single species.
Header for the Interface class for the vcs thermo equilibrium solver package,.
size_t m_numElemConstraints
Number of element constraints in the problem.
size_t m_numSpeciesTot
Total number of species in the problems.
vector_fp m_deltaPhaseMoles
Change in the total moles in each phase.
vector_fp m_feSpecies_old
Free energy vector from the start of the current iteration.
vector_fp TPhInertMoles
Total kmoles of inert to add to each phase.
int m_debug_print_lvl
Debug printing lvl.
int vcs_evalSS_TP(int ipr, int ip1, double Temp, double pres)
size_t m_numComponents
Number of components calculated for the problem.
int vcs_prep_oneTime(int printLvl)
This routine is mostly concerned with changing the private data to be consistent with what's needed f...
double m_temperature
Temperature (Kelvin)
std::vector< char > m_SSPhase
Boolean indicating whether a species belongs to a single-species phase.
Phase information and Phase calculations for vcs.
size_t ne
Number of element constraints in the equilibrium problem.
Array2D m_deltaMolNumPhase
Change in the number of moles of phase, iphase, due to the noncomponent formation reaction...
double m_pressurePA
Pressure.
std::vector< double > vector_fp
Turn on the use of stl vectors for the basic array type within cantera Vector of doubles.
vcs_SpeciesProperties * speciesProperty(const size_t kindex)
Retrieve the kth Species structure for the species belonging to this phase.
int vcs_basopt(const bool doJustComponents, double aw[], double sa[], double sm[], double ss[], double test, bool *const usedZeroedSpecies)
Choose the optimum species basis for the calculations.
#define plogf
define this Cantera function to replace printf
void zero()
Set all of the entries to zero.
Array2D m_phaseParticipation
This is 1 if the phase, iphase, participates in the formation reaction irxn, and zero otherwise...
Namespace for the Cantera kernel.
std::vector< size_t > m_indexRxnToSpecies
Mapping between the species index for noncomponent species and the full species index.
size_t m_numPhases
Number of Phases in the problem.
Interface class for the vcs thermo equilibrium solver package, which generally describes the problem ...
size_t m_numRxnTot
Total number of non-component species in the problem.
vector_fp m_molNumSpecies_new
Tentative value of the mole number vector.
std::vector< size_t > m_speciesLocalPhaseIndex
Index that keeps track of the index of the species within the local phase.