ASPECT
reactive_fluid_transport.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2023 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>
33 
34 
35 
36 namespace aspect
37 {
38  namespace MaterialModel
39  {
40  using namespace dealii;
48  template <int dim>
50  {
51  public:
57  bool is_compressible () const override;
58 
63  virtual double reference_darcy_coefficient () const override;
64 
65 
74  std::vector<double> tian_equilibrium_bound_water_content(const MaterialModel::MaterialModelInputs<dim> &in,
75  unsigned int q) const;
76 
86  virtual void melt_fractions (const MaterialModel::MaterialModelInputs<dim> &in,
87  std::vector<double> &melt_fractions) const override;
88 
93  void
94  initialize () override;
95 
99  void update() override;
100 
104  void
105  evaluate (const typename Interface<dim>::MaterialModelInputs &in,
106  typename Interface<dim>::MaterialModelOutputs &out) const override;
107 
111  static void
112  declare_parameters (ParameterHandler &prm);
113 
117  void
118  parse_parameters (ParameterHandler &prm) override;
119 
124  virtual
125  void
126  create_additional_named_outputs (MaterialModel::MaterialModelOutputs<dim> &out) const override;
127 
128  private:
129 
133  std::unique_ptr<MaterialModel::Interface<dim>> base_model;
134 
135  // Variables that describe the properties of the fluid, i.e. its density,
136  // viscosity, and compressibility.
137  // Properties of the solid are defined in the base model.
139  double eta_f;
141 
142  // Material properties governing the transport of the fluid with respect
143  // to the solid, i.e., the bulk viscosity (relative to the shear viscosity),
144  // the permeability, and how much the solid viscosity changes in the presence
145  // of fluids.
148  double alpha_phi;
149 
150  // Time scale for fluid release and absorption.
152 
153  // The maximum water content for each of the 4 rock types in the tian approximation
154  // method. These are important for keeping the polynomial bounded within reasonable
155  // values.
160 
161  // The following coefficients are taken from a publication from Tian et al., 2019, and can be found
162  // in Table 3 (Gabbro), Table B1 (MORB), Table B2 (Sediments) and Table B3 (peridotite).
163  // LR refers to the effective enthalpy change for devolatilization reactions,
164  // csat is the saturated mass fraction of water in the solid, and Td is the
165  // onset temperature of devolatilization for water.
166  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};
167  std::vector<double> csat_peridotite_poly_coeffs {0.00115628, 2.42179};
168  std::vector<double> Td_peridotite_poly_coeffs {-15.4627, 94.9716, 636.603};
169 
170  std::vector<double> LR_gabbro_poly_coeffs {-1.81745, 7.67198, -10.8507, 5.09329, 8.14519};
171  std::vector<double> csat_gabbro_poly_coeffs {-0.0176673, 0.0893044, 1.52732};
172  std::vector<double> Td_gabbro_poly_coeffs {-1.72277, 20.5898, 637.517};
173 
174  std::vector<double> LR_MORB_poly_coeffs {-1.78177, 7.50871, -10.4840, 5.19725, 7.96365};
175  std::vector<double> csat_MORB_poly_coeffs {0.0102725, -0.115390, 0.324452, 1.41588};
176  std::vector<double> Td_MORB_poly_coeffs {-3.81280, 22.7809, 638.049};
177 
178  std::vector<double> LR_sediment_poly_coeffs {-2.03283, 10.8186, -21.2119, 18.3351, -6.48711, 8.32459};
179  std::vector<double> csat_sediment_poly_coeffs {-0.150662, 0.301807, 1.01867};
180  std::vector<double> Td_sediment_poly_coeffs {2.83277, -24.7593, 85.9090, 524.898};
181 
182  std::vector<std::vector<double>> devolatilization_enthalpy_changes {LR_peridotite_poly_coeffs, LR_gabbro_poly_coeffs, \
183  LR_MORB_poly_coeffs, LR_sediment_poly_coeffs
184  };
185 
186  std::vector<std::vector<double>> water_mass_fractions {csat_peridotite_poly_coeffs, csat_gabbro_poly_coeffs, \
187  csat_MORB_poly_coeffs, csat_sediment_poly_coeffs
188  };
189 
190  std::vector<std::vector<double>> devolatilization_onset_temperatures {Td_peridotite_poly_coeffs, Td_gabbro_poly_coeffs, \
191  Td_MORB_poly_coeffs, Td_sediment_poly_coeffs
192  };
233  {
236  tian_approximation
237  }
238  fluid_solid_reaction_scheme;
239  };
240  }
241 }
242 
243 #endif
std::unique_ptr< MaterialModel::Interface< dim > > base_model
void declare_parameters(ParameterHandler &prm)
Definition: compat.h:42