26 const Teuchos::ParameterList& p)
27 : evaluateOnClosure_(false)
30 p.validateParameters(*valid_params);
32 const std::string inName = p.get<std::string>(
"Field Name");
33 const std::string outName = p.get<std::string>(
"Sum Name");
34 Teuchos::RCP<const PureBasis> basis = p.get< Teuchos::RCP<const PureBasis> >(
"Basis");
36 if(p.isType<
bool>(
"Evaluate On Closure"))
39 inField = PHX::MDField<const ScalarT,Cell,BASIS>( inName, basis->functional);
40 outField = PHX::MDField<ScalarT,Cell>( outName, basis->cell_data);
42 this->addDependentField(
inField);
48 std::string n =
"SubcellSum: " +
outField.fieldTag().name();
59 std::vector<int> indices;
64 if(evaluateOnClosure_)
65 fieldPattern_->getSubcellClosureIndices(workset.
subcell_dim,this->wda(workset).subcell_index,indices);
67 indices = fieldPattern_->getSubcellIndices(workset.
subcell_dim,this->wda(workset).subcell_index);
69 auto outField_h = Kokkos::create_mirror_view(outField.get_static_view());
70 auto inField_h = Kokkos::create_mirror_view(inField.get_static_view());
71 Kokkos::deep_copy(inField_h, inField.get_static_view());
72 for(index_t c=0;c<workset.
num_cells;c++) {
76 for(std::size_t i=0;i<indices.size();i++)
77 outField_h(c) += inField_h(c,indices[i]);
82 Kokkos::deep_copy(outField.get_static_view(), outField_h);