ASPECT
compositional_viscosity_prefactors.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_model_rheology_compositional_viscosity_prefactors_h
22 #define _aspect_material_model_rheology_compositional_viscosity_prefactors_h
23 
24 #include <aspect/global.h>
27 
28 namespace aspect
29 {
30  namespace MaterialModel
31  {
32  namespace Rheology
33  {
39  template <int dim>
41  {
42  public:
47 
51  static
52  void
53  declare_parameters (ParameterHandler &prm);
54 
58  void
59  parse_parameters (ParameterHandler &prm);
60 
61  // The flow laws that can be
62  // currently modified.
64  {
68 
72  double
74  const double base_viscosity,
75  const unsigned int composition_index,
76  const unsigned int q,
77  const ModifiedFlowLaws &modified_flow_laws) const;
78 
79  private:
96  {
100 
101  // Initialize variables for the water fugacity calculation, from HK04
105 
106  // From Hirth & Kohlstaedt 2004, equation 6
107  const double A_H2O = 2.6e-5; // 1/Pa
108  const double activation_energy_H2O = 40e3; // J/mol/K
109  const double activation_volume_H2O = 10e-6; // m^3/mol
110 
111  // We calculate the molar mass of olivine using the molar mass of fayalite (0.20379 kg/mol)
112  // and the molar mass of forsterite (0.140693 kg/mol), and a mole fraction of 90% forsterite
113  // in olivine.
114  const double molar_mass_olivine = 0.1470027; // kg/mol
115  const double molar_mass_H2O = 0.01801528; // kg/mol
116  };
117  }
118  }
119 }
120 #endif
enum aspect::MaterialModel::Rheology::CompositionalViscosityPrefactors::ViscosityPrefactorScheme viscosity_prefactor_scheme
Definition: compat.h:59
enum aspect::MaterialModel::Rheology::CompositionalViscosityPrefactors::ModifiedFlowLaws modified_flow_laws
double compute_viscosity(const MaterialModel::MaterialModelInputs< dim > &in, const double base_viscosity, const unsigned int composition_index, const unsigned int q, const ModifiedFlowLaws &modified_flow_laws) const