43 #ifndef PANZER_EVALUATOR_VECTOR_TO_SCALAR_DECL_HPP 44 #define PANZER_EVALUATOR_VECTOR_TO_SCALAR_DECL_HPP 48 #include "Phalanx_Evaluator_Macros.hpp" 49 #include "Phalanx_MDField.hpp" 54 template<
typename EvalT,
typename Traits>
58 public PHX::EvaluatorDerived<EvalT, Traits>
63 const Teuchos::ParameterList& p);
82 const std::vector<PHX::Tag<ScalarT>> & output);
99 template <
typename EvalT,
typename Traits>
101 const std::string & scalarPrefix,
102 const std::vector<std::string> & postfix,
103 const Teuchos::RCP<const PHX::DataLayout> & vectorLayout,
104 const Teuchos::RCP<const PHX::DataLayout> & scalarLayout)
108 using Teuchos::rcp_const_cast;
110 RCP<std::vector<std::string> > scalarNames = rcp(
new std::vector<std::string>);
111 for(std::size_t i=0;i<postfix.size();i++)
112 scalarNames->push_back(scalarPrefix+postfix[i]);
114 Teuchos::ParameterList input;
115 input.set(
"Vector Name",vectorName);
116 input.set(
"Scalar Names",scalarNames.getConst());
117 input.set(
"Data Layout Vector",rcp_const_cast<PHX::DataLayout>(vectorLayout));
118 input.set(
"Data Layout Scalar",rcp_const_cast<PHX::DataLayout>(scalarLayout));
134 template <
typename EvalT,
typename Traits>
136 const std::vector<std::string> & postfix,
137 const Teuchos::RCP<const PHX::DataLayout> & vectorLayout,
138 const Teuchos::RCP<const PHX::DataLayout> & scalarLayout)
140 return vectorToScalarEvaluator<EvalT,Traits>(vectorName,vectorName,postfix,vectorLayout,scalarLayout);
PHX::MDField< const ScalarT, Cell, Point, Dim > vector_field
Teuchos::RCP< PHX::Evaluator< Traits > > vectorToScalarEvaluator(const std::string &vectorName, const std::string &scalarPrefix, const std::vector< std::string > &postfix, const Teuchos::RCP< const PHX::DataLayout > &vectorLayout, const Teuchos::RCP< const PHX::DataLayout > &scalarLayout)
Wrapper to PHX::EvaluatorWithBaseImpl that implements Panzer-specific helpers.
std::vector< PHX::MDField< ScalarT, Cell, Point > > scalar_fields
VectorToScalar(const Teuchos::ParameterList &p)
void evaluateFields(typename Traits::EvalData d)
typename EvalT::ScalarT ScalarT