42 const Teuchos::RCP<FunctionalScatterBase> & functionalScatter)
44 , scatterObj_(functionalScatter)
52 RCP<PHX::DataLayout> dl_dummy = rcp(
new PHX::MDALayout<panzer::Dummy>(0));
57 RCP<PHX::DataLayout> dl_cell = rcp(
new PHX::MDALayout<panzer::Cell>(cd.
numCells()));
58 cellIntegral_ = PHX::MDField<const ScalarT,panzer::Cell>(name,dl_cell);
61 std::string n =
"Functional Response Scatter: " + name;
68 const std::string & responseName,
70 const Teuchos::RCP<FunctionalScatterBase> & functionalScatter)
71 : responseName_(responseName)
72 , scatterObj_(functionalScatter)
80 RCP<PHX::DataLayout> dl_dummy = rcp(
new PHX::MDALayout<panzer::Dummy>(0));
85 RCP<PHX::DataLayout> dl_cell = rcp(
new PHX::MDALayout<panzer::Cell>(cd.
numCells()));
86 cellIntegral_ = PHX::MDField<const ScalarT,panzer::Cell>(integrandName,dl_cell);
89 std::string n =
"Functional Response Scatter: " + responseName;
119 using Teuchos::rcp_dynamic_cast;
120 using Thyra::SpmdVectorBase;
123 TEUCHOS_ASSERT(scatterObj_!=Teuchos::null);
124 TEUCHOS_ASSERT(responseObj_->getGhostedVector()!=Teuchos::null);
126 RCP<ProductVectorBase<double> > prod_dgdx = Thyra::castOrCreateNonconstProductVectorBase(responseObj_->getGhostedVector());
128 std::vector<Teuchos::ArrayRCP<double> > local_dgdxs;
129 for(
int b=0;b<prod_dgdx->productSpace()->numBlocks();b++) {
131 Teuchos::ArrayRCP<double> local_dgdx;
132 RCP<SpmdVectorBase<double> > dgdx = rcp_dynamic_cast<SpmdVectorBase<double> >(prod_dgdx->getNonconstVectorBlock(b));
133 dgdx->getNonconstLocalData(ptrFromRef(local_dgdx));
135 TEUCHOS_ASSERT(!local_dgdx.is_null());
137 local_dgdxs.push_back(local_dgdx);
140 scatterObj_->scatterDerivative(cellIntegral_,d,this->wda,local_dgdxs);
149 using Teuchos::rcp_dynamic_cast;
150 using Thyra::SpmdVectorBase;
153 TEUCHOS_ASSERT(scatterObj_!=Teuchos::null);
154 TEUCHOS_ASSERT(responseObj_->getGhostedVector()!=Teuchos::null);
156 RCP<ProductVectorBase<double> > prod_dgdx = Thyra::castOrCreateNonconstProductVectorBase(responseObj_->getGhostedVector());
158 std::vector<Teuchos::ArrayRCP<double> > local_dgdxs;
159 for(
int b=0;b<prod_dgdx->productSpace()->numBlocks();b++) {
161 Teuchos::ArrayRCP<double> local_dgdx;
162 RCP<SpmdVectorBase<double> > dgdx = rcp_dynamic_cast<SpmdVectorBase<double> >(prod_dgdx->getNonconstVectorBlock(b));
163 dgdx->getNonconstLocalData(ptrFromRef(local_dgdx));
165 TEUCHOS_ASSERT(!local_dgdx.is_null());
167 local_dgdxs.push_back(local_dgdx);
171 scatterObj_->scatterHessian(cellIntegral_,d,this->wda,local_dgdxs);