ASPECT
reactive_fluid_transport.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2023 - 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_model_reactive_fluid_transport_h
22 #define _aspect_material_model_reactive_fluid_transport_h
23 
26 #include <aspect/melt.h>
27 #include <aspect/utilities.h>
29 
30 #include <aspect/melt.h>
31 #include <aspect/utilities.h>
34 
35 
36 
37 namespace aspect
38 {
39  namespace MaterialModel
40  {
41  using namespace dealii;
49  template <int dim>
51  {
52  public:
56  bool is_compressible () const override;
57 
62  double reference_darcy_coefficient () const override;
76  std::vector<double> tian_equilibrium_bound_water_content(const MaterialModel::MaterialModelInputs<dim> &in,
77  unsigned int q) const;
78 
88  void melt_fractions (const MaterialModel::MaterialModelInputs<dim> &in,
89  std::vector<double> &melt_fractions) const override;
90 
95  void
96  initialize () override;
97 
101  void update() override;
102 
106  void
107  evaluate (const typename Interface<dim>::MaterialModelInputs &in,
108  typename Interface<dim>::MaterialModelOutputs &out) const override;
109 
113  static void
114  declare_parameters (ParameterHandler &prm);
115 
119  void
120  parse_parameters (ParameterHandler &prm) override;
121 
126  void
127  create_additional_named_outputs (MaterialModel::MaterialModelOutputs<dim> &out) const override;
128 
129  private:
130 
134  std::unique_ptr<MaterialModel::Interface<dim>> base_model;
135 
142  double eta_f;
144 
155  double alpha_phi;
156  double reference_T;
157 
162 
172 
181  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};
182  std::vector<double> csat_peridotite_poly_coeffs {0.00115628, 2.42179};
183  std::vector<double> Td_peridotite_poly_coeffs {-15.4627, 94.9716, 636.603};
184 
185  std::vector<double> LR_gabbro_poly_coeffs {-1.81745, 7.67198, -10.8507, 5.09329, 8.14519};
186  std::vector<double> csat_gabbro_poly_coeffs {-0.0176673, 0.0893044, 1.52732};
187  std::vector<double> Td_gabbro_poly_coeffs {-1.72277, 20.5898, 637.517};
188 
189  std::vector<double> LR_MORB_poly_coeffs {-1.78177, 7.50871, -10.4840, 5.19725, 7.96365};
190  std::vector<double> csat_MORB_poly_coeffs {0.0102725, -0.115390, 0.324452, 1.41588};
191  std::vector<double> Td_MORB_poly_coeffs {-3.81280, 22.7809, 638.049};
192 
193  std::vector<double> LR_sediment_poly_coeffs {-2.03283, 10.8186, -21.2119, 18.3351, -6.48711, 8.32459};
194  std::vector<double> csat_sediment_poly_coeffs {-0.150662, 0.301807, 1.01867};
195  std::vector<double> Td_sediment_poly_coeffs {2.83277, -24.7593, 85.9090, 524.898};
196 
202  const std::vector<double> pressure_cutoffs {10, 26, 16, 50};
203 
204  std::vector<std::vector<double>> devolatilization_enthalpy_changes {LR_peridotite_poly_coeffs, LR_gabbro_poly_coeffs, \
205  LR_MORB_poly_coeffs, LR_sediment_poly_coeffs
206  };
207 
208  std::vector<std::vector<double>> water_mass_fractions {csat_peridotite_poly_coeffs, csat_gabbro_poly_coeffs, \
209  csat_MORB_poly_coeffs, csat_sediment_poly_coeffs
210  };
211 
212  std::vector<std::vector<double>> devolatilization_onset_temperatures {Td_peridotite_poly_coeffs, Td_gabbro_poly_coeffs, \
213  Td_MORB_poly_coeffs, Td_sediment_poly_coeffs
214  };
215 
216  /*
217  * Object for computing Katz 2003 melt parameters
218  */
220 
264  {
268  katz2003
269  }
270  fluid_solid_reaction_scheme;
271  };
272  }
273 }
274 
275 #endif
std::unique_ptr< MaterialModel::Interface< dim > > base_model
void declare_parameters(ParameterHandler &prm)
Definition: compat.h:59
ReactionModel::Katz2003MantleMelting< dim > katz2003_model
Definition: compat.h:42