ASPECT
tian2019_solubility.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2024 by the authors of the ASPECT code.
3 
4  This file is part of ASPECT.
5 
6  ASPECT is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2, or (at your option)
9  any later version.
10 
11  ASPECT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with ASPECT; see the file LICENSE. If not see
18  <http://www.gnu.org/licenses/>.
19 */
20 
21 #ifndef _aspect_material_reaction_model_melt_tian2019_solubility_h
22 #define _aspect_material_reaction_model_melt_tian2019_solubility_h
23 
26 #include <aspect/melt.h>
27 #include <aspect/utilities.h>
28 
29 
30 namespace aspect
31 {
32  namespace MaterialModel
33  {
34  using namespace dealii;
35 
36  namespace ReactionModel
37  {
38 
53  template <int dim>
55  {
56  public:
57 
67  double
68  melt_fraction (const MaterialModel::MaterialModelInputs<dim> &in,
69  const unsigned int porosity_idx,
70  unsigned int q) const;
71 
79  std::vector<double> tian_equilibrium_bound_water_content(const MaterialModel::MaterialModelInputs<dim> &in,
80  unsigned int q) const;
81 
85  static
86  void
87  declare_parameters (ParameterHandler &prm);
88 
92  void
93  parse_parameters (ParameterHandler &prm);
94 
95  private:
96 
106 
115  std::vector<double> LR_peridotite_poly_coeffs {-19.0609, 168.983, -630.032, 1281.84, -1543.14, 1111.88, -459.142, 95.4143, 1.97246};
116  std::vector<double> csat_peridotite_poly_coeffs {0.00115628, 2.42179};
117  std::vector<double> Td_peridotite_poly_coeffs {-15.4627, 94.9716, 636.603};
118 
119  std::vector<double> LR_gabbro_poly_coeffs {-1.81745, 7.67198, -10.8507, 5.09329, 8.14519};
120  std::vector<double> csat_gabbro_poly_coeffs {-0.0176673, 0.0893044, 1.52732};
121  std::vector<double> Td_gabbro_poly_coeffs {-1.72277, 20.5898, 637.517};
122 
123  std::vector<double> LR_MORB_poly_coeffs {-1.78177, 7.50871, -10.4840, 5.19725, 7.96365};
124  std::vector<double> csat_MORB_poly_coeffs {0.0102725, -0.115390, 0.324452, 1.41588};
125  std::vector<double> Td_MORB_poly_coeffs {-3.81280, 22.7809, 638.049};
126 
127  std::vector<double> LR_sediment_poly_coeffs {-2.03283, 10.8186, -21.2119, 18.3351, -6.48711, 8.32459};
128  std::vector<double> csat_sediment_poly_coeffs {-0.150662, 0.301807, 1.01867};
129  std::vector<double> Td_sediment_poly_coeffs {2.83277, -24.7593, 85.9090, 524.898};
130 
136  const std::array<double,4 > pressure_cutoffs {{10, 26, 16, 50}};
137 
138  std::vector<std::vector<double>> devolatilization_enthalpy_changes {LR_peridotite_poly_coeffs, LR_gabbro_poly_coeffs, \
139  LR_MORB_poly_coeffs, LR_sediment_poly_coeffs
140  };
141 
142  std::vector<std::vector<double>> water_mass_fractions {csat_peridotite_poly_coeffs, csat_gabbro_poly_coeffs, \
143  csat_MORB_poly_coeffs, csat_sediment_poly_coeffs
144  };
145 
146  std::vector<std::vector<double>> devolatilization_onset_temperatures {Td_peridotite_poly_coeffs, Td_gabbro_poly_coeffs, \
147  Td_MORB_poly_coeffs, Td_sediment_poly_coeffs
148  };
149  };
150  }
151 
152  }
153 }
154 
155 #endif
void declare_parameters(ParameterHandler &prm)
Definition: compat.h:59
Definition: compat.h:42