Line data Source code
1 : //* This file is part of the MOOSE framework
2 : //* https://mooseframework.inl.gov
3 : //*
4 : //* All rights reserved, see COPYRIGHT for full restrictions
5 : //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 : //*
7 : //* Licensed under LGPL 2.1, please see LICENSE for details
8 : //* https://www.gnu.org/licenses/lgpl-2.1.html
9 :
10 : #pragma once
11 :
12 : #include "libMeshReducedNamespace.h"
13 : #include "libmesh/perf_log.h"
14 : #include "libmesh/libmesh_common.h"
15 : #include "XTermConstants.h"
16 :
17 : #include <limits>
18 : #include <memory>
19 : #include <set>
20 : #include <string>
21 :
22 : #define QUOTE(macro) stringifyName(macro)
23 : #define stringifyName(name) #name
24 :
25 : namespace libMesh
26 : {
27 : template <typename>
28 : class NumericVector;
29 : template <typename>
30 : class SparseMatrix;
31 :
32 : // This was deprecated in libMesh a year ago! It was obsolete 5 years
33 : // ago! How are 6 apps in CI still using it!?
34 : #ifdef LIBMESH_ENABLE_DEPRECATED
35 : template <typename T>
36 : using UniquePtr = std::unique_ptr<T>;
37 : #endif
38 : }
39 :
40 : class ActionFactory;
41 : class Factory;
42 : class MooseEnumItem;
43 : class ExecFlagEnum;
44 : class MooseVariableFieldBase;
45 :
46 : namespace hit
47 : {
48 : class Node;
49 : }
50 :
51 : void MooseVecView(libMesh::NumericVector<libMesh::Number> & vector);
52 : void MooseVecView(const libMesh::NumericVector<libMesh::Number> & vector);
53 : void MooseMatView(libMesh::SparseMatrix<libMesh::Number> & mat);
54 : void MooseMatView(const libMesh::SparseMatrix<libMesh::Number> & mat);
55 :
56 : /**
57 : * MOOSE now contains C++17 code, so give a reasonable error message
58 : * stating what the user can do to address this in their environment if C++17
59 : * compatibility isn't found.
60 : */
61 : namespace Moose
62 : {
63 : static_assert(__cplusplus >= 201703L,
64 : "MOOSE requires a C++17 compatible compiler (GCC >= 7.5.0, Clang >= 5.0.2). Please "
65 : "update your compiler or, if compatible, add '-std=c++17' to your compiler flags "
66 : "and try again. If using the MOOSE conda package, please attempt a MOOSE environment "
67 : "update (using `mamba update moose-dev`). If this update is not successful, please "
68 : "create a new MOOSE environment (see "
69 : "https://mooseframework.inl.gov/getting_started/installation/"
70 : "conda.html#uninstall-conda-moose-environment).");
71 : }
72 :
73 : /**
74 : * Testing a condition on a local CPU that need to be propagated across all processes.
75 : *
76 : * If the condition 'cond' is satisfied, it gets propagated across all processes, so the parallel
77 : * code take the same path (if that is requires).
78 : */
79 : #define parallel_if \
80 : (cond) bool __local_bool__ = (cond); \
81 : Parallel::max<bool>(__local_bool__); \
82 : if (__local_bool__)
83 :
84 : /**
85 : * Wrap all fortran function calls in this.
86 : */
87 : #ifdef __bg__ // On Blue Gene Architectures there is no underscore
88 : #define FORTRAN_CALL(name) name
89 : #else // One underscore everywhere else
90 : #define FORTRAN_CALL(name) name##_
91 : #endif
92 :
93 : /**
94 : * Function to mirror the behavior of the C++17 std::map::try_emplace() method (no hint).
95 : * @param m The std::map
96 : * @param k The key use to insert the pair
97 : * @param args The value to be inserted. This can be a moveable type but won't be moved
98 : * if the insertion is successful.
99 : */
100 : template <class M, class... Args>
101 : std::pair<typename M::iterator, bool>
102 44141 : moose_try_emplace(M & m, const typename M::key_type & k, Args &&... args)
103 : {
104 44141 : auto it = m.lower_bound(k);
105 44141 : if (it == m.end() || m.key_comp()(k, it->first))
106 : {
107 5528 : return {m.emplace_hint(it,
108 : std::piecewise_construct,
109 : std::forward_as_tuple(k),
110 : std::forward_as_tuple(std::forward<Args>(args)...)),
111 5528 : true};
112 : }
113 38613 : return {it, false};
114 : }
115 :
116 : // forward declarations
117 : class Syntax;
118 : class FEProblemBase;
119 :
120 : // Define MOOSE execution flags, this cannot be done in MooseTypes because the registration calls
121 : // must be in Moose.C to remain consistent with other registration calls.
122 : using ExecFlagType = MooseEnumItem;
123 : extern const ExecFlagType EXEC_NONE;
124 : extern const ExecFlagType EXEC_INITIAL;
125 : extern const ExecFlagType EXEC_LINEAR_CONVERGENCE;
126 : extern const ExecFlagType EXEC_LINEAR;
127 : extern const ExecFlagType EXEC_NONLINEAR_CONVERGENCE;
128 : extern const ExecFlagType EXEC_NONLINEAR;
129 : extern const ExecFlagType EXEC_POSTCHECK;
130 : extern const ExecFlagType EXEC_TIMESTEP_END;
131 : extern const ExecFlagType EXEC_TIMESTEP_BEGIN;
132 : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_ITERATION_END;
133 : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_BEGIN;
134 : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_END;
135 : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_CONVERGENCE;
136 : extern const ExecFlagType EXEC_FINAL;
137 : extern const ExecFlagType EXEC_FORCED;
138 : extern const ExecFlagType EXEC_FAILED;
139 : extern const ExecFlagType EXEC_CUSTOM;
140 : extern const ExecFlagType EXEC_SUBDOMAIN;
141 : extern const ExecFlagType EXEC_PRE_DISPLACE;
142 : extern const ExecFlagType EXEC_SAME_AS_MULTIAPP;
143 : extern const ExecFlagType EXEC_PRE_MULTIAPP_SETUP;
144 : extern const ExecFlagType EXEC_TRANSFER;
145 : extern const ExecFlagType EXEC_PRE_KERNELS;
146 : extern const ExecFlagType EXEC_ALWAYS;
147 : #ifdef LIBMESH_ENABLE_AMR
148 : extern const ExecFlagType EXEC_POST_ADAPTIVITY;
149 : #endif
150 :
151 : namespace Moose
152 : {
153 : // MOOSE is not tested with LIBMESH_DIM != 3
154 : static_assert(LIBMESH_DIM == 3,
155 : "MOOSE must be built with a libmesh library compiled without --enable-1D-only "
156 : "or --enable-2D-only");
157 :
158 : /**
159 : * This is the dimension of all vector and tensor datastructures used in MOOSE.
160 : * We enforce LIBMESH_DIM == 3 through a static assertion above.
161 : * Note that lower dimensional simulations embedded in 3D space can always be requested at runtime.
162 : */
163 : static constexpr std::size_t dim = LIBMESH_DIM;
164 :
165 : /// Value for invalid size_t indices
166 : inline constexpr std::size_t invalid_size_t = std::numeric_limits<std::size_t>::max();
167 :
168 : /**
169 : * Used by the signal handler to determine if we should write a checkpoint file out at any point
170 : * during operation.
171 : */
172 : extern int interrupt_signal_number;
173 :
174 : /**
175 : * Set to false (the default) to display an error message only once for each error call code
176 : * location (as opposed to every time the code is executed).
177 : */
178 : extern bool show_multiple;
179 :
180 : /**
181 : * Perflog to be used by applications.
182 : * If the application prints this in the end they will get performance info.
183 : *
184 : * This is no longer instantiated in the framework and will be removed in the future.
185 : */
186 : extern libMesh::PerfLog perf_log;
187 :
188 : /**
189 : * Variable indicating whether we will enable FPE trapping for this run.
190 : */
191 : extern bool _trap_fpe;
192 :
193 : /**
194 : * Variable to toggle any warning into an error (includes deprecated code warnings)
195 : */
196 : extern bool _warnings_are_errors;
197 :
198 : /**
199 : * Variable to toggle only deprecated warnings as errors.
200 : */
201 : extern bool _deprecated_is_error;
202 :
203 : /**
204 : * Variable to turn on exceptions during mooseError(), should only be used within MOOSE unit tests
205 : * or when about to perform threaded operations because exception throwing in threaded regions is
206 : * safe while aborting is inherently not when singletons are involved (e.g. what thread is
207 : * responsible for destruction, or what do you do about mutexes?)
208 : */
209 : extern bool _throw_on_error;
210 :
211 : /**
212 : * Variable to turn on exceptions during mooseWarning(), should
213 : * only be used in MOOSE unit tests.
214 : */
215 : extern bool _throw_on_warning;
216 :
217 : /**
218 : * Storage for the registered execute flags. This is needed for the ExecuteMooseObjectWarehouse
219 : * to create the necessary storage containers on a per flag basis. This isn't something that
220 : * should be used by application developers.
221 : */
222 : extern ExecFlagEnum execute_flags;
223 :
224 : /**
225 : * Macros for coloring any output stream (_console, std::ostringstream, etc.)
226 : */
227 : #define COLOR_BLACK (Moose::colorConsole() ? XTERM_BLACK : "")
228 : #define COLOR_RED (Moose::colorConsole() ? XTERM_RED : "")
229 : #define COLOR_GREEN (Moose::colorConsole() ? XTERM_GREEN : "")
230 : #define COLOR_YELLOW (Moose::colorConsole() ? XTERM_YELLOW : "")
231 : #define COLOR_BLUE (Moose::colorConsole() ? XTERM_BLUE : "")
232 : #define COLOR_MAGENTA (Moose::colorConsole() ? XTERM_MAGENTA : "")
233 : #define COLOR_CYAN (Moose::colorConsole() ? XTERM_CYAN : "")
234 : #define COLOR_WHITE (Moose::colorConsole() ? XTERM_WHITE : "")
235 : #define COLOR_DEFAULT (Moose::colorConsole() ? XTERM_DEFAULT : "")
236 :
237 : /// Returns whether Console coloring is turned on (default: true).
238 : bool colorConsole();
239 :
240 : /// Turns color escape sequences on/off for info written to stdout.
241 : /// Returns the the set value which may be different than use_color.
242 : bool setColorConsole(bool use_color, bool force = false);
243 :
244 : /**
245 : * Import libMesh::out, and libMesh::err for use in MOOSE.
246 : */
247 : using libMesh::err;
248 : using libMesh::out;
249 :
250 : /**
251 : * Register objects that are in MOOSE
252 : */
253 :
254 : void registerAll(Factory & f, ActionFactory & af, Syntax & s);
255 :
256 : void registerObjects(Factory & factory, const std::set<std::string> & obj_labels);
257 : void addActionTypes(Syntax & syntax);
258 : void registerActions(Syntax & syntax, ActionFactory & action_factory);
259 : void registerActions(Syntax & syntax,
260 : ActionFactory & action_factory,
261 : const std::set<std::string> & obj_labels);
262 :
263 : void associateSyntax(Syntax & syntax, ActionFactory & action_factory);
264 :
265 : void setSolverDefaults(FEProblemBase & problem);
266 :
267 : /**
268 : * Swap the libMesh MPI communicator out for ours. Note that you should usually use
269 : * the Moose::ScopedCommSwapper class instead of calling this function.
270 : */
271 : MPI_Comm swapLibMeshComm(MPI_Comm new_comm);
272 :
273 : class ScopedCommSwapper
274 : {
275 : public:
276 : /// Swaps the current libmesh MPI communicator for new_comm. new_comm will be automatically
277 : /// swapped back in as the current libmesh communicator when this object is destructed.
278 584218 : ScopedCommSwapper(MPI_Comm new_comm) : _orig(swapLibMeshComm(new_comm)) {}
279 584143 : virtual ~ScopedCommSwapper() { swapLibMeshComm(_orig); }
280 : /// Forcibly swap the currently swapped-out communicator back in to libmesh. Calling this
281 : /// function twice in a row leaves communicators exactly as they were before this function
282 : /// was called. Usually you should not need/use this function because MPI communicators
283 : /// are swapped automatically when this object is constructed/destructed.
284 35507 : void forceSwap() { _orig = swapLibMeshComm(_orig); }
285 :
286 : private:
287 : MPI_Comm _orig;
288 : };
289 :
290 : /**
291 : * Scoped helper for setting Moose::_throw_on_error during this scope.
292 : *
293 : * Cannot be used within threads.
294 : */
295 : class ScopedThrowOnError
296 : {
297 : public:
298 : /**
299 : * Default constructor, which sets Moose::_throw_on_error = true
300 : */
301 : ScopedThrowOnError();
302 :
303 : /**
304 : * Specialized constructor, which sets Moose::_throw_on_error
305 : * based on the argument \p throw_on_error
306 : */
307 : ScopedThrowOnError(const bool throw_on_error);
308 :
309 : /**
310 : * Destructor, which sets Moose::_throw_on_error to what it
311 : * was upon construction
312 : */
313 : ~ScopedThrowOnError();
314 :
315 : private:
316 : /// The value of Moose::_throw_on_error at construction
317 : const bool _throw_on_error_before;
318 : };
319 :
320 : /**
321 : * Scoped helper for setting Moose::_deprecated_is_error during this scope.
322 : *
323 : * Cannot be used within threads.
324 : */
325 : class ScopedDeprecatedIsError
326 : {
327 : public:
328 : /**
329 : * Default constructor, which sets Moose::_deprecated_is_error = true
330 : */
331 : ScopedDeprecatedIsError();
332 :
333 : /**
334 : * Specialized constructor, which sets Moose::_deprecated_is_error
335 : * based on the argument \p deprecated_is_error
336 : */
337 : ScopedDeprecatedIsError(const bool deprecated_is_error);
338 :
339 : /**
340 : * Destructor, which sets Moose::_deprecated_is_error to what it
341 : * was upon construction
342 : */
343 : ~ScopedDeprecatedIsError();
344 :
345 : private:
346 : /// The value of Moose::_throw_on_error at construction
347 : const bool _deprecated_is_error_before;
348 : };
349 :
350 : /**
351 : * Get the prefix to be associated with a hit node for a message
352 : */
353 : std::string hitMessagePrefix(const hit::Node & node);
354 :
355 : // MOOSE Requires PETSc to run, this CPP check will cause a compile error if PETSc is not found
356 : #ifndef LIBMESH_HAVE_PETSC
357 : #error PETSc has not been detected, please ensure your environment is set up properly then rerun the libmesh build script and try to compile MOOSE again.
358 : #endif
359 :
360 : } // namespace Moose
361 :
362 : // If we are using MFEM, in addition to the checks we do as part of the build system in moose.mk,
363 : // we check at compile time if both MOOSE and MFEM were built in dbg mode or not
364 : #ifdef MOOSE_MFEM_ENABLED
365 : #include "libmesh/ignore_warnings.h"
366 : #include <mfem.hpp>
367 : #include "libmesh/restore_warnings.h"
368 : #ifdef MFEM_DEBUG
369 : static_assert(std::string_view(QUOTE(METHOD)) == "dbg",
370 : "MFEM was built in dbg mode, but not MOOSE. Try reinstalling "
371 : "MFEM using the scripts/update_and_rebuild_mfem.sh script.");
372 : #else
373 : static_assert(std::string_view(QUOTE(METHOD)) != "dbg",
374 : "MOOSE was built in dbg mode, but not MFEM. Try reinstalling "
375 : "MFEM using the scripts/update_and_rebuild_mfem.sh script.");
376 : #endif
377 : #endif
|