Rythmos - Transient Integration for Differential Equations Version of the Day
Rythmos_SingleResidualModelEvaluatorBase.hpp
00001 //@HEADER
00002 // ***********************************************************************
00003 //
00004 //                           Rythmos Package
00005 //                 Copyright (2006) Sandia Corporation
00006 //
00007 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
00008 // license for use of this work by or on behalf of the U.S. Government.
00009 //
00010 // This library is free software; you can redistribute it and/or modify
00011 // it under the terms of the GNU Lesser General Public License as
00012 // published by the Free Software Foundation; either version 2.1 of the
00013 // License, or (at your option) any later version.
00014 //
00015 // This library is distributed in the hope that it will be useful, but
00016 // WITHOUT ANY WARRANTY; without even the implied warranty of
00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00018 // Lesser General Public License for more details.
00019 //
00020 // You should have received a copy of the GNU Lesser General Public
00021 // License along with this library; if not, write to the Free Software
00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
00023 // USA
00024 // Questions? Contact Todd S. Coffey (tscoffe@sandia.gov)
00025 //
00026 // ***********************************************************************
00027 //@HEADER
00028 
00029 
00030 #ifndef RYTHMOS_SINGLE_RESIDUAL_MODEL_EVALUATOR_BASE_HPP
00031 #define RYTHMOS_SINGLE_RESIDUAL_MODEL_EVALUATOR_BASE_HPP
00032 
00033 
00034 #include "Thyra_ModelEvaluator.hpp"
00035 
00036 
00037 namespace Rythmos {
00038 
00039 
00044 template<class Scalar>
00045 class SingleResidualModelEvaluatorBase
00046   : virtual public Thyra::ModelEvaluator<Scalar>
00047 {
00048 public:
00049 
00052   
00054   virtual void initializeSingleResidualModel(
00055     const RCP<const Thyra::ModelEvaluator<Scalar> > &daeModel,
00056     const Thyra::ModelEvaluatorBase::InArgs<Scalar> &basePoint,
00057     const Scalar &coeff_x_dot,
00058     const RCP<const Thyra::VectorBase<Scalar> > &x_dot_base,
00059     const Scalar &coeff_x,
00060     const RCP<const Thyra::VectorBase<Scalar> > &x_base,
00061     const Scalar &t_base,
00062     const RCP<const Thyra::VectorBase<Scalar> > &x_bar_init
00063     ) = 0;
00064 
00066 
00069 
00071   virtual Scalar get_coeff_x_dot() const = 0;
00072 
00074   virtual RCP<const Thyra::VectorBase<Scalar> >
00075   get_x_dot_base() const = 0;
00076 
00078   virtual Scalar get_coeff_x() const = 0;
00079 
00081   virtual RCP<const Thyra::VectorBase<Scalar> >
00082   get_x_base() const = 0;
00083 
00085   virtual Scalar get_t_base() const = 0;
00086 
00088 
00089 };
00090 
00091 
00092 } // namespace Rythmos
00093 
00094 
00095 #endif // RYTHMOS_SINGLE_RESIDUAL_MODEL_EVALUATOR_BASE_HPP
 All Classes Functions Variables Typedefs Friends