Tempus Version of the Day
Time Integration
Loading...
Searching...
No Matches
CDR_Model_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_CDR_MODEL_DECL_HPP
11#define TEMPUS_CDR_MODEL_DECL_HPP
12
13#include "Thyra_StateFuncModelEvaluatorBase.hpp"
14
15class Epetra_Comm;
16class Epetra_Map;
17class Epetra_Vector;
18class Epetra_CrsGraph;
19class Epetra_Import;
20
21namespace Tempus_Test {
22
23template <class Scalar>
25
46template <class Scalar>
47class CDR_Model : public ::Thyra::StateFuncModelEvaluatorBase<Scalar> {
48 public:
49 CDR_Model(const Teuchos::RCP<const Epetra_Comm> &comm,
50 const int num_global_elements, const Scalar z_min,
51 const Scalar z_max,
52 const Scalar a, // convection
53 const Scalar k); // source
54
57
58 void set_x0(const Teuchos::ArrayView<const Scalar> &x0);
59
60 void setShowGetInvalidArgs(bool showGetInvalidArg);
61
62 void set_W_factory(
63 const Teuchos::RCP<const ::Thyra::LinearOpWithSolveFactoryBase<Scalar> >
64 &W_factory);
65
67
70
71 Teuchos::RCP<const ::Thyra::VectorSpaceBase<Scalar> > get_x_space() const;
72 Teuchos::RCP<const ::Thyra::VectorSpaceBase<Scalar> > get_f_space() const;
73 ::Thyra::ModelEvaluatorBase::InArgs<Scalar> getNominalValues() const;
74 Teuchos::RCP<Thyra::LinearOpWithSolveBase<double> > create_W() const;
75 Teuchos::RCP< ::Thyra::LinearOpBase<Scalar> > create_W_op() const;
76 Teuchos::RCP<const ::Thyra::LinearOpWithSolveFactoryBase<Scalar> >
77 get_W_factory() const;
78 ::Thyra::ModelEvaluatorBase::InArgs<Scalar> createInArgs() const;
79 Teuchos::RCP< ::Thyra::PreconditionerBase<Scalar> > create_W_prec() const;
81
82 private:
84 virtual Teuchos::RCP<Epetra_CrsGraph> createGraph();
85
88
89 ::Thyra::ModelEvaluatorBase::OutArgs<Scalar> createOutArgsImpl() const;
90 void evalModelImpl(
91 const ::Thyra::ModelEvaluatorBase::InArgs<Scalar> &inArgs,
92 const ::Thyra::ModelEvaluatorBase::OutArgs<Scalar> &outArgs) const;
93
95
96 private: // data members
97 const Teuchos::RCP<const Epetra_Comm> comm_;
99 const Scalar z_min_;
100 const Scalar z_max_;
101 const Scalar a_;
102 const Scalar k_;
103
104 Teuchos::RCP<const ::Thyra::VectorSpaceBase<Scalar> > x_space_;
105 Teuchos::RCP<const Epetra_Map> x_owned_map_;
106 Teuchos::RCP<const Epetra_Map> x_ghosted_map_;
107 Teuchos::RCP<const Epetra_Import> importer_;
108
109 Teuchos::RCP<const ::Thyra::VectorSpaceBase<Scalar> > f_space_;
110 Teuchos::RCP<const Epetra_Map> f_owned_map_;
111
112 Teuchos::RCP<Epetra_CrsGraph> W_graph_;
113
114 Teuchos::RCP<const ::Thyra::LinearOpWithSolveFactoryBase<Scalar> > W_factory_;
115
116 Teuchos::RCP<Epetra_Vector> node_coordinates_;
117 Teuchos::RCP<Epetra_Vector> ghosted_node_coordinates_;
118
119 mutable Teuchos::RCP<Epetra_Vector> u_ptr;
120 mutable Teuchos::RCP<Epetra_Vector> u_dot_ptr;
121 mutable Teuchos::RCP<Epetra_Vector> x_ptr;
122
123 mutable Teuchos::RCP<Epetra_Vector> J_diagonal_;
124
125 ::Thyra::ModelEvaluatorBase::InArgs<Scalar> nominalValues_;
126 Teuchos::RCP< ::Thyra::VectorBase<Scalar> > x0_;
127 Teuchos::Array<Scalar> p_;
129 ::Thyra::ModelEvaluatorBase::InArgs<Scalar> prototypeInArgs_;
130 ::Thyra::ModelEvaluatorBase::OutArgs<Scalar> prototypeOutArgs_;
131};
132
133//==================================================================
134// Finite Element Basis Object
135class Basis {
136 public:
137 // Constructor
138 Basis();
139
140 // Destructor
141 ~Basis();
142
143 // Calculates the values of u and x at the specified gauss point
144 void computeBasis(int gp, double *z, double *u, double *u_dot = nullptr);
145
146 public:
147 // Variables that are calculated at the gauss point
148 double *phi, *dphide;
149 double uu, zz, duu, eta, wt;
150 double dz;
151 // These are only needed for transient
153};
154
155} // namespace Tempus_Test
156
157#endif
void computeBasis(int gp, double *z, double *u, double *u_dot=nullptr)
1D CGFEM model for convection/diffusion/reaction
Teuchos::RCP< Epetra_Vector > u_dot_ptr
::Thyra::ModelEvaluatorBase::InArgs< Scalar > nominalValues_
Teuchos::RCP< Epetra_Vector > ghosted_node_coordinates_
const Teuchos::RCP< const Epetra_Comm > comm_
Teuchos::RCP< const ::Thyra::LinearOpWithSolveFactoryBase< Scalar > > W_factory_
Teuchos::RCP< const ::Thyra::VectorSpaceBase< Scalar > > get_x_space() const
Teuchos::RCP< Epetra_Vector > node_coordinates_
Teuchos::RCP< const ::Thyra::VectorSpaceBase< Scalar > > x_space_
void setShowGetInvalidArgs(bool showGetInvalidArg)
Teuchos::RCP< Epetra_Vector > J_diagonal_
::Thyra::ModelEvaluatorBase::InArgs< Scalar > getNominalValues() const
Teuchos::RCP< const Epetra_Map > x_owned_map_
void set_W_factory(const Teuchos::RCP< const ::Thyra::LinearOpWithSolveFactoryBase< Scalar > > &W_factory)
virtual Teuchos::RCP< Epetra_CrsGraph > createGraph()
Teuchos::RCP< const ::Thyra::VectorSpaceBase< Scalar > > get_f_space() const
::Thyra::ModelEvaluatorBase::InArgs< Scalar > createInArgs() const
Teuchos::RCP< ::Thyra::LinearOpBase< Scalar > > create_W_op() const
Teuchos::Array< Scalar > p_
Teuchos::RCP< Epetra_Vector > x_ptr
Teuchos::RCP< ::Thyra::VectorBase< Scalar > > x0_
::Thyra::ModelEvaluatorBase::InArgs< Scalar > prototypeInArgs_
Teuchos::RCP< const Epetra_Import > importer_
Teuchos::RCP< Epetra_CrsGraph > W_graph_
::Thyra::ModelEvaluatorBase::OutArgs< Scalar > prototypeOutArgs_
Teuchos::RCP< const ::Thyra::VectorSpaceBase< Scalar > > f_space_
void set_x0(const Teuchos::ArrayView< const Scalar > &x0)
Teuchos::RCP< ::Thyra::PreconditionerBase< Scalar > > create_W_prec() const
Teuchos::RCP< const Epetra_Map > x_ghosted_map_
Teuchos::RCP< Thyra::LinearOpWithSolveBase< double > > create_W() const
Teuchos::RCP< Epetra_Vector > u_ptr
Teuchos::RCP< const Epetra_Map > f_owned_map_
void evalModelImpl(const ::Thyra::ModelEvaluatorBase::InArgs< Scalar > &inArgs, const ::Thyra::ModelEvaluatorBase::OutArgs< Scalar > &outArgs) const
::Thyra::ModelEvaluatorBase::OutArgs< Scalar > createOutArgsImpl() const
Teuchos::RCP< const ::Thyra::LinearOpWithSolveFactoryBase< Scalar > > get_W_factory() const