43#ifndef __Panzer_STK_ParameterListCallbackBlocked_hpp__
44#define __Panzer_STK_ParameterListCallbackBlocked_hpp__
46#include "PanzerAdaptersSTK_config.hpp"
47#ifdef PANZER_HAVE_TEKO
49#include "Teuchos_RCP.hpp"
50#include "Teuchos_ParameterList.hpp"
52#include "Teko_RequestCallback.hpp"
56#ifdef PANZER_HAVE_EPETRA_STACK
72class ParameterListCallbackBlocked :
public Teko::RequestCallback<Teuchos::RCP<Teuchos::ParameterList> > {
74 ParameterListCallbackBlocked(
const Teuchos::RCP<const panzer_stk::STKConnManager> & connManager,
75 const Teuchos::RCP<const panzer::BlockedDOFManager> & blkDofs,
76 const Teuchos::RCP<const panzer::BlockedDOFManager> & auxBlkDofs=Teuchos::null);
78 Teuchos::RCP<Teuchos::ParameterList> request(
const Teko::RequestMesg & rm);
80 bool handlesRequest(
const Teko::RequestMesg & rm);
82 void preRequest(
const Teko::RequestMesg & rm);
86 bool isField(
const std::string&
field)
const
90 std::vector<Teuchos::RCP<panzer::GlobalIndexer>>
91 fieldDOFMngrs = blocked_ugi_->getFieldDOFManagers();
92 for (
int b(0); b < static_cast<int>(fieldDOFMngrs.size()); ++b)
94 for (
int f(0); f < fieldDOFMngrs[b]->getNumFields(); ++f)
96 if (fieldDOFMngrs[b]->getFieldString(f) ==
field)
101 return (aux_blocked_ugi_->getFieldNum(
field) != -1);
103 return (blocked_ugi_->getFieldNum(
field) != -1);
106 void buildArrayToVectorTpetra(
int block,
const std::string &
field,
const bool useAux =
false);
107 void buildCoordinatesTpetra(
const std::string &
field,
const bool useAux =
false);
109#ifdef PANZER_HAVE_EPETRA_STACK
110 void buildArrayToVectorEpetra(
int block,
const std::string &
field,
const bool useAux =
false);
111 void buildCoordinatesEpetra(
const std::string &
field,
const bool useAux =
false);
115 std::string getHandledField(
const Teuchos::ParameterList & pl)
const;
117 void setFieldByKey(
const std::string & key,
const std::string &
field,Teuchos::ParameterList & pl)
const;
121 const std::vector<double> & getCoordinateByField(
int dim,
const std::string &
field)
const;
125 Teuchos::RCP<const panzer::Intrepid2FieldPattern> getFieldPattern(
const std::string & fieldName,
const bool useAux =
false)
const;
128 Teuchos::RCP<const panzer_stk::STKConnManager> connManager_;
129 Teuchos::RCP<const panzer::BlockedDOFManager> blocked_ugi_;
130 Teuchos::RCP<const panzer::BlockedDOFManager> aux_blocked_ugi_;
132 std::map<std::string,Teuchos::RCP<const panzer::Intrepid2FieldPattern> > fieldPatterns_;
136 std::map<std::string,std::vector<double> > xcoords_;
137 std::map<std::string,std::vector<double> > ycoords_;
138 std::map<std::string,std::vector<double> > zcoords_;
140 mutable std::map<std::string,Teuchos::RCP<const panzer::ArrayToFieldVector> > arrayToVectorTpetra_;
141#ifdef PANZER_HAVE_EPETRA_STACK
142 mutable std::map<std::string,Teuchos::RCP<const panzer::ArrayToFieldVectorEpetra> > arrayToVectorEpetra_;
145 Teuchos::RCP<Tpetra::MultiVector<double,int,panzer::GlobalOrdinal,panzer::TpetraNodeType> > coordsVecTp_;
146#ifdef PANZER_HAVE_EPETRA_STACK
147 Teuchos::RCP<Epetra_MultiVector> coordsVecEp_;
150 bool returnTpetraObjects_;
PHX::MDField< ScalarT, panzer::Cell, panzer::BASIS > field
A field to which we'll contribute, or in which we'll store, the result of computing this integral.