43 #ifndef __Panzer_ResponseMESupportBase_hpp__
44 #define __Panzer_ResponseMESupportBase_hpp__
48 #include "Teuchos_RCP.hpp"
50 #include "Epetra_Map.h"
51 #include "Epetra_Vector.h"
52 #include "Epetra_MultiVector.h"
53 #include "Epetra_Operator.h"
55 #include "Thyra_VectorSpaceBase.hpp"
56 #include "Thyra_VectorBase.hpp"
57 #include "Thyra_MultiVectorBase.hpp"
58 #include "Thyra_LinearOpBase.hpp"
64 template <
typename EvalT>
76 virtual Teuchos::RCP<const Epetra_Map>
getMap()
const = 0;
81 virtual void setVector(
const Teuchos::RCP<Epetra_Vector> & destVec) = 0;
87 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<double> >
getVectorSpace()
const = 0;
119 virtual void setDerivative(
const Teuchos::RCP<Epetra_MultiVector> & derivative) = 0;
150 virtual Teuchos::RCP<const Epetra_Map>
getMap()
const = 0;
155 virtual void setVector(
const Teuchos::RCP<Epetra_MultiVector> & destVec) = 0;
161 virtual Teuchos::RCP<const Thyra::VectorSpaceBase<double> >
getVectorSpace()
const = 0;
174 #ifdef Panzer_BUILD_HESSIAN_SUPPORT
virtual Teuchos::RCP< Thyra::MultiVectorBase< double > > buildDerivative() const =0
Get an Epetra_Operator for this response, map is constructed lazily.
virtual void setDerivative(const Teuchos::RCP< Thyra::MultiVectorBase< double > > &derivative)=0
virtual bool supportsDerivative() const =0
Does this response support derivative evaluation?
virtual ~ResponseMESupportBase()
ResponseMESupportBase(const std::string &responseName)
ResponseMESupportBase(const ResponseMESupportBase< panzer::Traits::Hessian > &)
virtual Teuchos::RCP< Epetra_MultiVector > buildEpetraDerivative() const =0
Get the Epetra_MultiVector for this response, map is constructed lazily.
ResponseMESupportBase(const std::string &responseName)
virtual void setDerivative(const Teuchos::RCP< Epetra_MultiVector > &derivative)=0
virtual bool supportsDerivative() const =0
Does this response support derivative evaluation?
virtual ~ResponseMESupportBase()
ResponseMESupportBase(const ResponseMESupportBase< panzer::Traits::Jacobian > &)
virtual void setDerivative(const Teuchos::RCP< Thyra::MultiVectorBase< double > > &derivative)=0
virtual Teuchos::RCP< Thyra::MultiVectorBase< double > > buildDerivative() const =0
Get an Epetra_Operator for this response, map is constructed lazily.
virtual Teuchos::RCP< const Epetra_Map > getMap() const =0
Get the Epetra_Map for this response, map is constructed lazily.
virtual void setVector(const Teuchos::RCP< Epetra_MultiVector > &destVec)=0
ResponseMESupportBase(const std::string &responseName)
virtual void setVector(const Teuchos::RCP< Thyra::MultiVectorBase< double > > &destVec)=0
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< double > > getVectorSpace() const =0
Get the vector space for this response, vector space is constructed lazily.
virtual ~ResponseMESupportBase()
ResponseMESupportBase(const ResponseMESupportBase< panzer::Traits::Tangent > &)
ResponseMESupportBase(const ResponseMESupportBase< EvalT > &)
virtual Teuchos::RCP< const Epetra_Map > getMap() const =0
Get the Epetra_Map for this response, map is constructed lazily.
ResponseMESupportBase(const std::string &responseName)
virtual void setVector(const Teuchos::RCP< Thyra::VectorBase< double > > &destVec)=0
virtual ~ResponseMESupportBase()
virtual Teuchos::RCP< const Thyra::VectorSpaceBase< double > > getVectorSpace() const =0
Get the vector space for this response, vector space is constructed lazily.
virtual void setVector(const Teuchos::RCP< Epetra_Vector > &destVec)=0