43 #ifndef PANZER_RESPONSE_SCATTER_EVALUATOR_EXTREMEVALUE_IMPL_HPP 44 #define PANZER_RESPONSE_SCATTER_EVALUATOR_EXTREMEVALUE_IMPL_HPP 49 #include "PanzerDiscFE_config.hpp" 51 #include "Phalanx_Evaluator_Macros.hpp" 52 #include "Phalanx_MDField.hpp" 53 #include "Phalanx_DataLayout_MDALayout.hpp" 58 #include "Thyra_SpmdVectorBase.hpp" 59 #include "Teuchos_ArrayRCP.hpp" 66 template<
typename EvalT,
typename Traits>
73 , scatterObj_(extremeValueScatter)
91 std::string n =
"Functional Response Scatter: " + name;
95 template<
typename EvalT,
typename Traits>
98 const std::string & responseName,
102 : responseName_(responseName)
103 , scatterObj_(extremeValueScatter)
118 cellExtremeValue_ = PHX::MDField<const ScalarT,panzer::Cell>(integrandName,dl_cell);
121 std::string n =
"Functional Response Scatter: " + responseName;
125 template<
typename EvalT,
typename Traits>
135 template<
typename EvalT,
typename Traits>
140 this->utils.setFieldData(cellExtremeValue_,fm);
143 template<
typename EvalT,
typename Traits>
149 responseObj_->value = (responseObj_->value < cellExtremeValue_(i)) ? cellExtremeValue_(i) : responseObj_->value;
151 responseObj_->value = (responseObj_->value > cellExtremeValue_(i)) ? cellExtremeValue_(i) : responseObj_->value;
160 using Teuchos::rcp_dynamic_cast;
161 using Thyra::SpmdVectorBase;
168 dgdx->getNonconstLocalData(ptrFromRef(local_dgdx));
171 scatterObj_->scatterDerivative(cellExtremeValue_,d,this->wda,local_dgdx);
static std::string buildLookupName(const std::string &responseName)
void preEvaluate(typename Traits::PreEvalData d)
ResponseScatterEvaluator_ExtremeValue(const std::string &name, const CellData &cd, bool useMax, const Teuchos::RCP< ExtremeValueScatterBase > &functionalScatter)
A constructor with concrete arguments instead of a parameter list.
Teuchos::RCP< GlobalEvaluationData > getDataObject(const std::string &key) const
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
Data for determining cell topology and dimensionality.
PHX::MDField< const ScalarT, panzer::Cell > cellExtremeValue_
void evaluateFields(typename Traits::EvalData d)
Teuchos::RCP< PHX::FieldTag > scatterHolder_
void postRegistrationSetup(typename Traits::SetupData d, PHX::FieldManager< Traits > &fm)
GlobalEvaluationDataContainer gedc
#define TEUCHOS_ASSERT(assertion_test)
std::size_t numCells() const