www.mooseframework.org
Public Member Functions | Private Member Functions | Private Attributes | Friends | List of all members
OutputWarehouse Class Reference

Class for storing and utilizing output objects. More...

#include <OutputWarehouse.h>

Public Member Functions

 OutputWarehouse (MooseApp &app)
 Class constructor. More...
 
virtual ~OutputWarehouse ()
 
void addOutput (std::shared_ptr< Output > &output)
 Adds an existing output object to the warehouse. More...
 
const std::set< OutputName > & getOutputNames ()
 Get a complete set of all output object names. More...
 
bool hasOutput (const std::string &name) const
 Returns true if the output object exists. More...
 
void meshChanged ()
 Calls the meshChanged method for every output object. More...
 
void buildInterfaceHideVariables (const std::string &output_name, std::set< std::string > &hide)
 Return the list of hidden variables for the given output name. More...
 
void setFileNumbers (std::map< std::string, unsigned int > input, unsigned int offset=0)
 Calls the setFileNumber method for every FileOutput output object. More...
 
std::map< std::string, unsigned int > getFileNumbers ()
 Extracts the file numbers from the output objects. More...
 
void setCommonParameters (InputParameters *params_ptr)
 Stores the common InputParameters object. More...
 
InputParametersgetCommonParameters ()
 Get a reference to the common output parameters. More...
 
std::set< Real > & getSyncTimes ()
 Return the sync times for all objects. More...
 
void checkOutputs (const std::set< OutputName > &names)
 Test that the output names exist. More...
 
template<typename T >
T * getOutput (const OutputName &name)
 Return an Output object by name. More...
 
template<typename T >
std::vector< T * > getOutputs (const std::vector< OutputName > &names)
 Return a vector of objects by names. More...
 
template<typename T >
std::vector< T * > getOutputs () const
 Return a vector of objects of a given type. More...
 
template<typename T >
std::vector< OutputName > getOutputNames ()
 Return a list of output objects with a given type. More...
 
const std::set< std::string > & getReservedNames () const
 Return a set of reserved output names. More...
 
bool isReservedName (const std::string &name)
 Test if the given name is reserved. More...
 
void mooseConsole ()
 Send current output buffer to Console output objects. More...
 
std::ostringstream & consoleBuffer ()
 The buffered messages stream for Console objects. More...
 
void bufferConsoleOutputsBeforeConstruction (bool buffer)
 Set if the outputs to Console before its construction are to be buffered or to screen directly. More...
 
void setLoggingRequested ()
 Sets a Boolean indicating that at least one object is requesting performance logging in this application. More...
 
bool getLoggingRequested () const
 Returns a Boolean indicating whether performance logging is requested in this application. More...
 

Private Member Functions

void outputStep (ExecFlagType type)
 Calls the outputStep method for each output object. More...
 
void forceOutput ()
 Indicates that the next call to outputStep should be forced This is private, users should utilize FEProblemBase::forceOutput() More...
 
void addOutputFilename (const OutFileBase &filename)
 Adds the file name to the list of filenames being output The main function of this object is to test that the same output file does not already exist to protect against output files overwriting each other. More...
 
void initialSetup ()
 Calls the initialSetup function for each of the output objects. More...
 
void timestepSetup ()
 Calls the timestepSetup function for each of the output objects. More...
 
void solveSetup ()
 Calls the timestepSetup function for each of the output objects. More...
 
void jacobianSetup ()
 Calls the jacobianSetup function for each of the output objects. More...
 
void residualSetup ()
 Calls the residualSetup function for each of the output objects. More...
 
void subdomainSetup ()
 Calls the subdomainSetup function for each of the output objects. More...
 
void addInterfaceHideVariables (const std::string &output_name, const std::set< std::string > &variable_names)
 Insert variable names for hiding via the OutoutInterface. More...
 
void setOutputExecutionType (ExecFlagType type)
 Sets the execution flag type. More...
 
void flushConsoleBuffer ()
 If content exists in the buffer, write it. More...
 
void allowOutput (bool state)
 Ability to enable/disable output calls This is private, users should utilize FEProblemBase::allowOutput() More...
 
template<typename T >
void allowOutput (bool state)
 

Private Attributes

std::vector< std::shared_ptr< Output > > _all_ptrs
 We are using std::shared_ptr to handle the cleanup of the pointers at the end of execution. More...
 
MooseApp_app
 MooseApp. More...
 
std::vector< Output * > _all_objects
 All instances of objects (raw pointers) More...
 
bool _buffer_action_console_outputs
 True to buffer console outputs in actions. More...
 
std::map< OutputName, Output * > _object_map
 A map of the output pointers. More...
 
std::set< OutputName > _object_names
 A set of output names. More...
 
std::set< OutFileBase > _file_base_set
 List of object names. More...
 
InputParameters_common_params_ptr
 Pointer to the common InputParameters (. More...
 
std::set< Real > _sync_times
 Sync times for all objects. More...
 
std::string _input_file_name
 Input file name for this output object. More...
 
std::map< OutputName, std::set< AuxVariableName > > _material_output_map
 Map of output name and AuxVariable names to be output (used by auto Material output) More...
 
std::set< AuxVariableName > _all_material_output_variables
 List of all variable created by auto material output. More...
 
std::set< std::string > _reserved
 List of reserved names. More...
 
std::ostringstream _console_buffer
 The stream for holding messages passed to _console prior to Output object construction. More...
 
std::map< std::string, std::set< std::string > > _interface_map
 Storage for variables to hide as prescribed by the object via the OutputInterface. More...
 
ExecFlagType _output_exec_flag
 The current output execution flag. More...
 
bool _force_output
 Flag indicating that next call to outputStep is forced. More...
 
bool _logging_requested
 Indicates that performance logging has been requested by the console or some object (PerformanceData) More...
 

Friends

class FEProblemBase
 
class MaterialOutputAction
 
class OutputInterface
 
class PetscOutput
 

Detailed Description

Class for storing and utilizing output objects.

Definition at line 23 of file OutputWarehouse.h.

Constructor & Destructor Documentation

◆ OutputWarehouse()

OutputWarehouse::OutputWarehouse ( MooseApp app)

Class constructor.

Definition at line 23 of file OutputWarehouse.C.

24  : _app(app),
27  _force_output(false),
28  _logging_requested(false)
29 {
30  // Set the reserved names
31  _reserved.insert("none"); // allows 'none' to be used as a keyword in 'outputs' parameter
32  _reserved.insert("all"); // allows 'all' to be used as a keyword in 'outputs' parameter
33 }
bool _buffer_action_console_outputs
True to buffer console outputs in actions.
const ExecFlagType EXEC_CUSTOM
std::set< std::string > _reserved
List of reserved names.
ExecFlagType _output_exec_flag
The current output execution flag.
MooseApp & _app
MooseApp.
bool _force_output
Flag indicating that next call to outputStep is forced.
bool _logging_requested
Indicates that performance logging has been requested by the console or some object (PerformanceData)...

◆ ~OutputWarehouse()

OutputWarehouse::~OutputWarehouse ( )
virtual

Definition at line 35 of file OutputWarehouse.C.

36 {
37  // If the output buffer is not empty, it needs to be written
38  if (_console_buffer.str().length())
39  mooseConsole();
40 }
std::ostringstream _console_buffer
The stream for holding messages passed to _console prior to Output object construction.
void mooseConsole()
Send current output buffer to Console output objects.

Member Function Documentation

◆ addInterfaceHideVariables()

void OutputWarehouse::addInterfaceHideVariables ( const std::string &  output_name,
const std::set< std::string > &  variable_names 
)
private

Insert variable names for hiding via the OutoutInterface.

Parameters
output_nameThe name of the output object on which the variable is to be hidden
variable_namesThe names of the variables to be hidden

This is a private method used by the OutputInterface system, it is not intended for any other purpose.

Definition at line 263 of file OutputWarehouse.C.

Referenced by MaterialOutputAction::act(), and OutputInterface::buildOutputHideVariableList().

265 {
266  _interface_map[output_name].insert(variable_names.begin(), variable_names.end());
267 }
std::map< std::string, std::set< std::string > > _interface_map
Storage for variables to hide as prescribed by the object via the OutputInterface.

◆ addOutput()

void OutputWarehouse::addOutput ( std::shared_ptr< Output > &  output)

Adds an existing output object to the warehouse.

Parameters
outputPointer to the output object It is the responsibility of the OutputWarehouse to delete the output objects add using this method

Definition at line 85 of file OutputWarehouse.C.

Referenced by FEProblemBase::addOutput().

86 {
87  _all_ptrs.push_back(output);
88 
89  // Add the object to the warehouse storage, Checkpoint placed at end so they are called last
90  Checkpoint * cp = dynamic_cast<Checkpoint *>(output.get());
91  if (cp != NULL)
92  _all_objects.push_back(output.get());
93  else
94  _all_objects.insert(_all_objects.begin(), output.get());
95 
96  // Store the name and pointer
97  _object_map[output->name()] = output.get();
98  _object_names.insert(output->name());
99 
100  // If the output object is a FileOutput then store the output filename
101  FileOutput * ptr = dynamic_cast<FileOutput *>(output.get());
102  if (ptr != NULL)
103  addOutputFilename(ptr->filename());
104 
105  // Insert object sync times to the global set
106  if (output->parameters().isParamValid("sync_times"))
107  {
108  std::vector<Real> sync_times = output->parameters().get<std::vector<Real>>("sync_times");
109  _sync_times.insert(sync_times.begin(), sync_times.end());
110  }
111 }
virtual std::string filename()
The filename for the output file.
Definition: FileOutput.C:172
std::map< OutputName, Output * > _object_map
A map of the output pointers.
std::set< OutputName > _object_names
A set of output names.
std::vector< Output * > _all_objects
All instances of objects (raw pointers)
void addOutputFilename(const OutFileBase &filename)
Adds the file name to the list of filenames being output The main function of this object is to test ...
std::vector< std::shared_ptr< Output > > _all_ptrs
We are using std::shared_ptr to handle the cleanup of the pointers at the end of execution.
An outputter with filename support.
Definition: FileOutput.h:27
std::set< Real > _sync_times
Sync times for all objects.

◆ addOutputFilename()

void OutputWarehouse::addOutputFilename ( const OutFileBase &  filename)
private

Adds the file name to the list of filenames being output The main function of this object is to test that the same output file does not already exist to protect against output files overwriting each other.

Parameters
filenameName of an output file (extracted from filename() method of the objects)

Definition at line 132 of file OutputWarehouse.C.

Referenced by addOutput().

133 {
134  if (_file_base_set.find(filename) != _file_base_set.end())
135  mooseError("An output file with the name, ", filename, ", already exists.");
136  _file_base_set.insert(filename);
137 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:208
std::set< OutFileBase > _file_base_set
List of object names.

◆ allowOutput() [1/2]

void OutputWarehouse::allowOutput ( bool  state)
private

Ability to enable/disable output calls This is private, users should utilize FEProblemBase::allowOutput()

See also
FEProblemBase::allowOutput()

Definition at line 306 of file OutputWarehouse.C.

Referenced by FEProblemBase::allowOutput().

307 {
308  for (const auto & obj : _all_objects)
309  obj->allowOutput(state);
310 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ allowOutput() [2/2]

template<typename T >
void OutputWarehouse::allowOutput ( bool  state)
private

Definition at line 440 of file OutputWarehouse.h.

441 {
442  std::vector<T *> outputs = getOutputs<T>();
443  for (typename std::vector<T *>::iterator it = outputs.begin(); it != outputs.end(); ++it)
444  (*it)->allowOutput(state);
445 }

◆ bufferConsoleOutputsBeforeConstruction()

void OutputWarehouse::bufferConsoleOutputsBeforeConstruction ( bool  buffer)
inline

Set if the outputs to Console before its construction are to be buffered or to screen directly.

Parameters
bufferTure to buffer

Definition at line 184 of file OutputWarehouse.h.

185  {
187  }
bool _buffer_action_console_outputs
True to buffer console outputs in actions.

◆ buildInterfaceHideVariables()

void OutputWarehouse::buildInterfaceHideVariables ( const std::string &  output_name,
std::set< std::string > &  hide 
)

Return the list of hidden variables for the given output name.

Parameters
output_nameThe name of the output object for which the variables should be returned
hideThe set of variables to hide which is built by this method

Objects inheriting from the OutputInterface have the ability to control the output of variables associated with the objects (i.e., Marker elemental variable). This method returns a list of variables that should be hidden for the supplied object name due to the 'outputs' parameter being set by the object(s).

This method is used by Output::initOutputList to populate the correct hide lists for the output object, it is not intended for general use.

Definition at line 270 of file OutputWarehouse.C.

Referenced by AdvancedOutput::initOutputList().

272 {
273  std::map<std::string, std::set<std::string>>::const_iterator it =
274  _interface_map.find(output_name);
275  if (it != _interface_map.end())
276  hide = it->second;
277 }
std::map< std::string, std::set< std::string > > _interface_map
Storage for variables to hide as prescribed by the object via the OutputInterface.

◆ checkOutputs()

void OutputWarehouse::checkOutputs ( const std::set< OutputName > &  names)

Test that the output names exist.

Parameters
namesA vector of names to check This method will produce an error if any of the supplied names do not exist in the warehouse. Reserved names are not considered.

Definition at line 280 of file OutputWarehouse.C.

Referenced by CheckOutputAction::checkMaterialOutput(), and AdvancedOutput::initPostprocessorOrVectorPostprocessorLists().

281 {
282  for (const auto & name : names)
283  if (!isReservedName(name) && !hasOutput(name))
284  mooseError("The output object '", name, "' is not a defined output object");
285 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:208
bool isReservedName(const std::string &name)
Test if the given name is reserved.
bool hasOutput(const std::string &name) const
Returns true if the output object exists.

◆ consoleBuffer()

std::ostringstream& OutputWarehouse::consoleBuffer ( )
inline

The buffered messages stream for Console objects.

Returns
Reference to the stream storing cached messages from calls to _console

Definition at line 178 of file OutputWarehouse.h.

178 { return _console_buffer; }
std::ostringstream _console_buffer
The stream for holding messages passed to _console prior to Output object construction.

◆ flushConsoleBuffer()

void OutputWarehouse::flushConsoleBuffer ( )
private

If content exists in the buffer, write it.

This is used by Console to make sure PETSc related output does not dump before buffered content. It is private because people shouldn't be messing with it.

Definition at line 203 of file OutputWarehouse.C.

Referenced by outputStep(), PetscOutput::petscLinearOutput(), and PetscOutput::petscNonlinearOutput().

204 {
205  if (!_console_buffer.str().empty())
206  mooseConsole();
207 }
std::ostringstream _console_buffer
The stream for holding messages passed to _console prior to Output object construction.
void mooseConsole()
Send current output buffer to Console output objects.

◆ forceOutput()

void OutputWarehouse::forceOutput ( )
private

Indicates that the next call to outputStep should be forced This is private, users should utilize FEProblemBase::forceOutput()

See also
FEProblemBase::forceOutput()

Definition at line 313 of file OutputWarehouse.C.

Referenced by FEProblemBase::forceOutput().

314 {
315  _force_output = true;
316 }
bool _force_output
Flag indicating that next call to outputStep is forced.

◆ getCommonParameters()

InputParameters * OutputWarehouse::getCommonParameters ( )

Get a reference to the common output parameters.

Returns
Pointer to the common InputParameters object

Definition at line 251 of file OutputWarehouse.C.

Referenced by FEProblemBase::addOutput().

252 {
253  return _common_params_ptr;
254 }
InputParameters * _common_params_ptr
Pointer to the common InputParameters (.

◆ getFileNumbers()

std::map< std::string, unsigned int > OutputWarehouse::getFileNumbers ( )

Extracts the file numbers from the output objects.

Returns
Map of file numbers for the output objects

Definition at line 231 of file OutputWarehouse.C.

Referenced by MultiApp::createApp().

232 {
233 
234  std::map<std::string, unsigned int> output;
235  for (const auto & obj : _all_objects)
236  {
237  FileOutput * ptr = dynamic_cast<FileOutput *>(obj);
238  if (ptr != NULL)
239  output[ptr->name()] = ptr->getFileNumber();
240  }
241  return output;
242 }
unsigned int getFileNumber()
Return the current file number for this outputter.
Definition: FileOutput.C:184
std::vector< Output * > _all_objects
All instances of objects (raw pointers)
const std::string & name() const
Get the name of the object.
Definition: MooseObject.h:51
An outputter with filename support.
Definition: FileOutput.h:27

◆ getLoggingRequested()

bool OutputWarehouse::getLoggingRequested ( ) const
inline

Returns a Boolean indicating whether performance logging is requested in this application.

Definition at line 193 of file OutputWarehouse.h.

193 { return _logging_requested; }
bool _logging_requested
Indicates that performance logging has been requested by the console or some object (PerformanceData)...

◆ getOutput()

template<typename T >
T * OutputWarehouse::getOutput ( const OutputName &  name)

Return an Output object by name.

Template Parameters
TThe Out put object type to return
Parameters
nameThe name of the output object
Returns
A pointer to the output object

Definition at line 364 of file OutputWarehouse.h.

365 {
366  // Check that the object exists
367  if (!hasOutput(name))
368  mooseError("An output object with the name '", name, "' does not exist.");
369 
370  // Attempt to cast the object to the correct type
371  T * output = dynamic_cast<T *>(_object_map[name]);
372 
373  // Error if the cast fails
374  if (output == NULL)
375  mooseError("An output object with the name '", name, "' for the specified type does not exist");
376 
377  // Return the object
378  return output;
379 }
std::map< OutputName, Output * > _object_map
A map of the output pointers.
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:208
bool hasOutput(const std::string &name) const
Returns true if the output object exists.

◆ getOutputNames() [1/2]

const std::set< OutputName > & OutputWarehouse::getOutputNames ( )

Get a complete set of all output object names.

Returns
A set of output names for each output object

Note, if this method is called prior to the creation of outputs in AddOutputAction it will create the proxy list of names from the action system. The main use is for the OutputInterface, specifically, when used with Postprocessors in the UserObjects block of the input file. UserObjects are created prior to Outputs objects, but OutputInterface needs the list of output names to operate correctly.

Definition at line 120 of file OutputWarehouse.C.

Referenced by OutputInterface::buildOutputHideVariableList().

121 {
122  if (_object_names.empty() && _app.actionWarehouse().hasActions("add_output"))
123  {
124  const auto & actions = _app.actionWarehouse().getActionListByName("add_output");
125  for (const auto & act : actions)
126  _object_names.insert(act->name());
127  }
128  return _object_names;
129 }
std::set< OutputName > _object_names
A set of output names.
const std::list< Action * > & getActionListByName(const std::string &task) const
Retrieve a constant list of Action pointers associated with the passed in task.
MooseApp & _app
MooseApp.
ActionWarehouse & actionWarehouse()
Definition: MooseApp.h:139
bool hasActions(const std::string &task) const
Check if Actions associated with passed in task exist.

◆ getOutputNames() [2/2]

template<typename T >
std::vector< OutputName > OutputWarehouse::getOutputNames ( )

Return a list of output objects with a given type.

Template Parameters
TThe output object type
Returns
A vector of names

Definition at line 419 of file OutputWarehouse.h.

420 {
421  // The output vector
422  std::vector<OutputName> names;
423 
424  // Loop through the objects and store the name if the type cast succeeds
425  for (std::map<OutputName, Output *>::const_iterator it = _object_map.begin();
426  it != _object_map.end();
427  ++it)
428  {
429  T * output = dynamic_cast<T *>(it->second);
430  if (output != NULL)
431  names.push_back(it->first);
432  }
433 
434  // Return the names
435  return names;
436 }
std::map< OutputName, Output * > _object_map
A map of the output pointers.

◆ getOutputs() [1/2]

template<typename T >
std::vector< T * > OutputWarehouse::getOutputs ( const std::vector< OutputName > &  names)

Return a vector of objects by names.

Template Parameters
TThe Output object type to return
Parameters
namesA vector of names of the output object
Returns
A pointer to the output object

Definition at line 383 of file OutputWarehouse.h.

Referenced by CheckOutputAction::checkConsoleOutput(), CheckOutputAction::checkPerfLogOutput(), and ConsoleUtils::outputOutputInformation().

384 {
385  // The vector to output
386  std::vector<T *> outputs;
387 
388  // Populate the vector
389  for (std::vector<OutputName>::const_iterator it = names.begin(); it != names.end(); ++it)
390  outputs.push_back(getOutput<T>(*it));
391 
392  // Return the objects
393  return outputs;
394 }

◆ getOutputs() [2/2]

template<typename T >
std::vector< T * > OutputWarehouse::getOutputs ( ) const

Return a vector of objects of a given type.

Template Parameters
TThe Output object type to return
Returns
A pointer to the output object

Definition at line 398 of file OutputWarehouse.h.

399 {
400  // The vector to output
401  std::vector<T *> outputs;
402 
403  // Populate the vector
404  for (std::map<OutputName, Output *>::const_iterator it = _object_map.begin();
405  it != _object_map.end();
406  ++it)
407  {
408  T * output = dynamic_cast<T *>(it->second);
409  if (output != NULL)
410  outputs.push_back(output);
411  }
412 
413  // Return the objects
414  return outputs;
415 }
std::map< OutputName, Output * > _object_map
A map of the output pointers.

◆ getReservedNames()

const std::set< std::string > & OutputWarehouse::getReservedNames ( ) const

Return a set of reserved output names.

Returns
A std::set of reserved names

Definition at line 288 of file OutputWarehouse.C.

289 {
290  return _reserved;
291 }
std::set< std::string > _reserved
List of reserved names.

◆ getSyncTimes()

std::set< Real > & OutputWarehouse::getSyncTimes ( )

Return the sync times for all objects.

Definition at line 257 of file OutputWarehouse.C.

Referenced by TimePeriod::initialSetup().

258 {
259  return _sync_times;
260 }
std::set< Real > _sync_times
Sync times for all objects.

◆ hasOutput()

bool OutputWarehouse::hasOutput ( const std::string &  name) const

Returns true if the output object exists.

Parameters
nameThe name of the output object for which to test for existence within the warehouse

Definition at line 114 of file OutputWarehouse.C.

Referenced by FEProblemBase::addOutput(), checkOutputs(), and getOutput().

115 {
116  return _object_map.find(name) != _object_map.end();
117 }
std::map< OutputName, Output * > _object_map
A map of the output pointers.

◆ initialSetup()

void OutputWarehouse::initialSetup ( )
private

Calls the initialSetup function for each of the output objects.

See also
FEProblemBase::initialSetup()

Definition at line 43 of file OutputWarehouse.C.

Referenced by FEProblemBase::initialSetup().

44 {
45  for (const auto & obj : _all_objects)
46  obj->initialSetup();
47 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ isReservedName()

bool OutputWarehouse::isReservedName ( const std::string &  name)

Test if the given name is reserved.

Parameters
nameThe name to test
Returns
True if the name is reserved

Definition at line 294 of file OutputWarehouse.C.

Referenced by FEProblemBase::addOutput(), and checkOutputs().

295 {
296  return _reserved.find(name) != _reserved.end();
297 }
std::set< std::string > _reserved
List of reserved names.

◆ jacobianSetup()

void OutputWarehouse::jacobianSetup ( )
private

Calls the jacobianSetup function for each of the output objects.

See also
FEProblemBase::computeJacobian

Definition at line 64 of file OutputWarehouse.C.

Referenced by FEProblemBase::computeJacobianTags().

65 {
66  for (const auto & obj : _all_objects)
67  obj->jacobianSetup();
68 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ meshChanged()

void OutputWarehouse::meshChanged ( )

Calls the meshChanged method for every output object.

Definition at line 166 of file OutputWarehouse.C.

Referenced by MooseApp::setOutputPosition().

167 {
168  for (const auto & obj : _all_objects)
169  obj->meshChanged();
170 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ mooseConsole()

void OutputWarehouse::mooseConsole ( )

Send current output buffer to Console output objects.

Definition at line 173 of file OutputWarehouse.C.

Referenced by callMooseErrorRaw(), flushConsoleBuffer(), FEProblemBase::initialSetup(), ConsoleStream::operator<<(), and ~OutputWarehouse().

174 {
175  // Loop through all Console Output objects and pass the current output buffer
176  std::vector<Console *> objects = getOutputs<Console>();
177  if (!objects.empty())
178  {
179  for (const auto & obj : objects)
180  obj->mooseConsole(_console_buffer.str());
181 
182  // Reset
183  _console_buffer.clear();
184  _console_buffer.str("");
185  }
186  else
187  {
189  {
190  // this will cause messages to console before its construction immediately flushed and
191  // cleared.
192  std::string message = _console_buffer.str();
193  if (_app.multiAppLevel() > 0)
194  MooseUtils::indentMessage(_app.name(), message);
195  Moose::out << message << std::flush;
196  _console_buffer.clear();
197  _console_buffer.str("");
198  }
199  }
200 }
const std::string & name() const
Get the name of the object.
Definition: MooseApp.h:72
bool _buffer_action_console_outputs
True to buffer console outputs in actions.
void indentMessage(const std::string &prefix, std::string &message, const char *color=COLOR_CYAN)
Indents the supplied message given the prefix and color.
Definition: MooseUtils.C:488
unsigned int multiAppLevel() const
The MultiApp Level.
Definition: MooseApp.h:515
MooseApp & _app
MooseApp.
std::ostringstream _console_buffer
The stream for holding messages passed to _console prior to Output object construction.

◆ outputStep()

void OutputWarehouse::outputStep ( ExecFlagType  type)
private

Calls the outputStep method for each output object.

Parameters
typeThe type execution flag (see Moose.h)

This is private, users should utilize FEProblemBase::outputStep()

This is one of three locations where we explicitly flush the output buffers during a simulation: PetscOutput::petscNonlinearOutput() PetscOutput::petscLinearOutput() OutputWarehouse::outputStep()

All other Console output should be using newlines to avoid covering buffer errors and to avoid excessive I/O

Definition at line 140 of file OutputWarehouse.C.

Referenced by FEProblemBase::outputStep().

141 {
142  if (_force_output)
143  type = EXEC_FORCED;
144 
145  for (const auto & obj : _all_objects)
146  if (obj->enabled())
147  obj->outputStep(type);
148 
160 
161  // Reset force output flag
162  _force_output = false;
163 }
const ExecFlagType EXEC_FORCED
std::vector< Output * > _all_objects
All instances of objects (raw pointers)
bool _force_output
Flag indicating that next call to outputStep is forced.
MatType type
void flushConsoleBuffer()
If content exists in the buffer, write it.

◆ residualSetup()

void OutputWarehouse::residualSetup ( )
private

Calls the residualSetup function for each of the output objects.

See also
FEProblemBase::computeResidualTyp

Definition at line 71 of file OutputWarehouse.C.

Referenced by FEProblemBase::computeResidualTags().

72 {
73  for (const auto & obj : _all_objects)
74  obj->residualSetup();
75 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ setCommonParameters()

void OutputWarehouse::setCommonParameters ( InputParameters params_ptr)

Stores the common InputParameters object.

Parameters
params_ptrA pointer to the common parameters object to be stored
See also
CommonOutputAction

Definition at line 245 of file OutputWarehouse.C.

Referenced by CommonOutputAction::act().

246 {
247  _common_params_ptr = params_ptr;
248 }
InputParameters * _common_params_ptr
Pointer to the common InputParameters (.

◆ setFileNumbers()

void OutputWarehouse::setFileNumbers ( std::map< std::string, unsigned int >  input,
unsigned int  offset = 0 
)

Calls the setFileNumber method for every FileOutput output object.

Definition at line 210 of file OutputWarehouse.C.

211 {
212  for (const auto & obj : _all_objects)
213  {
214  FileOutput * ptr = dynamic_cast<FileOutput *>(obj);
215  if (ptr != NULL)
216  {
217  std::map<std::string, unsigned int>::const_iterator it = input.find(ptr->name());
218  if (it != input.end())
219  {
220  int value = it->second + offset;
221  if (value < 0)
222  ptr->setFileNumber(0);
223  else
224  ptr->setFileNumber(it->second + offset);
225  }
226  }
227  }
228 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)
void setFileNumber(unsigned int num)
Sets the file number manually.
Definition: FileOutput.C:178
const std::string & name() const
Get the name of the object.
Definition: MooseObject.h:51
An outputter with filename support.
Definition: FileOutput.h:27

◆ setLoggingRequested()

void OutputWarehouse::setLoggingRequested ( )
inline

Sets a Boolean indicating that at least one object is requesting performance logging in this application.

Definition at line 190 of file OutputWarehouse.h.

Referenced by PerformanceData::PerformanceData().

190 { _logging_requested = true; }
bool _logging_requested
Indicates that performance logging has been requested by the console or some object (PerformanceData)...

◆ setOutputExecutionType()

void OutputWarehouse::setOutputExecutionType ( ExecFlagType  type)
private

Sets the execution flag type.

This is a private method used by FEProblemBase, it is not intended for any other purpose

Definition at line 300 of file OutputWarehouse.C.

301 {
303 }
ExecFlagType _output_exec_flag
The current output execution flag.
MatType type

◆ solveSetup()

void OutputWarehouse::solveSetup ( )
private

Calls the timestepSetup function for each of the output objects.

See also
FEProblemBase::solve()

Definition at line 57 of file OutputWarehouse.C.

Referenced by FEProblemBase::initPetscOutput().

58 {
59  for (const auto & obj : _all_objects)
60  obj->solveSetup();
61 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ subdomainSetup()

void OutputWarehouse::subdomainSetup ( )
private

Calls the subdomainSetup function for each of the output objects.

See also
FEProblemBase::setupSubdomain

Definition at line 78 of file OutputWarehouse.C.

Referenced by FEProblemBase::subdomainSetup().

79 {
80  for (const auto & obj : _all_objects)
81  obj->subdomainSetup();
82 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

◆ timestepSetup()

void OutputWarehouse::timestepSetup ( )
private

Calls the timestepSetup function for each of the output objects.

See also
FEProblemBase::timestepSetup()

Definition at line 50 of file OutputWarehouse.C.

Referenced by FEProblemBase::timestepSetup().

51 {
52  for (const auto & obj : _all_objects)
53  obj->timestepSetup();
54 }
std::vector< Output * > _all_objects
All instances of objects (raw pointers)

Friends And Related Function Documentation

◆ FEProblemBase

friend class FEProblemBase
friend

Definition at line 350 of file OutputWarehouse.h.

◆ MaterialOutputAction

friend class MaterialOutputAction
friend

Definition at line 353 of file OutputWarehouse.h.

◆ OutputInterface

friend class OutputInterface
friend

Definition at line 356 of file OutputWarehouse.h.

◆ PetscOutput

friend class PetscOutput
friend

Definition at line 359 of file OutputWarehouse.h.

Member Data Documentation

◆ _all_material_output_variables

std::set<AuxVariableName> OutputWarehouse::_all_material_output_variables
private

List of all variable created by auto material output.

Definition at line 328 of file OutputWarehouse.h.

◆ _all_objects

std::vector<Output *> OutputWarehouse::_all_objects
private

◆ _all_ptrs

std::vector<std::shared_ptr<Output> > OutputWarehouse::_all_ptrs
private

We are using std::shared_ptr to handle the cleanup of the pointers at the end of execution.

This is necessary since several warehouses might be sharing a single instance of a MooseObject.

Definition at line 226 of file OutputWarehouse.h.

Referenced by addOutput().

◆ _app

MooseApp& OutputWarehouse::_app
private

MooseApp.

Definition at line 298 of file OutputWarehouse.h.

Referenced by getOutputNames(), and mooseConsole().

◆ _buffer_action_console_outputs

bool OutputWarehouse::_buffer_action_console_outputs
private

True to buffer console outputs in actions.

Definition at line 304 of file OutputWarehouse.h.

Referenced by bufferConsoleOutputsBeforeConstruction(), and mooseConsole().

◆ _common_params_ptr

InputParameters* OutputWarehouse::_common_params_ptr
private

Pointer to the common InputParameters (.

See also
CommonOutputAction)

Definition at line 316 of file OutputWarehouse.h.

Referenced by getCommonParameters(), and setCommonParameters().

◆ _console_buffer

std::ostringstream OutputWarehouse::_console_buffer
private

The stream for holding messages passed to _console prior to Output object construction.

Definition at line 334 of file OutputWarehouse.h.

Referenced by consoleBuffer(), flushConsoleBuffer(), mooseConsole(), and ~OutputWarehouse().

◆ _file_base_set

std::set<OutFileBase> OutputWarehouse::_file_base_set
private

List of object names.

Definition at line 313 of file OutputWarehouse.h.

Referenced by addOutputFilename().

◆ _force_output

bool OutputWarehouse::_force_output
private

Flag indicating that next call to outputStep is forced.

Definition at line 343 of file OutputWarehouse.h.

Referenced by forceOutput(), and outputStep().

◆ _input_file_name

std::string OutputWarehouse::_input_file_name
private

Input file name for this output object.

Definition at line 322 of file OutputWarehouse.h.

◆ _interface_map

std::map<std::string, std::set<std::string> > OutputWarehouse::_interface_map
private

Storage for variables to hide as prescribed by the object via the OutputInterface.

Definition at line 337 of file OutputWarehouse.h.

Referenced by addInterfaceHideVariables(), and buildInterfaceHideVariables().

◆ _logging_requested

bool OutputWarehouse::_logging_requested
private

Indicates that performance logging has been requested by the console or some object (PerformanceData)

Definition at line 346 of file OutputWarehouse.h.

Referenced by getLoggingRequested(), and setLoggingRequested().

◆ _material_output_map

std::map<OutputName, std::set<AuxVariableName> > OutputWarehouse::_material_output_map
private

Map of output name and AuxVariable names to be output (used by auto Material output)

Definition at line 325 of file OutputWarehouse.h.

◆ _object_map

std::map<OutputName, Output *> OutputWarehouse::_object_map
private

A map of the output pointers.

Definition at line 307 of file OutputWarehouse.h.

Referenced by addOutput(), getOutput(), getOutputNames(), getOutputs(), and hasOutput().

◆ _object_names

std::set<OutputName> OutputWarehouse::_object_names
private

A set of output names.

Definition at line 310 of file OutputWarehouse.h.

Referenced by addOutput(), and getOutputNames().

◆ _output_exec_flag

ExecFlagType OutputWarehouse::_output_exec_flag
private

The current output execution flag.

Definition at line 340 of file OutputWarehouse.h.

Referenced by setOutputExecutionType().

◆ _reserved

std::set<std::string> OutputWarehouse::_reserved
private

List of reserved names.

Definition at line 331 of file OutputWarehouse.h.

Referenced by getReservedNames(), isReservedName(), and OutputWarehouse().

◆ _sync_times

std::set<Real> OutputWarehouse::_sync_times
private

Sync times for all objects.

Definition at line 319 of file OutputWarehouse.h.

Referenced by addOutput(), and getSyncTimes().


The documentation for this class was generated from the following files: