24 const Teuchos::ParameterList& p)
26 std::string sum_name = p.get<std::string>(
"Sum Name");
27 Teuchos::RCP<std::vector<std::string> > value_names =
28 p.get<Teuchos::RCP<std::vector<std::string> > >(
"Values Names");
29 Teuchos::RCP<PHX::DataLayout> data_layout =
30 p.get< Teuchos::RCP<PHX::DataLayout> >(
"Data Layout");
32 TEUCHOS_ASSERT(
static_cast<int>(value_names->size()) < MAX_VALUES);
35 auto local_scalars = PHX::View<double *>(
"scalars",value_names->size());
36 auto local_scalars_host = Kokkos::create_mirror_view(local_scalars);
37 if(p.isType<Teuchos::RCP<
const std::vector<double> > >(
"Scalars")) {
38 auto scalars_v = *p.get<Teuchos::RCP<const std::vector<double> > >(
"Scalars");
41 TEUCHOS_ASSERT(scalars_v.size()==value_names->size());
43 for (std::size_t i=0; i < value_names->size(); ++i)
44 local_scalars_host(i) = scalars_v[i];
47 for (std::size_t i=0; i < value_names->size(); ++i)
48 local_scalars_host(i) = 1.0;
50 Kokkos::deep_copy(local_scalars,local_scalars_host);
52 scalars = local_scalars;
54 sum = PHX::MDField<ScalarT>(sum_name, data_layout);
56 this->addEvaluatedField(sum);
58 for (std::size_t i=0; i < value_names->size(); ++i) {
59 values[i] = PHX::MDField<const ScalarT>( (*value_names)[i], data_layout);
60 this->addDependentField(values[i]);
70 std::string n =
"Sum Evaluator";
91 auto num_vals = scalars.extent(0);
96 for (std::size_t iv = 0; iv < num_vals; ++iv)
97 sum(i) += scalars(iv)*(values[iv](i));
101 const size_t dim_1 = sum.extent(1);
102 for (std::size_t j = 0; j < dim_1; ++j)
103 for (std::size_t iv = 0; iv < num_vals; ++iv)
104 sum(i,j) += scalars(iv)*(values[iv](i,j));
108 const size_t dim_1 = sum.extent(1),dim_2 = sum.extent(2);
109 for (std::size_t j = 0; j < dim_1; ++j)
110 for (std::size_t k = 0; k < dim_2; ++k)
111 for (std::size_t iv = 0; iv < num_vals; ++iv)
112 sum(i,j,k) += scalars(iv)*(values[iv](i,j,k));
116 const size_t dim_1 = sum.extent(1),dim_2 = sum.extent(2),dim_3 = sum.extent(3);
117 for (std::size_t j = 0; j < dim_1; ++j)
118 for (std::size_t k = 0; k < dim_2; ++k)
119 for (std::size_t l = 0; l < dim_3; ++l)
120 for (std::size_t iv = 0; iv < num_vals; ++iv)
121 sum(i,j,k,l) += scalars(iv)*(values[iv](i,j,k,l));
125 const size_t dim_1 = sum.extent(1),dim_2 = sum.extent(2),dim_3 = sum.extent(3),dim_4 = sum.extent(4);
126 for (std::size_t j = 0; j < dim_1; ++j)
127 for (std::size_t k = 0; k < dim_2; ++k)
128 for (std::size_t l = 0; l < dim_3; ++l)
129 for (std::size_t m = 0; m < dim_4; ++m)
130 for (std::size_t iv = 0; iv < num_vals; ++iv)
131 sum(i,j,k,l,m) += scalars(iv)*(values[iv](i,j,k,l,m));
135 const size_t dim_1 = sum.extent(1),dim_2 = sum.extent(2),dim_3 = sum.extent(3),dim_4 = sum.extent(4),dim_5 = sum.extent(5);
136 for (std::size_t j = 0; j < dim_1; ++j)
137 for (std::size_t k = 0; k < dim_2; ++k)
138 for (std::size_t l = 0; l < dim_3; ++l)
139 for (std::size_t m = 0; m < dim_4; ++m)
140 for (std::size_t n = 0; n < dim_5; ++n)
141 for (std::size_t iv = 0; iv < num_vals; ++iv)
142 sum(i,j,k,l,m,n) += scalars(iv)*(values[iv](i,j,k,l,m,n));
197SumStatic(
const Teuchos::ParameterList& p)
199 std::string sum_name = p.get<std::string>(
"Sum Name");
200 Teuchos::RCP<std::vector<std::string> > value_names =
201 p.get<Teuchos::RCP<std::vector<std::string> > >(
"Values Names");
202 Teuchos::RCP<PHX::DataLayout> data_layout =
203 p.get< Teuchos::RCP<PHX::DataLayout> >(
"Data Layout");
206 TEUCHOS_ASSERT(data_layout->rank()==1);
208 sum = PHX::MDField<ScalarT,Tag0>(sum_name, data_layout);
210 this->addEvaluatedField(sum);
212 values.resize(value_names->size());
213 for (std::size_t i=0; i < value_names->size(); ++i) {
214 values[i] = PHX::MDField<const ScalarT,Tag0>( (*value_names)[i], data_layout);
215 this->addDependentField(values[i]);
218 std::string n =
"SumStatic Rank 1 Evaluator";
239SumStatic(
const Teuchos::ParameterList& p)
241 std::string sum_name = p.get<std::string>(
"Sum Name");
242 Teuchos::RCP<std::vector<std::string> > value_names =
243 p.get<Teuchos::RCP<std::vector<std::string> > >(
"Values Names");
244 Teuchos::RCP<PHX::DataLayout> data_layout =
245 p.get< Teuchos::RCP<PHX::DataLayout> >(
"Data Layout");
248 if(p.isType<Teuchos::RCP<
const std::vector<double> > >(
"Scalars")) {
249 Teuchos::RCP<const std::vector<double> > scalar_values
250 = p.get<Teuchos::RCP<const std::vector<double> > >(
"Scalars");
253 TEUCHOS_ASSERT(scalar_values->size()==value_names->size());
256 PHX::View<double*> scalars_nc = PHX::View<double*>(
"scalars",scalar_values->size());
258 for(std::size_t i=0;i<scalar_values->size();i++)
259 scalars_nc(i) = (*scalar_values)[i];
261 scalars = scalars_nc;
268 TEUCHOS_ASSERT(data_layout->rank()==2);
270 sum = PHX::MDField<ScalarT,Tag0,Tag1>(sum_name, data_layout);
272 this->addEvaluatedField(sum);
274 values.resize(value_names->size());
275 for (std::size_t i=0; i < value_names->size(); ++i) {
276 values[i] = PHX::MDField<const ScalarT,Tag0,Tag1>( (*value_names)[i], data_layout);
277 this->addDependentField(values[i]);
279 numValues = value_names->size();
280 TEUCHOS_ASSERT(numValues<=MAX_VALUES);
282 std::string n =
"SumStatic Rank 2 Evaluator";
290SumStatic(
const std::vector<PHX::Tag<typename EvalT::ScalarT>> & inputs,
291 const std::vector<double> & scalar_values,
292 const PHX::Tag<typename EvalT::ScalarT> & output)
294 TEUCHOS_ASSERT(scalar_values.size()==inputs.size());
297 if(scalars.size()==0) {
303 PHX::View<double*> scalars_nc = PHX::View<double*>(
"scalars",scalar_values.size());
305 for(std::size_t i=0;i<scalar_values.size();i++)
306 scalars_nc(i) = scalar_values[i];
308 scalars = scalars_nc;
312 TEUCHOS_ASSERT(inputs.size()<=MAX_VALUES);
315 this->addEvaluatedField(sum);
317 values.resize(inputs.size());
318 for (std::size_t i=0; i < inputs.size(); ++i) {
319 values[i] = inputs[i];
320 this->addDependentField(values[i]);
323 numValues = inputs.size();
325 std::string n =
"SumStatic Rank 2 Evaluator";