World Builder  1.1.0-pre
A geodynamic initial conditions generator
plate_model.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2018-2024 by the authors of the World Builder code.
3 
4  This file is part of the World Builder.
5 
6  This program is free software: you can redistribute it and/or modify
7  it under the terms of the GNU Lesser General Public License as published
8  by the Free Software Foundation, either version 2 of the License, or
9  (at your option) any later version.
10 
11  This program 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 Lesser General Public License for more details.
15 
16  You should have received a copy of the GNU Lesser General Public License
17  along with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19 
20 #ifndef WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_TEMPERATURE_PLATE_MODEL_H
21 #define WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_TEMPERATURE_PLATE_MODEL_H
22 
23 
27 
28 
29 namespace WorldBuilder
30 {
31  class Parameters;
32  class World;
33 
34  namespace Features
35  {
36  using namespace FeatureUtilities;
37  namespace OceanicPlateModels
38  {
39  namespace Temperature
40  {
50  class PlateModel final: public Interface
51  {
52  public:
57 
61  ~PlateModel() override final;
62 
66  static
67  void declare_entries(Parameters &prm, const std::string &parent_name = "");
68 
72  void parse_entries(Parameters &prm, const std::vector<Point<2>> &coordinates) override final;
73 
74 
79  double get_temperature(const Point<3> &position,
80  const Objects::NaturalCoordinate &position_in_natural_coordinates,
81  const double depth,
82  const double gravity,
83  double temperature,
84  const double feature_min_depth,
85  const double feature_max_depth) const override final;
86 
87 
88  private:
89  // plate model temperature submodule parameters
90  double min_depth;
92  double max_depth;
96  std::pair<std::vector<double>,std::vector<double>> spreading_velocities;
97  std::vector<std::vector<Point<2> > > mid_oceanic_ridges;
98  std::vector<std::vector<double>> spreading_velocities_at_each_ridge_point;
100 
101  };
102  } // namespace Temperature
103  } // namespace OceanicPlateModels
104  } // namespace Features
105 } // namespace WorldBuilder
106 
107 #endif
std::pair< std::vector< double >, std::vector< double > > spreading_velocities
Definition: plate_model.h:96
std::vector< std::vector< Point< 2 > > > mid_oceanic_ridges
Definition: plate_model.h:97
std::vector< std::vector< double > > spreading_velocities_at_each_ridge_point
Definition: plate_model.h:98