World Builder  1.1.0-pre
A geodynamic initial conditions generator
gaussian.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_PLUME_MODELS_TEMPERATURE_GAUSSIAN_H
21 #define WORLD_BUILDER_FEATURES_PLUME_MODELS_TEMPERATURE_GAUSSIAN_H
22 
23 
26 
27 
28 namespace WorldBuilder
29 {
30 
31  namespace Features
32  {
33  using namespace FeatureUtilities;
34  namespace PlumeModels
35  {
36  namespace Temperature
37  {
44  class Gaussian final: public Interface
45  {
46  public:
51 
55  ~Gaussian() override final;
56 
60  static
61  void declare_entries(Parameters &prm, const std::string &parent_name = "");
62 
66  void parse_entries(Parameters &prm) override final;
67 
68 
73  double get_temperature(const Point<3> &position,
74  const Objects::NaturalCoordinate &position_in_natural_coordinates,
75  const double depth,
76  const double gravity,
77  double temperature,
78  const double feature_min_depth,
79  const double feature_max_depth,
80  const double relative_distance_from_center) const override final;
81 
82 
83  private:
84  // Gaussian temperature submodule parameters
85  std::vector<double> depths;
86  std::vector<double> center_temperatures;
87  std::vector<double> gaussian_sigmas;
89 
90  };
91  } // namespace Temperature
92  } // namespace FaultModels
93  } // namespace Features
94 } // namespace WorldBuilder
95 
96 #endif