Tempus Version of the Day
Time Integration
Loading...
Searching...
No Matches
Tempus_WrapperModelEvaluatorBasic_decl.hpp
Go to the documentation of this file.
1//@HEADER
2// *****************************************************************************
3// Tempus: Time Integration and Sensitivity Analysis Package
4//
5// Copyright 2017 NTESS and the Tempus contributors.
6// SPDX-License-Identifier: BSD-3-Clause
7// *****************************************************************************
8//@HEADER
9
10#ifndef Tempus_WrapperModelEvaluatorBasic_decl_hpp
11#define Tempus_WrapperModelEvaluatorBasic_decl_hpp
12
13#include <functional>
14#include "Tempus_config.hpp"
16
17namespace Tempus {
18
26template <typename Scalar>
28 : public Tempus::WrapperModelEvaluator<Scalar> {
29 public:
32 const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar>> &appModel)
34 {
35 using Teuchos::rcp_const_cast;
36
37 p_ = Teuchos::rcp(new ImplicitODEParameters<Scalar>());
38 index_ = -1;
39
40 typedef Thyra::ModelEvaluatorBase MEB;
41 MEB::InArgs<Scalar> inArgs = appModel_->getNominalValues();
42 x_ = rcp_const_cast<Thyra::VectorBase<Scalar>>(inArgs.get_x());
43
44 if (inArgs.supports(MEB::IN_ARG_x_dot)) {
45 xDot_ = rcp_const_cast<Thyra::VectorBase<Scalar>>(inArgs.get_x_dot());
46 }
47 else {
48 xDot_ = Teuchos::null;
49 }
50 }
51
53 virtual void setAppModel(
54 const Teuchos::RCP<const Thyra::ModelEvaluator<Scalar>> &me)
55 {
56 appModel_ = me;
57 }
58
60 virtual Teuchos::RCP<const Thyra::ModelEvaluator<Scalar>> getAppModel() const
61 {
62 return appModel_;
63 }
64
67 const Teuchos::RCP<Thyra::VectorBase<Scalar>> &x,
68 const Teuchos::RCP<Thyra::VectorBase<Scalar>> &xDot, const Scalar time,
69 const Teuchos::RCP<ImplicitODEParameters<Scalar>> &p,
70 const Teuchos::RCP<Thyra::VectorBase<Scalar>> &y = Teuchos::null,
71 const int index = -1 /* index and y are for IMEX_RK_Partition */)
72 {
73 x_ = x;
74 xDot_ = xDot;
75 time_ = time;
76 p_ = p;
77 y_ = y;
78 index_ = index;
79
80 timeDer_ = p->timeDer_;
81 evaluationType_ = p->evaluationType_;
82 }
83
85
86 Teuchos::RCP<Thyra::LinearOpBase<Scalar>> create_W_op() const
87 {
88 return appModel_->create_W_op();
89 }
90
91 Teuchos::RCP<Thyra::PreconditionerBase<Scalar>> create_W_prec() const
92 {
93 return appModel_->create_W_prec();
94 }
95
96 Teuchos::RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar>>
98 {
99 return appModel_->get_W_factory();
100 }
101
102 Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar>> get_f_space() const
103 {
104 return appModel_->get_f_space();
105 }
106
107 Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar>> get_p_space(int p) const
108 {
109 return appModel_->get_p_space(p);
110 }
111
112 Teuchos::RCP<const Teuchos::Array<std::string>> get_p_names(int p) const
113 {
114 return appModel_->get_p_names(p);
115 }
116
117 Teuchos::ArrayView<const std::string> get_g_names(int g) const
118 {
119 return appModel_->get_g_names(g);
120 }
121
122 Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar>> get_x_space() const
123 {
124 return appModel_->get_x_space();
125 }
126
127 Teuchos::RCP<const Thyra::VectorSpaceBase<Scalar>> get_g_space(int i) const
128 {
129 return appModel_->get_g_space(i);
130 }
131
132 Thyra::ModelEvaluatorBase::InArgs<Scalar> getNominalValues() const
133 {
134 return appModel_->getNominalValues();
135 }
136
137 Teuchos::RCP<Thyra::LinearOpBase<Scalar>> create_DfDp_op(int l) const
138 {
139 return appModel_->create_DfDp_op(l);
140 }
141
142 Teuchos::RCP<Thyra::LinearOpBase<Scalar>> create_DgDx_op(int j) const
143 {
144 return appModel_->create_DgDx_op(j);
145 }
146
147 Teuchos::RCP<Thyra::LinearOpBase<Scalar>> create_DgDp_op(int j, int l) const
148 {
149 return appModel_->create_DgDp_op(j, l);
150 }
151
152 Thyra::ModelEvaluatorBase::InArgs<Scalar> createInArgs() const;
153 Thyra::ModelEvaluatorBase::OutArgs<Scalar> createOutArgsImpl() const;
154
155 void evalModelImpl(
156 const Thyra::ModelEvaluatorBase::InArgs<Scalar> &inArgs,
157 const Thyra::ModelEvaluatorBase::OutArgs<Scalar> &outArgs) const;
159
160 private:
163
164 private:
165 Teuchos::RCP<const Thyra::ModelEvaluator<Scalar>> appModel_;
166
167 Teuchos::RCP<Thyra::VectorBase<Scalar>> x_;
168 Teuchos::RCP<Thyra::VectorBase<Scalar>> xDot_;
169 Scalar time_;
170 Teuchos::RCP<ImplicitODEParameters<Scalar>> p_;
171 Teuchos::RCP<Thyra::VectorBase<Scalar>> y_;
173
174 Teuchos::RCP<TimeDerivative<Scalar>> timeDer_;
176};
177
178} // namespace Tempus
179
180#endif // Tempus_WrapperModelEvaluatorBasic_decl_hpp
A ModelEvaluator for residual evaluations given a state. This ModelEvaluator takes a state,...
Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_DfDp_op(int l) const
Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_DgDx_op(int j) const
Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_W_op() const
Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_g_space(int i) const
Get the g space.
Teuchos::RCP< Thyra::PreconditionerBase< Scalar > > create_W_prec() const
WrapperModelEvaluatorBasic(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &appModel)
Constructor.
Teuchos::RCP< TimeDerivative< Scalar > > timeDer_
void evalModelImpl(const Thyra::ModelEvaluatorBase::InArgs< Scalar > &inArgs, const Thyra::ModelEvaluatorBase::OutArgs< Scalar > &outArgs) const
Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
Teuchos::RCP< Thyra::VectorBase< Scalar > > xDot_
virtual void setAppModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &me)
Set the underlying application ModelEvaluator.
Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
Teuchos::RCP< Thyra::VectorBase< Scalar > > y_
Teuchos::RCP< const Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const
Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
Teuchos::RCP< Thyra::VectorBase< Scalar > > x_
Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Get the x-solution space.
Teuchos::ArrayView< const std::string > get_g_names(int g) const
WrapperModelEvaluatorBasic()
Default constructor - not allowed.
Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_f_space() const
Teuchos::RCP< ImplicitODEParameters< Scalar > > p_
Teuchos::RCP< const Thyra::VectorSpaceBase< Scalar > > get_p_space(int p) const
Get the p space.
void setForSolve(const Teuchos::RCP< Thyra::VectorBase< Scalar > > &x, const Teuchos::RCP< Thyra::VectorBase< Scalar > > &xDot, const Scalar time, const Teuchos::RCP< ImplicitODEParameters< Scalar > > &p, const Teuchos::RCP< Thyra::VectorBase< Scalar > > &y=Teuchos::null, const int index=-1)
Set parameters for application implicit ModelEvaluator solve.
Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > appModel_
Teuchos::RCP< Thyra::LinearOpBase< Scalar > > create_DgDp_op(int j, int l) const
Teuchos::RCP< const Teuchos::Array< std::string > > get_p_names(int p) const
virtual Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > getAppModel() const
Get the underlying application model 'f'.
A ModelEvaluator which wraps the application ModelEvaluator.
EVALUATION_TYPE
EVALUATION_TYPE indicates the evaluation to apply to the implicit ODE.
@ SOLVE_FOR_X
Solve for x and determine xDot from x.