Feellgood
settings.h
Go to the documentation of this file.
1 #ifndef settings_h
2 #define settings_h
3 
9 #include <cmath>
10 #include <string>
11 #include <vector>
12 
13 #include <yaml-cpp/yaml.h>
14 
15 #include "expression_parser.h"
16 #include "triangle.h"
17 #include "tetra.h"
18 
25  {
28  };
29 
40  {
41  UNDEF = -1,
42  RtoR3 = 1,
43  R4toR3 = 2
45  };
46 
69 class Settings
70  {
71 public:
78  Settings();
79 
81  static void dumpDefaults();
82 
85  static void dumpTemplate();
86 
88  void toYaml(void);
89 
91  std::string evolMetadata() const;
92 
94  std::string solMetadata(const double t) const;
95 
97  void read(YAML::Node);
98 
100  bool read(const std::string& filename);
101 
103  inline int getPrecision(void) const { return precision; }
104 
106  inline std::string getFileDisplayName(void) const { return fileDisplayName; }
107 
109  inline void setFileDisplayName(const std::string &_s) { fileDisplayName = _s; }
110 
112  inline void setPbName(const std::string &str) { pbName = str; }
113 
115  inline std::string getPbName(void) const { return pbName; }
116 
118  inline void setSimName(const std::string &str) { simName = str; }
119 
121  inline std::string getSimName(void) const { return simName; }
122 
124  inline void setScale(const double s) { _scale = s; }
125 
127  inline double getScale(void) const { return _scale; }
128 
130  inline void set_MAXITER(const int i) { MAXITER = i; }
131 
133  bool withTsv;
134 
136  int verbose;
137 
139  double time_step;
140 
143 
145  bool recenter;
146 
149 
151  double threshold;
152 
155 
157  bool V_file;
158 
160  bool spin_acc;
161 
163  std::string sMx;
164 
166  std::string sMy;
167 
169  std::string sMz;
170 
172  std::string sM;
173 
175  std::string sBx;
176 
178  std::string sBy;
179 
181  std::string sBz;
182 
184  std::string sB;
185 
187  std::string sB_space;
188 
190  std::string sB_time;
191 
193  std::string restoreFileName;
194 
196  double initial_time = NAN;
197 
199  double DUMAX; // 0.1 for magnetostatic simulations; 0.02 for the dynamics
200 
202  double TOL;
203 
205  int MAXITER;
206 
208  std::vector<Tetra::prm> paramTetra;
209 
214  template <typename T>
215  int findRegionIdx(const std::string &name ) const
216  {
217  typename std::vector<T>::const_iterator containerBegin, containerEnd;
218  if constexpr (std::is_same_v<T,Tetra::prm>)
219  { containerBegin = paramTetra.begin(); containerEnd = paramTetra.end(); }
220  else if constexpr (std::is_same_v<T,Triangle::prm>)
221  { containerBegin = paramTriangle.begin(); containerEnd = paramTriangle.end(); }
222 
223  typename std::vector<T>::const_iterator result = std::find_if(
224  containerBegin, containerEnd,
225  [name] (const T &p) { return (p.regName == name);} );
226  int idx(-2);
227  if (result == containerEnd)
228  { idx = -1; }
229  else
230  { idx = std::distance(containerBegin, result); }
231  return idx;
232  }
233 
235  std::vector<Triangle::prm> paramTriangle;
236 
238  std::string r_path_output_dir;
239 
241  std::vector<std::string> evol_columns;
242 
244  double tf;
245 
247  double dt_min;
248 
250  double dt_max;
251 
255  inline mag_exprType getMagType() const
256  {
257  if (mag_parser.parameter_count() < 4) return POSITION_ONLY;
258  return POSITION_AND_REGIONS;
259  }
260 
265  inline Eigen::Vector3d getMagnetization(const Eigen::Ref<const Eigen::Vector3d> p) const
266  {
267  Eigen::Vector3d tmp = mag_parser.get_vector(p);
268  tmp.normalize();
269  return tmp;
270  }
271 
276  inline Eigen::Vector3d getMagnetization(const Eigen::Ref<const Eigen::Vector3d> p,
277  const std::vector<std::string> &regions) const
278  {
279  Eigen::Vector3d tmp = mag_parser.get_vector(p, regions);
280  tmp.normalize();
281  return tmp;
282  }
283 
288  inline Eigen::Vector3d getField(const double t_val) const
289  {
290  // If this is not meaningful, return a vector of NAN.
291  if (field_type != RtoR3)
292  { return {NAN, NAN, NAN}; }
293 
294  return (field_parser.get_vector(t_val))/mu0;
295  }
296 
300  inline field_exprType getFieldType(void) const
301  { return field_type; }
302 
307  inline Eigen::Vector3d getFieldSpace(const Eigen::Ref<const Eigen::Vector3d> p) const
308  { return field_space_parser.get_vector(p); }
309 
314  inline double getFieldTime(const double t_val) const
315  { return (field_time_parser.get_scalar(t_val))/mu0; }
316 
317 private:
318  using MetadataItem = std::pair<std::string, std::string>;
320  std::vector<MetadataItem> userMetadata;
321  int precision;
322  std::string fileDisplayName;
323  double _scale;
324  std::string simName;
325  std::string pbName;
333 
336 
337  // field(x,y,z,t) = field_time(t) * field_space(x,y,z) with field_time R -> R
338  // and field_space R³->R³
341 
344 
346  std::ostringstream commonMetadata() const;
347 
349  const bool NORMALIZE = true;
350  };
351 
352 #endif /* settings_h */
Definition: expression_parser.h:22
double get_scalar(double arg) const
Definition: expression_parser.cpp:81
Eigen::Vector3d get_vector(double arg) const
Definition: expression_parser.cpp:117
int parameter_count() const
Definition: expression_parser.h:47
Container for all the settings provided by the user, with conversions to/from YAML.
Definition: settings.h:70
std::vector< Triangle::prm > paramTriangle
Definition: settings.h:235
std::string getFileDisplayName(void) const
Definition: settings.h:106
void setPbName(const std::string &str)
Definition: settings.h:112
std::string pbName
Definition: settings.h:325
std::string sB_space
Definition: settings.h:187
Eigen::Vector3d getMagnetization(const Eigen::Ref< const Eigen::Vector3d > p) const
Definition: settings.h:265
void toYaml(void)
Definition: settings.cpp:154
std::string r_path_output_dir
Definition: settings.h:238
double DUMAX
Definition: settings.h:199
void read(YAML::Node)
Definition: settings.cpp:316
int verbose
Definition: settings.h:136
static void dumpTemplate()
Definition: settings.cpp:146
bool spin_acc
Definition: settings.h:160
int getPrecision(void) const
Definition: settings.h:103
std::string sB_time
Definition: settings.h:190
void setScale(const double s)
Definition: settings.h:124
const bool NORMALIZE
Definition: settings.h:349
Nodes::index recentering_direction
Definition: settings.h:148
int MAXITER
Definition: settings.h:205
bool V_file
Definition: settings.h:157
std::vector< MetadataItem > userMetadata
Definition: settings.h:320
Eigen::Vector3d getFieldSpace(const Eigen::Ref< const Eigen::Vector3d > p) const
Definition: settings.h:307
std::pair< std::string, std::string > MetadataItem
Definition: settings.h:318
std::string evolMetadata() const
Definition: settings.cpp:293
std::string sMz
Definition: settings.h:169
field_exprType getFieldType(void) const
Definition: settings.h:300
ExpressionParser field_time_parser
Definition: settings.h:340
ExpressionParser field_parser
Definition: settings.h:335
ExpressionParser field_space_parser
Definition: settings.h:343
double dt_max
Definition: settings.h:250
double initial_time
Definition: settings.h:196
ExpressionParser mag_parser
Definition: settings.h:326
std::string sM
Definition: settings.h:172
void setFileDisplayName(const std::string &_s)
Definition: settings.h:109
std::string sBz
Definition: settings.h:181
int findRegionIdx(const std::string &name) const
Definition: settings.h:215
double getScale(void) const
Definition: settings.h:127
Eigen::Vector3d getMagnetization(const Eigen::Ref< const Eigen::Vector3d > p, const std::vector< std::string > &regions) const
Definition: settings.h:276
std::string simName
Definition: settings.h:324
double getFieldTime(const double t_val) const
Definition: settings.h:314
std::string getPbName(void) const
Definition: settings.h:115
std::string sMy
Definition: settings.h:166
std::string sBx
Definition: settings.h:175
bool withTsv
Definition: settings.h:133
void setSimName(const std::string &str)
Definition: settings.h:118
int precision
Definition: settings.h:321
std::string solMetadata(const double t) const
Definition: settings.cpp:305
Settings()
Definition: settings.cpp:133
std::string restoreFileName
Definition: settings.h:193
mag_exprType getMagType() const
Definition: settings.h:255
bool recenter
Definition: settings.h:145
std::string getSimName(void) const
Definition: settings.h:121
double TOL
Definition: settings.h:202
double tf
Definition: settings.h:244
double threshold
Definition: settings.h:151
std::vector< std::string > evol_columns
Definition: settings.h:241
static void dumpDefaults()
Definition: settings.cpp:144
Eigen::Vector3d getField(const double t_val) const
Definition: settings.h:288
void set_MAXITER(const int i)
Definition: settings.h:130
double _scale
Definition: settings.h:323
std::string fileDisplayName
Definition: settings.h:322
std::string sB
Definition: settings.h:184
double dt_min
Definition: settings.h:247
std::string sMx
Definition: settings.h:163
std::vector< Tetra::prm > paramTetra
Definition: settings.h:208
field_exprType field_type
Definition: settings.h:332
std::string sBy
Definition: settings.h:178
int save_period
Definition: settings.h:142
double time_step
Definition: settings.h:139
int scalfmmNbTh
Definition: settings.h:154
std::ostringstream commonMetadata() const
Definition: settings.cpp:272
index
Definition: node.h:33
field_exprType
Definition: settings.h:40
@ RtoR3
B(t)
Definition: settings.h:42
@ UNDEF
undefined
Definition: settings.h:41
@ R4toR3
Definition: settings.h:43
mag_exprType
Definition: settings.h:25
@ POSITION_AND_REGIONS
M(x, y, z, regions)
Definition: settings.h:27
@ POSITION_ONLY
M(x, y, z)
Definition: settings.h:26
namespace Tetra header containing Tet class, some constants, and integrales
contains namespace Triangle header containing Tri class, and some constants and a less_than operator ...