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

Transfers residuals for given variables and vector tags from a sub-subapplication to a PODReducedBasisTrainer object. More...

#include <PODResidualTransfer.h>

Inheritance diagram for PODResidualTransfer:
[legend]

Public Types

enum  DIRECTION
 
typedef DataFileName DataFileParameterType
 

Public Member Functions

 PODResidualTransfer (const InputParameters &parameters)
 
virtual void initialSetup () override
 
void setGlobalMultiAppIndex (dof_id_type index)
 Method for setting the app index when running in batch mode. More...
 
void setGlobalRowIndex (dof_id_type row)
 Method for keeping track of the global row index when running in batch mode. More...
 
void setCurrentRow (const std::vector< Real > &row)
 Method for keeping track of the row data when running in batch mode. More...
 
void variableIntegrityCheck (const AuxVariableName &var_name, bool is_from_multiapp) const
 
const std::shared_ptr< MultiAppgetMultiApp () const
 
const std::shared_ptr< MultiAppgetFromMultiApp () const
 
const std::shared_ptr< MultiAppgetToMultiApp () const
 
std::string getFromName () const
 
std::string getToName () const
 
bool hasFromMultiApp () const
 
bool hasToMultiApp () const
 
virtual void getAppInfo ()
 
const MultiMooseEnumdirections ()
 
void setCurrentDirection (const int direction)
 
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
 
PerfGraphperfGraph ()
 
MooseEnum direction ()
 
MooseEnum direction ()
 
MooseEnum currentDirection ()
 
MooseEnum currentDirection ()
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 
virtual void initializeFromMultiapp () override
 Methods used when running in batch mode (see SamplerFullSolveMultiApp) More...
 
virtual void executeFromMultiapp () override
 
virtual void finalizeFromMultiapp () override
 
virtual void initializeToMultiapp () override
 Methods for transferring data to sub-applications to the master application. More...
 
virtual void executeToMultiapp () override
 
virtual void finalizeToMultiapp () override
 

Static Public Member Functions

static InputParameters validParams ()
 
static void addSkipCoordCollapsingParam (InputParameters &params)
 
static libMesh::Systemfind_sys (libMesh::EquationSystems &es, const std::string &var_name)
 
static std::string possibleDirections ()
 

Public Attributes

 TO_MULTIAPP
 
 FROM_MULTIAPP
 
 BETWEEN_MULTIAPP
 
const ConsoleStream _console
 

Static Public Attributes

static const libMesh::Number OutOfMeshValue
 

Protected Member Functions

virtual void execute () override
 Transfer callback that will transfer residuals with given tags from the subapplication. More...
 
std::vector< unsigned intgetFromsPerProc ()
 
libMesh::NumericVector< Real > & getTransferVector (unsigned int i_local, std::string var_name)
 
unsigned int getGlobalSourceAppIndex (unsigned int i_from) const
 
unsigned int getGlobalTargetAppIndex (unsigned int i_to) const
 
unsigned int getLocalSourceAppIndex (unsigned int i_from) const
 
virtual void checkSiblingsTransferSupported () const
 
void errorIfObjectExecutesOnTransferInSourceApp (const std::string &object_name) const
 
Point getPointInTargetAppFrame (const Point &p, unsigned int local_i_to, const std::string &phase) const
 
void checkMultiAppExecuteOn ()
 
void checkVariable (const FEProblemBase &fe_problem, const VariableName &var_name, const std::string &param_name="") const
 
void extendBoundingBoxes (const Real factor, std::vector< libMesh::BoundingBox > &bboxes) const
 
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
 
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
 
std::vector< libMesh::BoundingBoxgetFromBoundingBoxes ()
 
std::vector< libMesh::BoundingBoxgetFromBoundingBoxes (BoundaryID boundary_id)
 
std::vector< libMesh::BoundingBoxgetFromBoundingBoxes ()
 
std::vector< libMesh::BoundingBoxgetFromBoundingBoxes (BoundaryID boundary_id)
 

Static Protected Member Functions

static void addBBoxFactorParam (InputParameters &params)
 
static void transformBoundingBox (libMesh::BoundingBox &box, const MultiAppCoordTransform &transform)
 

Protected Attributes

std::shared_ptr< PODFullSolveMultiApp_pod_multi_app
 The input multiapp casted into a PODFullSolveMultiapp to get access to the specific pod attributes. More...
 
PODReducedBasisTrainer_trainer
 The trainer object to save the solution vector into or to fetch the artificial solution vectors from. More...
 
dof_id_type _app_index = 0
 Index for the sub-app that the batch-mode multiapp is working on. More...
 
dof_id_type _global_index = 0
 Index for tracking the row index when using batch mode operation. More...
 
std::vector< Real_row_data
 The current row of data (comes from multiapp) More...
 
Sampler_sampler_ptr
 Pointer to the Sampler object used by the SamplerTransientMultiApp or SamplerFullSolveMultiApp. More...
 
std::shared_ptr< MultiApp_multi_app
 
std::vector< FEProblemBase *> _to_problems
 
std::vector< FEProblemBase *> _from_problems
 
std::vector< libMesh::EquationSystems *> _to_es
 
std::vector< libMesh::EquationSystems *> _from_es
 
std::vector< MooseMesh *> _to_meshes
 
std::vector< MooseMesh *> _from_meshes
 
std::vector< Point > _to_positions
 
std::vector< Point > _from_positions
 
std::vector< std::unique_ptr< MultiAppCoordTransform > > _to_transforms
 
std::vector< std::unique_ptr< MultiAppCoordTransform > > _from_transforms
 
const bool _skip_coordinate_collapsing
 
bool _displaced_source_mesh
 
bool _displaced_target_mesh
 
Real _bbox_factor
 
std::vector< unsigned int_to_local2global_map
 
std::vector< unsigned int_from_local2global_map
 
SubProblem_subproblem
 
FEProblemBase_fe_problem
 
SystemBase_sys
 
THREAD_ID _tid
 
MultiMooseEnum _directions
 
const bool & _enabled
 
MooseApp_app
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
const ExecFlagEnum_execute_enum
 
const ExecFlagType_current_execute_flag
 
MooseApp_restartable_app
 
const std::string _restartable_system_name
 
const THREAD_ID _restartable_tid
 
const bool _restartable_read_only
 
MooseApp_pg_moose_app
 
const std::string _prefix
 
MooseEnum _direction
 
MooseEnum _current_direction
 
const Parallel::Communicator & _communicator
 

Private Member Functions

void transferResidual (dof_id_type base_i, dof_id_type multi_app_i)
 Adds the variable-residuals to the trainer. More...
 

Detailed Description

Transfers residuals for given variables and vector tags from a sub-subapplication to a PODReducedBasisTrainer object.

Definition at line 19 of file PODResidualTransfer.h.

Constructor & Destructor Documentation

◆ PODResidualTransfer()

PODResidualTransfer::PODResidualTransfer ( const InputParameters parameters)

Definition at line 27 of file PODResidualTransfer.C.

29 {
30  if (hasToMultiApp())
31  paramError("to_multi_app", "To and between multiapp directions are not implemented");
32 }
PODSamplerSolutionTransfer(const InputParameters &parameters)
void paramError(const std::string &param, Args... args) const
bool hasToMultiApp() const
const InputParameters & parameters() const

Member Function Documentation

◆ execute()

void PODResidualTransfer::execute ( )
overrideprotectedvirtual

Transfer callback that will transfer residuals with given tags from the subapplication.

Reimplemented from PODSamplerSolutionTransfer.

Definition at line 35 of file PODResidualTransfer.C.

36 {
37  const unsigned int total_base_num = _trainer.getSumBaseSize();
38 
39  // Looping over sub-apps
40  for (unsigned int base_i = 0; base_i < total_base_num; ++base_i)
41  if (getFromMultiApp()->hasLocalApp(base_i))
42  transferResidual(base_i, base_i);
43 }
const std::shared_ptr< MultiApp > getFromMultiApp() const
void transferResidual(dof_id_type base_i, dof_id_type multi_app_i)
Adds the variable-residuals to the trainer.
PODReducedBasisTrainer & _trainer
The trainer object to save the solution vector into or to fetch the artificial solution vectors from...
unsigned int getSumBaseSize() const
Getting the overall base size, which is the sum of the individual bases.

◆ executeFromMultiapp()

void PODResidualTransfer::executeFromMultiapp ( )
overridevirtual

Reimplemented from PODSamplerSolutionTransfer.

Definition at line 46 of file PODResidualTransfer.C.

47 {
49 }
dof_id_type _global_index
Index for tracking the row index when using batch mode operation.
void transferResidual(dof_id_type base_i, dof_id_type multi_app_i)
Adds the variable-residuals to the trainer.
processor_id_type processor_id() const

◆ executeToMultiapp()

void PODSamplerSolutionTransfer::executeToMultiapp ( )
overridevirtualinherited

Reimplemented from StochasticToolsTransfer.

Definition at line 193 of file PODSamplerSolutionTransfer.C.

194 {
195  if (!_pod_multi_app->snapshotGeneration())
196  {
197  const std::vector<std::string> & var_names = _trainer.getVarNames();
199 
200  // Getting the reference to the solution vector in the subapp.
201  FEProblemBase & app_problem = getToMultiApp()->appProblemBase(processor_id());
202  NonlinearSystemBase & nl = app_problem.getNonlinearSystemBase(/*nl_sys_num=*/0);
203  NumericVector<Number> & solution = nl.solution();
204 
205  // Zeroing the solution to make sure that only the required part
206  // is non-zero after copy.
207  solution.zero();
208 
209  // Getting the degrees of freedom for the given variable.
210  nl.setVariableGlobalDoFs(var_names[var_i]);
211  const std::vector<dof_id_type> & var_dofs = nl.getVariableGlobalDoFs();
212 
213  // Fetching the basis vector and plugging it into the solution.
214  const DenseVector<Real> & base_vector = _trainer.getBasisVector(_global_index);
215  solution.insert(base_vector, var_dofs);
216  solution.close();
217 
218  // Make sure that the sub-application uses this vector to evaluate the
219  // residual.
220  nl.setSolution(solution);
221  }
222 }
dof_id_type _global_index
Index for tracking the row index when using batch mode operation.
virtual void insert(const Number *v, const std::vector< numeric_index_type > &dof_indices)
std::shared_ptr< PODFullSolveMultiApp > _pod_multi_app
The input multiapp casted into a PODFullSolveMultiapp to get access to the specific pod attributes...
NumericVector< Number > & solution()
void setSolution(const NumericVector< Number > &soln)
const std::shared_ptr< MultiApp > getToMultiApp() const
virtual void zero()=0
const std::vector< dof_id_type > & getVariableGlobalDoFs()
NonlinearSystemBase & getNonlinearSystemBase(const unsigned int sys_num)
unsigned int getVariableIndex(unsigned int glob_i) const
Getting appropriate variable index for a global base index.
virtual void close()=0
PODReducedBasisTrainer & _trainer
The trainer object to save the solution vector into or to fetch the artificial solution vectors from...
void setVariableGlobalDoFs(const std::string &var_name)
processor_id_type processor_id() const
const std::vector< std::string > & getVarNames() const
const DenseVector< Real > & getBasisVector(unsigned int var_i, unsigned int base_i) const
Getting a basis vector for a given variable.
uint8_t dof_id_type

◆ finalizeFromMultiapp()

virtual void PODResidualTransfer::finalizeFromMultiapp ( )
inlineoverridevirtual

Reimplemented from PODSamplerSolutionTransfer.

Definition at line 31 of file PODResidualTransfer.h.

31 {};

◆ finalizeToMultiapp()

void PODSamplerSolutionTransfer::finalizeToMultiapp ( )
overridevirtualinherited

Reimplemented from StochasticToolsTransfer.

Definition at line 225 of file PODSamplerSolutionTransfer.C.

226 {
227 }

◆ initializeFromMultiapp()

virtual void PODResidualTransfer::initializeFromMultiapp ( )
inlineoverridevirtual

Methods used when running in batch mode (see SamplerFullSolveMultiApp)

Reimplemented from PODSamplerSolutionTransfer.

Definition at line 29 of file PODResidualTransfer.h.

29 {};

◆ initializeToMultiapp()

void PODSamplerSolutionTransfer::initializeToMultiapp ( )
overridevirtualinherited

Methods for transferring data to sub-applications to the master application.

Reimplemented from StochasticToolsTransfer.

Definition at line 188 of file PODSamplerSolutionTransfer.C.

189 {
190 }

◆ initialSetup()

void PODSamplerSolutionTransfer::initialSetup ( )
overridevirtualinherited

Reimplemented from MultiAppTransfer.

Definition at line 42 of file PODSamplerSolutionTransfer.C.

43 {
44  const auto multi_app = hasFromMultiApp() ? getFromMultiApp() : getToMultiApp();
45 
46  // Checking if the subapplication has the requested variables
47  const std::vector<std::string> & var_names = _trainer.getVarNames();
48  const dof_id_type n = multi_app->numGlobalApps();
49  for (MooseIndex(n) i = 0; i < n; i++)
50  {
51  if (multi_app->hasLocalApp(i))
52  for (auto var_name : var_names)
53  if (!multi_app->appProblemBase(i).hasVariable(var_name))
54  mooseError("Variable '" + var_name + "' not found on sub-application ", i, "!");
55  }
56 }
const std::shared_ptr< MultiApp > getFromMultiApp() const
const std::shared_ptr< MultiApp > getToMultiApp() const
bool hasFromMultiApp() const
void mooseError(Args &&... args) const
PODReducedBasisTrainer & _trainer
The trainer object to save the solution vector into or to fetch the artificial solution vectors from...
const std::vector< std::string > & getVarNames() const
uint8_t dof_id_type

◆ setCurrentRow()

void StochasticToolsTransfer::setCurrentRow ( const std::vector< Real > &  row)
inlineinherited

Method for keeping track of the row data when running in batch mode.

See StochasticTools<FullSolve/Transient>MultiApp

Definition at line 65 of file StochasticToolsTransfer.h.

65 { _row_data = row; }
std::vector< Real > _row_data
The current row of data (comes from multiapp)

◆ setGlobalMultiAppIndex()

void StochasticToolsTransfer::setGlobalMultiAppIndex ( dof_id_type  index)
inlineinherited

Method for setting the app index when running in batch mode.

See StochasticTools<FullSolve/Transient>MultiApp

Definition at line 51 of file StochasticToolsTransfer.h.

51 { _app_index = index; }
dof_id_type _app_index
Index for the sub-app that the batch-mode multiapp is working on.

◆ setGlobalRowIndex()

void StochasticToolsTransfer::setGlobalRowIndex ( dof_id_type  row)
inlineinherited

Method for keeping track of the global row index when running in batch mode.

See StochasticTools<FullSolve/Transient>MultiApp

Definition at line 58 of file StochasticToolsTransfer.h.

58 { _global_index = row; }
dof_id_type _global_index
Index for tracking the row index when using batch mode operation.

◆ transferResidual()

void PODResidualTransfer::transferResidual ( dof_id_type  base_i,
dof_id_type  multi_app_i 
)
private

Adds the variable-residuals to the trainer.

Definition at line 52 of file PODResidualTransfer.C.

Referenced by execute(), and executeFromMultiapp().

53 {
54  const std::vector<std::string> & var_names = _trainer.getVarNames();
55  const std::vector<std::string> & tag_names = _trainer.getTagNames();
56  const std::vector<std::string> & tag_types = _trainer.getTagTypes();
57 
58  // Getting reference to the non-linear system
59  FEProblemBase & app_problem = getFromMultiApp()->appProblemBase(multi_app_i);
60  NonlinearSystemBase & nl = app_problem.getNonlinearSystemBase(/*nl_sys_num=*/0);
61 
62  // Looping over the residual tags and extracting the corresponding vector.
63  for (unsigned int tag_i = 0; tag_i < tag_names.size(); ++tag_i)
64  {
65  // If the tag corresponds to an independent operator, it is enough to
66  // transfer it once.
67  if (base_i > 0 && (tag_types[tag_i] == "src" || tag_types[tag_i] == "src_dir"))
68  continue;
69 
70  TagID tag_id = app_problem.getVectorTagID(tag_names[tag_i]);
71 
72  // Fetching the corresponding residual vector and extracting the parts for
73  // each variable.
74  NumericVector<Number> & full_residual = nl.getVector(tag_id);
75  std::vector<DenseVector<Real>> split_residual(var_names.size());
76 
77  for (unsigned int var_i = 0; var_i < var_names.size(); ++var_i)
78  {
79  // Getting the DoF indices of the variable.
80  nl.setVariableGlobalDoFs(var_names[var_i]);
81  const std::vector<dof_id_type> & var_dofs = nl.getVariableGlobalDoFs();
82 
83  // Extracting the corresponding part of the residual vector.
84  full_residual.localize(split_residual[var_i].get_values(), var_dofs);
85  }
86 
87  // Inserting the contribution of this residual into the reduced operator in
88  // the trainer.
89  _trainer.addToReducedOperator(base_i, tag_i, split_residual);
90  }
91 }
virtual TagID getVectorTagID(const TagName &tag_name) const
void addToReducedOperator(unsigned int base_i, unsigned int tag_i, std::vector< DenseVector< Real >> &residual)
Adding the contribution of a residual to the reduced operators.
const std::shared_ptr< MultiApp > getFromMultiApp() const
unsigned int TagID
const std::vector< std::string > & getTagNames() const
const std::vector< dof_id_type > & getVariableGlobalDoFs()
NonlinearSystemBase & getNonlinearSystemBase(const unsigned int sys_num)
const std::vector< std::string > & getTagTypes() const
PODReducedBasisTrainer & _trainer
The trainer object to save the solution vector into or to fetch the artificial solution vectors from...
void setVariableGlobalDoFs(const std::string &var_name)
const std::vector< std::string > & getVarNames() const
virtual NumericVector< Number > & getVector(const std::string &name)
virtual void localize(std::vector< Number > &v_local) const =0

◆ validParams()

InputParameters PODResidualTransfer::validParams ( )
static

Definition at line 17 of file PODResidualTransfer.C.

18 {
20  params.addClassDescription("Transfers residual vectors from the sub-application to a "
21  "a container in the Trainer object.");
22  params.suppressParameter<MultiMooseEnum>("direction");
23  params.suppressParameter<MultiAppName>("multi_app");
24  return params;
25 }
void suppressParameter(const std::string &name)
static InputParameters validParams()
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _app_index

dof_id_type StochasticToolsTransfer::_app_index = 0
protectedinherited

◆ _global_index

dof_id_type StochasticToolsTransfer::_global_index = 0
protectedinherited

◆ _pod_multi_app

std::shared_ptr<PODFullSolveMultiApp> PODSamplerSolutionTransfer::_pod_multi_app
protectedinherited

The input multiapp casted into a PODFullSolveMultiapp to get access to the specific pod attributes.

Used in batch mode only and checking if the correct MultiApp type has been provided.

Definition at line 50 of file PODSamplerSolutionTransfer.h.

Referenced by PODSamplerSolutionTransfer::executeFromMultiapp(), PODSamplerSolutionTransfer::executeToMultiapp(), and PODSamplerSolutionTransfer::PODSamplerSolutionTransfer().

◆ _row_data

std::vector<Real> StochasticToolsTransfer::_row_data
protectedinherited

The current row of data (comes from multiapp)

Definition at line 73 of file StochasticToolsTransfer.h.

Referenced by SamplerParameterTransfer::executeToMultiapp(), and StochasticToolsTransfer::setCurrentRow().

◆ _sampler_ptr

Sampler* StochasticToolsTransfer::_sampler_ptr
protectedinherited

◆ _trainer

PODReducedBasisTrainer& PODSamplerSolutionTransfer::_trainer
protectedinherited

The trainer object to save the solution vector into or to fetch the artificial solution vectors from.

Definition at line 56 of file PODSamplerSolutionTransfer.h.

Referenced by PODSamplerSolutionTransfer::execute(), execute(), PODSamplerSolutionTransfer::executeFromMultiapp(), PODSamplerSolutionTransfer::executeToMultiapp(), PODSamplerSolutionTransfer::initialSetup(), and transferResidual().


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