ASPECT
spherical_shell.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 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 
22 #ifndef _aspect_initial_temperature_spherical_shell_h
23 #define _aspect_initial_temperature_spherical_shell_h
24 
27 
28 
29 namespace aspect
30 {
31  namespace InitialTemperature
32  {
39  template <int dim>
40  class SphericalHexagonalPerturbation : public Interface<dim>, public SimulatorAccess<dim>
41  {
42  public:
46  double initial_temperature (const Point<dim> &position) const override;
47 
51  static
52  void
53  declare_parameters (ParameterHandler &prm);
54 
58  void
59  parse_parameters (ParameterHandler &prm) override;
60 
61  private:
68  unsigned int angular_mode;
69 
78 
82  double R1;
83 
84  };
85 
86 
93  template <int dim>
94  class SphericalGaussianPerturbation : public Interface<dim>, public SimulatorAccess<dim>
95  {
96  public:
97 
102 
106  double initial_temperature (const Point<dim> &position) const override;
107 
111  static
112  void
113  declare_parameters (ParameterHandler &prm);
114 
118  void
119  parse_parameters (ParameterHandler &prm) override;
120 
121  private:
122  double angle;
123  double depth;
124  double amplitude;
125  double sigma;
126  double sign;
127  unsigned int npoint;
128 
129  std::vector<double> radial_position;
130  std::vector<double> geotherm;
131 
135  double R0;
136 
140  double R1;
141  };
142  }
143 }
144 
145 #endif
void parse_parameters(ParameterHandler &prm) override
Definition: compat.h:59
double initial_temperature(const Point< dim > &position) const override
static void declare_parameters(ParameterHandler &prm)