World Builder  1.1.0-pre
A geodynamic initial conditions generator
interface.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_MANTLE_LAYER_MODELS_VELOCITY_INTERFACE_H
21 #define WORLD_BUILDER_FEATURES_MANTLE_LAYER_MODELS_VELOCITY_INTERFACE_H
22 
23 
26 
27 
28 namespace WorldBuilder
29 {
30  class World;
31  class Parameters;
32  template <unsigned int dim> class Point;
33 
38  namespace Features
39  {
40 
41  namespace MantleLayerModels
42  {
43  namespace Velocity
44  {
45  class ObjectFactory;
46 
47  class Interface
48  {
49  public:
53  Interface();
54 
58  virtual
59  ~Interface();
60 
64  static
65  void declare_entries(Parameters &prm,
66  const std::string &parent_name,
67  const std::vector<std::string> &required_entries);
68 
72  virtual
73  void parse_entries(Parameters &prm, const std::vector<Point<2>> &coordinates) = 0;
74 
75 
79  virtual
80  std::array<double,3> get_velocity(const Point<3> &position,
81  const Objects::NaturalCoordinate &position_in_natural_coordinates,
82  const double depth,
83  const double gravity,
84  std::array<double,3> velocity,
85  const double feature_min_depth,
86  const double feature_max_depth) const = 0;
91  static void registerType(const std::string &name,
92  void ( * /*declare_entries*/)(Parameters &, const std::string &),
93  ObjectFactory *factory);
94 
95 
100  static std::unique_ptr<Interface> create(const std::string &name, WorldBuilder::World *world);
101 
105  std::string get_name() const
106  {
107  return name;
108  };
109 
110  protected:
115 
119  std::string name;
120 
121  private:
122  static std::map<std::string, ObjectFactory *> &get_factory_map()
123  {
124  static std::map<std::string, ObjectFactory *> factories;
125  return factories;
126  }
127 
128  static std::map<std::string, void ( *)(Parameters &,const std::string &)> &get_declare_map()
129  {
130  static std::map<std::string, void ( *)(Parameters &,const std::string &)> declares;
131  return declares;
132  }
133 
134  };
135 
136 
141  {
142  public:
143  virtual std::unique_ptr<Interface> create(World *world) = 0;
144  };
145 
151 #define WB_REGISTER_FEATURE_MANTLE_LAYER_VELOCITY_MODEL(classname,name) \
152  class classname##Factory : public ObjectFactory { \
153  public: \
154  classname##Factory() \
155  { \
156  Interface::registerType(#name, classname::declare_entries, this); \
157  } \
158  std::unique_ptr<Interface> create(World *world) override final { \
159  return std::unique_ptr<Interface>(new classname(world)); \
160  } \
161  }; \
162  static classname##Factory global_##classname##Factory;
163 
164  } // namespace Velocity
165  } // namespace MantleLayerModels
166  } // namespace Features
167 } // namespace WorldBuilder
168 
169 #endif
static std::map< std::string, ObjectFactory * > & get_factory_map()
Definition: interface.h:122
virtual void parse_entries(Parameters &prm, const std::vector< Point< 2 >> &coordinates)=0
static std::unique_ptr< Interface > create(const std::string &name, WorldBuilder::World *world)
Definition: interface.cc:71
static void registerType(const std::string &name, void(*)(Parameters &, const std::string &), ObjectFactory *factory)
Definition: interface.cc:62
virtual std::array< double, 3 > get_velocity(const Point< 3 > &position, const Objects::NaturalCoordinate &position_in_natural_coordinates, const double depth, const double gravity, std::array< double, 3 > velocity, const double feature_min_depth, const double feature_max_depth) const =0
static void declare_entries(Parameters &prm, const std::string &parent_name, const std::vector< std::string > &required_entries)
Definition: interface.cc:41
static std::map< std::string, void(*)(Parameters &, const std::string &)> & get_declare_map()
Definition: interface.h:128