https://mooseframework.inl.gov
SetupDebugAction.C
Go to the documentation of this file.
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 #include "SetupDebugAction.h"
11 #include "FEProblem.h"
12 #include "ActionWarehouse.h"
13 #include "Factory.h"
14 #include "Output.h"
15 #include "MooseApp.h"
16 #include "MooseObjectAction.h"
17 #include "ActionFactory.h"
18 #include "AddAuxVariableAction.h"
19 #include "MooseUtils.h"
21 
22 using namespace libMesh;
23 
24 registerMooseAction("MooseApp", SetupDebugAction, "add_output");
25 
28 {
30  params.addParam<unsigned int>(
31  "show_top_residuals", 0, "The number of top residuals to print out (0 = no output)");
32  params.addParam<bool>(
33  "show_var_residual_norms",
34  false,
35  "Print the residual norms of the individual solution variables at each nonlinear iteration");
36  params.addParam<bool>("show_action_dependencies", false, "Print out the action dependencies");
37  params.addParam<bool>("show_actions", false, "Print out the actions being executed");
38  params.addParam<bool>(
39  "show_parser", false, "Shows parser block extraction and debugging information");
40  params.addParam<bool>(
41  "show_material_props",
42  false,
43  "Print out the material properties supplied for each block, face, neighbor, and/or sideset");
44  params.addParam<bool>("show_chain_control_data",
45  false,
46  "Print out the chain control data on every time step setup");
47  params.addParam<bool>("show_controllable",
48  false,
49  "Print out the controllable parameters from all input parameters");
50  params.addParam<bool>("show_mesh_meta_data", false, "Print out the available mesh meta data");
51  params.addParam<bool>(
52  "show_reporters", false, "Print out information about the declared and requested Reporters");
53  params.addParam<bool>(
54  "show_mesh_generators", false, "Print out the mesh generators being executed");
55 
57  print_on.addAvailableFlags(EXEC_TRANSFER);
58  print_on.addAvailableFlags(EXEC_FAILED);
59  print_on.addAvailableFlags(EXEC_ALWAYS);
60  params.addParam<ExecFlagEnum>(
61  "show_execution_order",
62  print_on,
63  "Print more information about the order of execution during calculations");
64  params.addDeprecatedParam<bool>(
65  "pid_aux",
66  "Add a AuxVariable named \"pid\" that shows the processors and partitioning",
67  "pid_aux is deprecated, use output_process_domains");
68  params.addParam<bool>(
69  "output_process_domains",
70  false,
71  "Add a AuxVariable named \"pid\" that shows the partitioning for each process");
72  params.addParam<bool>(
73  "show_functors", false, "Whether to print information about the functors in the problem");
74  params.addParam<MultiMooseEnum>(
75  "show_block_restriction",
77  "Print out active objects like variables supplied for each block.");
78 
79  params.addClassDescription("Adds various debugging type output to the simulation system.");
80 
81  return params;
82 }
83 
85 {
86  _awh.showActionDependencies(getParam<bool>("show_action_dependencies"));
87  _awh.showActions(getParam<bool>("show_actions"));
88  _awh.showParser(getParam<bool>("show_parser"));
89  _awh.mooseApp().getMeshGeneratorSystem().setVerbose(getParam<bool>("show_mesh_generators"));
90 }
91 
92 void
94 {
95  // Material properties
96  if (_pars.get<bool>("show_material_props"))
97  {
98  const std::string type = "MaterialPropertyDebugOutput";
99  auto params = _factory.getValidParams(type);
100  _problem->addOutput(type, "_moose_material_property_debug_output", params);
101  }
102 
103  // Variable residual norms
104  if (_pars.get<bool>("show_var_residual_norms"))
105  {
106  const std::string type = "VariableResidualNormsDebugOutput";
107  auto params = _factory.getValidParams(type);
108  // Add one for every nonlinear system
109  for (const auto & sys_name : _problem->getNonlinearSystemNames())
110  {
111  params.set<NonlinearSystemName>("nl_sys") = sys_name;
112  _problem->addOutput(type, "_moose_variable_residual_norms_debug_output_" + sys_name, params);
113  }
114  }
115 
116  // Top residuals
117  if (_pars.get<unsigned int>("show_top_residuals") > 0)
118  {
119  const std::string type = "TopResidualDebugOutput";
120  auto params = _factory.getValidParams(type);
121  params.set<unsigned int>("num_residuals") = _pars.get<unsigned int>("show_top_residuals");
122  _problem->addOutput(type, "_moose_top_residual_debug_output", params);
123  }
124 
125  // Print full names of mesh meta data
126  if (getParam<bool>("show_mesh_meta_data"))
127  {
128  _console << "Mesh meta data:\n";
129  for (auto it = _app.getRestartableDataMapBegin(); it != _app.getRestartableDataMapEnd(); ++it)
130  if (it->first == MooseApp::MESH_META_DATA)
131  for (auto & data : it->second.first)
132  _console << " " << data.name() << std::endl;
133  }
134 
135  // Print Reporter information
136  if (getParam<bool>("show_reporters"))
137  {
138  const std::string type = "ReporterDebugOutput";
139  auto params = _factory.getValidParams(type);
140  _problem->addOutput(type, "_moose_reporter_debug_output", params);
141  }
142 
143  // Print execution information in all loops
144  if (parameters().isParamSetByUser("show_execution_order"))
145  _problem->setExecutionPrinting(getParam<ExecFlagEnum>("show_execution_order"));
146 
147  // Add pid aux
148  if (getParam<bool>("output_process_domains") ||
149  (isParamValid("pid_aux") && getParam<bool>("pid_aux")))
150  {
151  if (_problem->hasVariable("pid"))
152  paramError("output_process_domains", "Variable with the name \"pid\" already exists");
153 
154  auto fe_type = FEType(CONSTANT, MONOMIAL);
156  auto var_params = _factory.getValidParams(type);
157  _problem->addAuxVariable(type, "pid", var_params);
158 
159  InputParameters params = _factory.getValidParams("ProcessorIDAux");
160  params.set<AuxVariableName>("variable") = "pid";
161  params.set<ExecFlagEnum>("execute_on") = {EXEC_INITIAL, EXEC_TIMESTEP_BEGIN};
162  _problem->addAuxKernel("ProcessorIDAux", "pid_aux", params);
163  }
164 
165  // Add functor output
166  if (getParam<bool>("show_functors"))
167  _problem->setFunctorOutput(getParam<bool>("show_functors"));
168 
169  // Add chain control data output
170  if (getParam<bool>("show_chain_control_data"))
171  _problem->setChainControlDataOutput(true);
172 
173  // Block-restriction
174  const MultiMooseEnum & block_restriction_scope =
175  _pars.get<MultiMooseEnum>("show_block_restriction");
176  if (block_restriction_scope.isValid() && !block_restriction_scope.contains("none"))
177  {
178  const std::string type = "BlockRestrictionDebugOutput";
179  auto params = _factory.getValidParams(type);
180  params.set<MultiMooseEnum>("scope") = block_restriction_scope;
181  _problem->addOutput(type, "_moose_block_restriction_debug_output", params);
182  }
183 
184  // Controllable output
185  if (getParam<bool>("show_controllable"))
186  {
187  const std::string type = "ControlOutput";
188  auto params = _factory.getValidParams(type);
189  _problem->addOutput(type, "_moose_controllable_debug_output", params);
190  }
191 }
const ExecFlagType EXEC_TRANSFER
Definition: Moose.C:55
const ExecFlagType EXEC_FAILED
Definition: Moose.C:48
A MultiMooseEnum object to hold "execute_on" flags.
Definition: ExecFlagEnum.h:21
void setVerbose(const bool verbose)
Set the verbose flag.
auto getRestartableDataMapBegin()
Iterator based access to the extra RestartableDataMap objects; see Checkpoint.C for use case...
Definition: MooseApp.h:1033
const InputParameters & _pars
The object&#39;s parameters.
Definition: MooseBase.h:366
void addDeprecatedParam(const std::string &name, const T &value, const std::string &doc_string, const std::string &deprecation_message)
MooseApp & mooseApp()
ActionWarehouse & _awh
Reference to ActionWarehouse where we store object build by actions.
Definition: Action.h:169
void paramError(const std::string &param, Args... args) const
Emits an error prefixed with the file and line number of the given param (from the input file) along ...
Definition: MooseBase.h:439
std::vector< std::pair< R1, R2 > > get(const std::string &param1, const std::string &param2) const
Combine two vector parameters into a single vector of pairs.
Factory & _factory
The Factory associated with the MooseApp.
static const RestartableDataMapName MESH_META_DATA
Definition: MooseApp.h:130
virtual bool isValid() const override
IsValid.
const InputParameters & parameters() const
Get the parameters of the object.
Definition: MooseBase.h:131
virtual void act() override
Method to add objects to the simulation or perform other setup tasks.
T & set(const std::string &name, bool quiet_mode=false)
Returns a writable reference to the named parameters.
void showActions(bool state=true)
This method sets a Boolean which is used to show information about action execution of various wareho...
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
void showActionDependencies(bool state=true)
This method sets a Boolean which is used to print information about action dependencies before variou...
The following methods are specializations for using the libMesh::Parallel::packed_range_* routines fo...
const ExecFlagType EXEC_ALWAYS
Definition: Moose.C:51
registerMooseAction("MooseApp", SetupDebugAction, "add_output")
Base class for actions.
Definition: Action.h:34
SetupDebugAction(const InputParameters &parameters)
ExecFlagEnum getDefaultExecFlagEnum()
Definition: MooseUtils.C:972
bool contains(const std::string &value) const
Methods for seeing if a value is set in the MultiMooseEnum.
CONSTANT
void showParser(bool state=true)
This method sets a Boolean which is used to show debugging information when actions are inserted in t...
static InputParameters validParams()
Definition: Action.C:26
const ExecFlagType EXEC_TIMESTEP_BEGIN
Definition: Moose.C:37
const std::string & type() const
Get the type of this class.
Definition: MooseBase.h:93
static std::string variableType(const libMesh::FEType &fe_type, const bool is_fv=false, const bool is_array=false)
Determines a variable type.
MooseApp & _app
The MOOSE application this is associated with.
Definition: MooseBase.h:357
MONOMIAL
auto getRestartableDataMapEnd()
Definition: MooseApp.h:1035
static MultiMooseEnum getScopes(std::string default_scopes="")
Get the supported scopes of output (e.g., variables, etc.)
void addClassDescription(const std::string &doc_string)
This method adds a description of the class that will be displayed in the input file syntax dump...
std::shared_ptr< FEProblemBase > & _problem
Convenience reference to a problem this action works on.
Definition: Action.h:178
void addParam(const std::string &name, const S &value, const std::string &doc_string)
These methods add an optional parameter and a documentation string to the InputParameters object...
bool isParamValid(const std::string &name) const
Test if the supplied parameter is valid.
Definition: MooseBase.h:199
const ConsoleStream _console
An instance of helper class to write streams to the Console objects.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type...
MeshGeneratorSystem & getMeshGeneratorSystem()
Gets the system that manages the MeshGenerators.
Definition: MooseApp.h:840
static InputParameters validParams()
bool isParamSetByUser(const std::string &name) const
Test if the supplied parameter is set by a user, as opposed to not set or set to default.
Definition: MooseBase.h:205
const ExecFlagType EXEC_INITIAL
Definition: Moose.C:30