https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions | Static Protected Member Functions | Protected Attributes | Private Attributes | List of all members
ExodusOptimizationSteady Class Reference

Class for output data to the ExodusII format. More...

#include <ExodusOptimizationSteady.h>

Inheritance diagram for ExodusOptimizationSteady:
[legend]

Public Types

enum  OutputDimension {
  OutputDimension::DEFAULT, OutputDimension::ONE, OutputDimension::TWO, OutputDimension::THREE,
  OutputDimension::PROBLEM_DIMENSION
}
 
typedef DataFileName DataFileParameterType
 

Public Member Functions

 ExodusOptimizationSteady (const InputParameters &parameters)
 Class constructor. More...
 
virtual void output () override
 
virtual void initialSetup () override
 
virtual void meshChanged () override
 
virtual void outputSetup ()
 
virtual void sequence (bool state)
 
void setOutputDimension (unsigned int dim)
 
void clear ()
 
bool supportsMaterialPropertyOutput () const override
 
virtual void outputStep (const ExecFlagType &type) override
 
virtual bool hasOutput ()
 
bool hasOutput (const ExecFlagType &type)
 
bool hasNodalVariableOutput ()
 
const std::set< std::string > & getNodalVariableOutput ()
 
bool hasElementalVariableOutput ()
 
const std::set< std::string > & getElementalVariableOutput ()
 
bool hasScalarOutput ()
 
const std::set< std::string > & getScalarOutput ()
 
bool hasPostprocessorOutput ()
 
const std::set< std::string > & getPostprocessorOutput ()
 
bool hasVectorPostprocessorOutput ()
 
const std::set< std::string > & getVectorPostprocessorOutput ()
 
bool hasReporterOutput ()
 
const std::set< std::string > & getReporterOutput ()
 
const OutputOnWarehouseadvancedExecuteOn () const
 
void setFileBase (const std::string &file_base)
 
void setFileNumber (unsigned int num)
 
unsigned int getFileNumber ()
 
virtual Real time () override
 
virtual Real timeOld ()
 
virtual Real dt ()
 
virtual Real dtOld ()
 
virtual int timeStep ()
 
const unsigned intinterval () const
 
const MultiMooseEnumexecuteOn () const
 
bool isAdvanced ()
 
void allowOutput (bool state)
 
const std::set< Real > & getSyncTimes ()
 
virtual bool enabled () const
 
std::shared_ptr< MooseObjectgetSharedPtr ()
 
std::shared_ptr< const MooseObjectgetSharedPtr () const
 
MooseAppgetMooseApp () const
 
const std::string & type () const
 
virtual const std::string & name () const
 
std::string typeAndName () const
 
std::string errorPrefix (const std::string &error_type) const
 
void callMooseError (std::string msg, const bool with_prefix) const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
const InputParametersparameters () const
 
MooseObjectName uniqueName () const
 
const T & getParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const T * queryParam (const std::string &name) const
 
const T & getRenamedParam (const std::string &old_name, const std::string &new_name) const
 
getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &nm) const
 
void paramError (const std::string &param, Args... args) const
 
void paramWarning (const std::string &param, Args... args) const
 
void paramInfo (const std::string &param, Args... args) const
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void mooseError (Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseInfo (Args &&... args) const
 
std::string getDataFileName (const std::string &param) const
 
std::string getDataFileNameByName (const std::string &relative_path) const
 
std::string getDataFilePath (const std::string &relative_path) const
 
virtual void timestepSetup ()
 
virtual void jacobianSetup ()
 
virtual void residualSetup ()
 
virtual void subdomainSetup ()
 
virtual void customSetup (const ExecFlagType &)
 
const ExecFlagEnumgetExecuteOnEnum () const
 
const FunctiongetFunction (const std::string &name) const
 
const FunctiongetFunctionByName (const FunctionName &name) const
 
bool hasFunction (const std::string &param_name) const
 
bool hasFunctionByName (const FunctionName &name) const
 
bool isDefaultPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
bool hasPostprocessor (const std::string &param_name, const unsigned int index=0) const
 
bool hasPostprocessorByName (const PostprocessorName &name) const
 
std::size_t coupledPostprocessors (const std::string &param_name) const
 
const PostprocessorName & getPostprocessorName (const std::string &param_name, const unsigned int index=0) const
 
const VectorPostprocessorValuegetVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name, bool needs_broadcast) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
bool hasVectorPostprocessor (const std::string &param_name, const std::string &vector_name) const
 
bool hasVectorPostprocessor (const std::string &param_name) const
 
bool hasVectorPostprocessorByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
bool hasVectorPostprocessorByName (const VectorPostprocessorName &name) const
 
const VectorPostprocessorName & getVectorPostprocessorName (const std::string &param_name) const
 
PerfGraphperfGraph ()
 
const PostprocessorValuegetPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOld (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOld (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOlder (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOlder (const std::string &param_name, const unsigned int index=0) const
 
virtual const PostprocessorValuegetPostprocessorValueByName (const PostprocessorName &name) const
 
virtual const PostprocessorValuegetPostprocessorValueByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOldByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOldByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOlderByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOlderByName (const PostprocessorName &name) const
 
bool isVectorPostprocessorDistributed (const std::string &param_name) const
 
bool isVectorPostprocessorDistributed (const std::string &param_name) const
 
bool isVectorPostprocessorDistributedByName (const VectorPostprocessorName &name) const
 
bool isVectorPostprocessorDistributedByName (const VectorPostprocessorName &name) const
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 

Static Public Member Functions

static InputParameters validParams ()
 
static void setOutputDimensionInExodusWriter (libMesh::ExodusII_IO &exodus_io, const MooseMesh &mesh, OutputDimension output_dim=OutputDimension::DEFAULT)
 
static InputParameters enableOutputTypes (const std::string &names=std::string())
 
static ExecFlagEnum getDefaultExecFlagEnum ()
 
static void addDeprecatedInputParameters (InputParameters &params)
 

Public Attributes

const ConsoleStream _console
 

Protected Member Functions

void customizeFileOutput () override
 Customize file output with steady and adjoint iteration number. More...
 
virtual Real getOutputTime () override
 Get time for output (i.e. More...
 
virtual void outputNodalVariables () override
 
virtual void outputElementalVariables () override
 
virtual void outputPostprocessors () override
 
virtual void outputScalarVariables () override
 
virtual void outputInput () override
 
virtual void outputReporters () override
 
virtual std::string filename () override
 
virtual void updateSample ()
 
virtual void setFileBaseInternal (const std::string &file_base) override
 
virtual void init ()
 
virtual bool shouldOutput ()
 
virtual void outputVectorPostprocessors ()
 
virtual void outputSystemInformation ()
 
bool checkFilename ()
 
bool inNonlinearTimeWindow ()
 
bool inLinearTimeWindow ()
 
virtual bool onInterval ()
 
void setWallTimeIntervalFromCommandLineParam ()
 
T & declareRestartableData (const std::string &data_name, Args &&... args)
 
ManagedValue< T > declareManagedRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
const T & getRestartableData (const std::string &data_name) const
 
T & declareRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
T & declareRecoverableData (const std::string &data_name, Args &&... args)
 
T & declareRestartableDataWithObjectName (const std::string &data_name, const std::string &object_name, Args &&... args)
 
T & declareRestartableDataWithObjectNameWithContext (const std::string &data_name, const std::string &object_name, void *context, Args &&... args)
 
std::string restartableName (const std::string &data_name) const
 
virtual void addPostprocessorDependencyHelper (const PostprocessorName &) const
 
virtual void addVectorPostprocessorDependencyHelper (const VectorPostprocessorName &) const
 
const ReporterNamegetReporterName (const std::string &param_name) const
 
virtual void addReporterDependencyHelper (const ReporterName &)
 
PerfID registerTimedSection (const std::string &section_name, const unsigned int level) const
 
PerfID registerTimedSection (const std::string &section_name, const unsigned int level, const std::string &live_message, const bool print_dots=true) const
 
std::string timedSectionName (const std::string &section_name) const
 
const T & getReporterValue (const std::string &param_name, const std::size_t time_index=0)
 
const T & getReporterValue (const std::string &param_name, ReporterMode mode, const std::size_t time_index=0)
 
const T & getReporterValue (const std::string &param_name, const std::size_t time_index=0)
 
const T & getReporterValue (const std::string &param_name, ReporterMode mode, const std::size_t time_index=0)
 
const T & getReporterValueByName (const ReporterName &reporter_name, const std::size_t time_index=0)
 
const T & getReporterValueByName (const ReporterName &reporter_name, ReporterMode mode, const std::size_t time_index=0)
 
const T & getReporterValueByName (const ReporterName &reporter_name, const std::size_t time_index=0)
 
const T & getReporterValueByName (const ReporterName &reporter_name, ReporterMode mode, const std::size_t time_index=0)
 
bool hasReporterValue (const std::string &param_name) const
 
bool hasReporterValue (const std::string &param_name) const
 
bool hasReporterValue (const std::string &param_name) const
 
bool hasReporterValue (const std::string &param_name) const
 
bool hasReporterValueByName (const ReporterName &reporter_name) const
 
bool hasReporterValueByName (const ReporterName &reporter_name) const
 
bool hasReporterValueByName (const ReporterName &reporter_name) const
 
bool hasReporterValueByName (const ReporterName &reporter_name) const
 

Static Protected Member Functions

static PetscErrorCode petscNonlinearOutput (SNES, PetscInt its, PetscReal fnorm, void *void_ptr)
 
static PetscErrorCode petscLinearOutput (KSP, PetscInt its, PetscReal fnorm, void *void_ptr)
 

Protected Attributes

std::unique_ptr< libMesh::ExodusII_IO_exodus_io_ptr
 
std::vector< Real_global_values
 
std::vector< std::string > _global_names
 
bool _exodus_initialized
 
bool & _exodus_mesh_changed
 
bool _sequence
 
unsigned int_exodus_num
 
const unsigned int _refinements
 
const bool _using_external_sampling_file
 
const bool _change_position
 
bool _use_sampled_output
 
bool _elemental_as_nodal
 
bool _scalar_as_nodal
 
const ReporterData_reporter_data
 
unsigned int_file_num
 
unsigned int _padding
 
std::vector< std::string > _output_if_base_contains
 
std::string _file_base
 
Real _norm
 
PetscInt _nonlinear_iter
 
PetscInt _linear_iter
 
bool _on_linear_residual
 
bool _on_nonlinear_residual
 
FEProblemBase_problem_ptr
 
bool _transient
 
bool _use_displaced
 
libMesh::EquationSystems_es_ptr
 
MooseMesh_mesh_ptr
 
ExecFlagEnum _execute_on
 
ExecFlagType _current_execute_flag
 
Real_time
 
Real_time_old
 
int_t_step
 
Real_dt
 
Real_dt_old
 
unsigned int _num
 
const bool _time_step_interval_set_by_addparam
 
unsigned int _time_step_interval
 
const Real _min_simulation_time_interval
 
const Real _simulation_time_interval
 
Real _wall_time_interval
 
std::set< Real_sync_times
 
const Times *const _sync_times_object
 
Real _start_time
 
Real _end_time
 
int _start_step
 
int _end_step
 
Real _t_tol
 
bool _sync_only
 
bool _allow_output
 
bool _is_advanced
 
OutputOnWarehouse _advanced_execute_on
 
Real_last_output_simulation_time
 
std::chrono::time_point< std::chrono::steady_clock > _last_output_wall_time
 
Real _wall_time_since_last_output
 
const bool & _enabled
 
MooseApp_app
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
MooseApp_restartable_app
 
const std::string _restartable_system_name
 
const THREAD_ID _restartable_tid
 
const bool _restartable_read_only
 
FEProblemBase_mci_feproblem
 
const ExecFlagEnum_execute_enum
 
MooseApp_pg_moose_app
 
const std::string _prefix
 
PetscOutput_petsc_output
 
const Parallel::Communicator & _communicator
 

Private Attributes

const Steady *const _steady_exec
 For steady (and steady and adjoint) executioner. More...
 

Detailed Description

Class for output data to the ExodusII format.

Definition at line 19 of file ExodusOptimizationSteady.h.

Constructor & Destructor Documentation

◆ ExodusOptimizationSteady()

ExodusOptimizationSteady::ExodusOptimizationSteady ( const InputParameters parameters)

Class constructor.

Definition at line 25 of file ExodusOptimizationSteady.C.

26  : Exodus(parameters), _steady_exec(dynamic_cast<Steady *>(_app.getExecutioner()))
27 {
28  if (!_steady_exec)
29  mooseError(
30  "ExodusOptimizationSteady output can only be used with the SteadyAndAdjoint or Steady"
31  "executioners to output a per-optimization iteration solution.");
32 }
const Steady *const _steady_exec
For steady (and steady and adjoint) executioner.
Exodus(const InputParameters &parameters)
Executioner * getExecutioner() const
MooseApp & _app
void mooseError(Args &&... args) const
const InputParameters & parameters() const

Member Function Documentation

◆ customizeFileOutput()

void ExodusOptimizationSteady::customizeFileOutput ( )
overrideprotectedvirtual

Customize file output with steady and adjoint iteration number.

Reimplemented from Exodus.

Definition at line 35 of file ExodusOptimizationSteady.C.

36 {
38  _file_num++;
39 
41 
42  if (_exodus_num == 1)
43  _exodus_io_ptr->append(false);
44  else
45  _exodus_io_ptr->append(true);
46 }
std::unique_ptr< libMesh::ExodusII_IO > _exodus_io_ptr
const Steady *const _steady_exec
For steady (and steady and adjoint) executioner.
bool & _exodus_mesh_changed
unsigned int & _exodus_num
bool _sequence
unsigned int & _file_num
virtual unsigned int getIterationNumberOutput() const

◆ getOutputTime()

Real ExodusOptimizationSteady::getOutputTime ( )
overrideprotectedvirtual

Get time for output (i.e.

iteration number for optimization solves).

Reimplemented from Exodus.

Definition at line 49 of file ExodusOptimizationSteady.C.

50 {
52 }
const Steady *const _steady_exec
For steady (and steady and adjoint) executioner.
virtual unsigned int getIterationNumberOutput() const

◆ validParams()

InputParameters ExodusOptimizationSteady::validParams ( )
static

Definition at line 15 of file ExodusOptimizationSteady.C.

16 {
17  // Get the base class parameters
19  params.set<ExecFlagEnum>("execute_on") = EXEC_TIMESTEP_END;
20 
21  // Return the InputParameters
22  return params;
23 }
T & set(const std::string &name, bool quiet_mode=false)
static InputParameters validParams()

Member Data Documentation

◆ _steady_exec

const Steady* const ExodusOptimizationSteady::_steady_exec
private

For steady (and steady and adjoint) executioner.

Definition at line 42 of file ExodusOptimizationSteady.h.

Referenced by customizeFileOutput(), ExodusOptimizationSteady(), and getOutputTime().


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