43 #ifndef __Panzer_GatherTangent_Epetra_impl_hpp__
44 #define __Panzer_GatherTangent_Epetra_impl_hpp__
53 #include "Epetra_Vector.h"
63 #include "Teuchos_Assert.hpp"
66 #include "Thyra_SpmdVectorBase.hpp"
73 template<
typename EvalT,
typename TRAITS,
typename LO,
typename GO>
79 globalIndexer_(indexer),
80 useTimeDerivativeSolutionVector_(false),
81 globalDataKey_(
"Tangent Gather Container")
85 using PHX::typeAsString;
99 if (p.
isType<
bool>(
"Use Time Derivative Solution Vector"))
101 p.
get<
bool>(
"Use Time Derivative Solution Vector");
102 if (p.
isType<
string>(
"Global Data Key"))
111 MDField<ScalarT, Cell, NODE>(names[fd], basis->functional);
116 string firstName(
"<none>");
118 firstName = names[0];
119 string n(
"GatherTangent (Epetra): " + firstName +
" (" +
120 typeAsString<EvalT>() +
")");
129 template<
typename EvalT,
typename TRAITS,
typename LO,
typename GO>
133 typename TRAITS::SetupData ,
136 using std::logic_error;
146 const string& fieldName((*indexerNames_)[fd]);
147 fieldIds_[fd] = globalIndexer_->getFieldNum(fieldName);
151 "GatherTangent_Epetra<Residual>: Could not find field \"" + fieldName +
152 "\" in the global indexer. ");
154 indexerNames_ =
null;
162 template<
typename EvalT,
typename TRAITS,
typename LO,
typename GO>
166 typename TRAITS::PreEvalData d)
169 using Teuchos::rcp_dynamic_cast;
172 if (d.gedc->containsDataObject(globalDataKey_))
174 RCP<GED> ged = d.gedc->getDataObject(globalDataKey_);
175 dxdpEvRoGed_ = rcp_dynamic_cast<EVROGED>(ged,
true);
184 template<
typename EvalT,
typename TRAITS,
typename LO,
typename GO>
188 typename TRAITS::EvalData workset)
195 using Teuchos::ptrFromRef;
197 using Teuchos::rcp_dynamic_cast;
198 using Thyra::SpmdVectorBase;
202 if (dxdpEvRoGed_.is_null())
206 string blockId(this->wda(workset).block_id);
207 const vector<size_t>& localCellIds = this->wda(workset).cell_local_ids;
208 int numCells(localCellIds.size()),
numFields(gatherFields_.size());
215 for (
int cell(0); cell < numCells; ++cell)
217 size_t cellLocalId(localCellIds[cell]);
218 auto LIDs = globalIndexer_->getElementLIDs(cellLocalId);
221 for (
int fieldIndex(0); fieldIndex <
numFields; ++fieldIndex)
223 MDField<ScalarT, Cell, NODE>&
field = gatherFields_[fieldIndex];
224 int fieldNum(fieldIds_[fieldIndex]);
225 const vector<int>& elmtOffset =
226 globalIndexer_->getGIDFieldOffsets(blockId, fieldNum);
227 int numBases(elmtOffset.size());
230 for (
int basis(0); basis < numBases; ++basis)
232 int offset(elmtOffset[basis]), lid(LIDs[offset]);
233 field(cell, basis) = (*dxdpEvRoGed_)[lid];
239 #endif // __Panzer_GatherTangent_Epetra_impl_hpp__