44 includeXDot_ = includeXDot;
45 isInitialized_ =
false;
47 xDotIC_ = Scalar(lambda);
54 acceptModelParams_ =
false;
57 x_space_ = Thyra::defaultSpmdVectorSpace<Scalar>(dim_);
58 f_space_ = Thyra::defaultSpmdVectorSpace<Scalar>(dim_);
61 typedef Thyra::ModelEvaluatorBase MEB;
64 MEB::InArgsSetup<Scalar> inArgs;
65 inArgs.setModelEvalDescription(this->description());
66 inArgs.setSupports(MEB::IN_ARG_t);
67 inArgs.setSupports(MEB::IN_ARG_x);
68 inArgs.setSupports(MEB::IN_ARG_x_dot);
70 inArgs.setSupports(MEB::IN_ARG_beta);
71 inArgs.setSupports(MEB::IN_ARG_alpha);
72 if (acceptModelParams_) inArgs.set_Np(Np_);
79 MEB::OutArgsSetup<Scalar> outArgs;
80 outArgs.setModelEvalDescription(this->description());
81 outArgs.setSupports(MEB::OUT_ARG_f);
83 outArgs.setSupports(MEB::OUT_ARG_W_op);
84 if (acceptModelParams_) {
85 outArgs.set_Np_Ng(Np_, Ng_);
86 outArgs.setSupports(MEB::OUT_ARG_DfDp, 0, MEB::DERIV_MV_JACOBIAN_FORM);
87 outArgs.setSupports(MEB::OUT_ARG_DgDp, 0, 0, MEB::DERIV_MV_JACOBIAN_FORM);
88 outArgs.setSupports(MEB::OUT_ARG_DgDx, 0, MEB::DERIV_MV_GRADIENT_FORM);
94 nominalValues_ = inArgs_;
96 nominalValues_.set_t(Scalar(0.0));
97 const RCP<Thyra::VectorBase<Scalar> > x_ic = createMember(x_space_);
99 Thyra::DetachedVectorView<Scalar> x_ic_view(*x_ic);
102 nominalValues_.set_x(x_ic);
106 const RCP<Thyra::VectorBase<Scalar> > x_dot_ic = createMember(x_space_);
108 Thyra::DetachedVectorView<Scalar> x_dot_ic_view(*x_dot_ic);
109 x_dot_ic_view[0] = xDotIC_;
111 nominalValues_.set_x_dot(x_dot_ic);
114 isInitialized_ =
true;
121 Thyra::ModelEvaluatorBase::InArgs<Scalar> inArgs = inArgs_;
123 inArgs.set_t(exact_t);
126 Teuchos::RCP<Thyra::VectorBase<Scalar> > exact_x = createMember(x_space_);
128 Thyra::DetachedVectorView<Scalar> exact_x_view(*exact_x);
129 exact_x_view[0] = exp(lambda_ * exact_t);
131 inArgs.set_x(exact_x);
135 Teuchos::RCP<Thyra::VectorBase<Scalar> > exact_x_dot =
136 createMember(x_space_);
138 Thyra::DetachedVectorView<Scalar> exact_x_dot_view(*exact_x_dot);
139 exact_x_dot_view[0] = lambda_ * exp(lambda_ * exact_t);
141 inArgs.set_x_dot(exact_x_dot);
184 const Thyra::ModelEvaluatorBase::InArgs<Scalar> &inArgs,
185 const Thyra::ModelEvaluatorBase::OutArgs<Scalar> &outArgs)
const
188 using Teuchos::rcp_dynamic_cast;
191 TEUCHOS_TEST_FOR_EXCEPTION(!isInitialized_, std::logic_error,
192 "Error, setupInOutArgs_ must be called first!\n");
194 const RCP<const VectorBase<Scalar> > x_in = inArgs.get_x().assert_not_null();
195 Thyra::ConstDetachedVectorView<Scalar> x_in_view(*x_in);
196 const RCP<VectorBase<Scalar> > f_out = outArgs.get_f();
197 const RCP<Thyra::LinearOpBase<Scalar> > W_out = outArgs.get_W_op();
199 if (inArgs.get_x_dot().is_null()) {
201 if (!is_null(f_out)) {
202 Thyra::DetachedVectorView<Scalar> f_out_view(*f_out);
203 f_out_view[0] = lambda_ * x_in_view[0];
206 TEUCHOS_TEST_FOR_EXCEPTION(
207 true, std::logic_error,
208 "Error -- Dahlquist Test Model requires f_out!\n");
211 if (!is_null(W_out)) {
212 RCP<Thyra::MultiVectorBase<Scalar> > matrix =
213 Teuchos::rcp_dynamic_cast<Thyra::MultiVectorBase<Scalar> >(W_out,
215 Thyra::DetachedMultiVectorView<Scalar> matrix_view(*matrix);
216 matrix_view(0, 0) = lambda_;
221 RCP<const VectorBase<Scalar> > x_dot_in;
222 x_dot_in = inArgs.get_x_dot().assert_not_null();
223 Scalar alpha = inArgs.get_alpha();
224 Scalar beta = inArgs.get_beta();
226 if (!is_null(f_out)) {
227 Thyra::DetachedVectorView<Scalar> f_out_view(*f_out);
228 Thyra::ConstDetachedVectorView<Scalar> x_dot_in_view(*x_dot_in);
229 f_out_view[0] = x_dot_in_view[0] - lambda_ * x_in_view[0];
232 if (!is_null(W_out)) {
233 RCP<Thyra::MultiVectorBase<Scalar> > matrix =
234 Teuchos::rcp_dynamic_cast<Thyra::MultiVectorBase<Scalar> >(W_out,
236 Thyra::DetachedMultiVectorView<Scalar> matrix_view(*matrix);
237 matrix_view(0, 0) = alpha - beta * lambda_;
248 RCP<const Thyra::LinearOpWithSolveFactoryBase<Scalar> > W_factory =
249 this->get_W_factory();
250 RCP<Thyra::LinearOpBase<Scalar> > matrix = this->create_W_op();
252 RCP<Thyra::MultiVectorBase<Scalar> > multivec =
253 Teuchos::rcp_dynamic_cast<Thyra::MultiVectorBase<Scalar> >(matrix,
256 RCP<Thyra::VectorBase<Scalar> > vec = Thyra::createMember(x_space_);
258 Thyra::DetachedVectorView<Scalar> vec_view(*vec);
259 vec_view[0] = lambda_;
261 V_V(multivec->col(0).ptr(), *vec);
264 RCP<Thyra::LinearOpWithSolveBase<Scalar> > W =
265 Thyra::linearOpWithSolve<Scalar>(*W_factory, matrix);