OGS
ChemicalSystem.cpp
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) OpenGeoSys Community (opengeosys.org)
2// SPDX-License-Identifier: BSD-3-Clause
3
4#include "ChemicalSystem.h"
5
6#include "AqueousSolution.h"
9
10namespace ChemistryLib
11{
12namespace PhreeqcIOData
13{
14void ChemicalSystem::initialize(std::size_t const num_chemical_systems)
15{
18 num_chemical_systems);
19
20 aqueous_solution->pe->resize(num_chemical_systems, aqueous_solution->pe0);
21
22 auto& components = aqueous_solution->components;
23 for (auto& component : components)
24 {
25 component.amount =
27 num_chemical_systems);
28 }
29
30 for (auto& kinetic_reactant : kinetic_reactants)
31 {
32 kinetic_reactant.molality->resize(num_chemical_systems);
33 kinetic_reactant.molality_prev->resize(num_chemical_systems);
34 kinetic_reactant.volume_fraction->resize(num_chemical_systems);
35 kinetic_reactant.volume_fraction_prev->resize(num_chemical_systems);
36 }
37
38 for (auto& equilibrium_reactant : equilibrium_reactants)
39 {
40 equilibrium_reactant.molality->resize(num_chemical_systems);
41 equilibrium_reactant.molality_prev->resize(num_chemical_systems);
42 equilibrium_reactant.volume_fraction->resize(num_chemical_systems);
43 equilibrium_reactant.volume_fraction_prev->resize(num_chemical_systems);
44 }
45
46 for (auto& exchanger : exchangers)
47 {
48 exchanger.molality->resize(num_chemical_systems);
49 }
50
51 for (auto& surface_site : surface)
52 {
53 if (auto const surface_site_ptr =
54 std::get_if<MoleBasedSurfaceSite>(&surface_site))
55 {
56 surface_site_ptr->molality->resize(num_chemical_systems);
57 }
58 }
59}
60} // namespace PhreeqcIOData
61} // namespace ChemistryLib
Definition of one reactive chemical system for PHREEQC coupling.
Per-system aqueous state exchanged with PHREEQC.
std::unique_ptr< AqueousSolution > aqueous_solution
std::vector< KineticReactant > kinetic_reactants
std::vector< EquilibriumReactant > equilibrium_reactants
std::vector< std::variant< DensityBasedSurfaceSite, MoleBasedSurfaceSite > > surface
void initialize(std::size_t const num_chemical_systems)