31 const Teuchos::ParameterList& p)
33 comm = p.get< Teuchos::RCP<const Teuchos::Comm<int> > >(
"Comm");
35 global_data = p.get<Teuchos::RCP<panzer::GlobalData> >(
"Global Data");
40 std::string names_string = p.get<std::string>(
"Names");
41 std::vector<std::string> names;
44 Teuchos::RCP<panzer::IntegrationRule> ir = p.get< Teuchos::RCP<panzer::IntegrationRule> >(
"IR");
47 for (
typename std::vector<std::string>::const_iterator name = names.begin(); name != names.end(); ++name)
48 field_values.push_back(PHX::MDField<const ScalarT,Cell,IP>(*name, ir->dl_scalar));
50 Teuchos::RCP<PHX::MDALayout<Cell> > cell_dl = Teuchos::rcp(
new PHX::MDALayout<Cell>(ir->dl_scalar->extent(0)));
51 volumes = PHX::MDField<ScalarT,Cell>(
"Cell Volumes",cell_dl);
53 tmp = PHX::MDField<ScalarT,Cell>(
"GlobalStatistics:tmp:"+names_string,cell_dl);
54 ones = PHX::MDField<ScalarT,Cell,IP>(
"GlobalStatistics:ones:"+names_string,ir->dl_scalar);
56 this->addEvaluatedField(volumes);
57 this->addEvaluatedField(tmp);
58 this->addEvaluatedField(ones);
59 for (
typename std::vector<PHX::MDField<const ScalarT,Cell,IP> >::const_iterator
field = field_values.begin();
61 this->addDependentField(*
field);
64 averages.resize(field_values.size());
65 maxs.resize(field_values.size());
66 mins.resize(field_values.size());
67 global_maxs.resize(field_values.size());
68 global_mins.resize(field_values.size());
69 global_averages.resize(field_values.size());
71 ir_order = ir->cubature_degree;
73 std::string n =
"GlobalStatistics: " + names_string;
103 Intrepid2::FunctionSpaceTools<PHX::Device::execution_space>::integrate(volumes.get_view(),
105 (this->wda(workset).int_rules[ir_index])->weighted_measure.get_view());
106 auto volumes_h = Kokkos::create_mirror_view(as_view(volumes));
107 Kokkos::deep_copy(volumes_h, as_view(volumes));
109 for (index_t cell = 0; cell < workset.
num_cells; ++cell)
110 total_volume += volumes_h(cell);
112 typename std::vector<PHX::MDField<ScalarT,Cell,IP> >::size_type field_index = 0;
113 for (
typename std::vector<PHX::MDField<const ScalarT,Cell,IP> >::iterator
field = field_values.begin();
114 field != field_values.end(); ++
field,++field_index) {
116 Intrepid2::FunctionSpaceTools<PHX::Device::execution_space>::integrate(tmp.get_view(),
118 (this->wda(workset).int_rules[ir_index])->weighted_measure.get_view());
119 auto tmp_h = Kokkos::create_mirror_view(tmp.get_static_view());
120 auto field_h = Kokkos::create_mirror_view(
field->get_static_view());
121 Kokkos::deep_copy(tmp_h, tmp.get_static_view());
122 Kokkos::deep_copy(field_h,
field->get_static_view());
125 for (index_t cell = 0; cell < workset.
num_cells; ++cell) {
126 averages[field_index] += tmp_h(cell);
128 for (
typename PHX::MDField<ScalarT,Cell,IP>::size_type ip = 0; ip < (
field->extent(1)); ++ip) {
129 maxs[field_index] = std::max( field_h(cell,ip), maxs[field_index]);
130 mins[field_index] = std::min( field_h(cell,ip), mins[field_index]);
144 total_volume = Teuchos::ScalarTraits<ScalarT>::zero();
146 for (
typename std::vector<ScalarT>::iterator
field = averages.begin();
field != averages.end(); ++
field)
147 *
field = Teuchos::ScalarTraits<ScalarT>::zero();
149 for (
typename std::vector<ScalarT>::iterator
field = maxs.begin();
field != maxs.end(); ++
field)
150 *
field = Teuchos::ScalarTraits<ScalarT>::rmin();
152 for (
typename std::vector<ScalarT>::iterator
field = mins.begin();
field != mins.end(); ++
field)
153 *
field = Teuchos::ScalarTraits<ScalarT>::rmax();
178 Teuchos::reduceAll(*comm, Teuchos::REDUCE_SUM,
static_cast<int>(1), &total_volume, &global_total_volume);
179 Teuchos::reduceAll(*comm, Teuchos::REDUCE_SUM,
static_cast<int>(averages.size()), &averages[0], &global_averages[0]);
180 Teuchos::reduceAll(*comm, Teuchos::REDUCE_MAX,
static_cast<int>(maxs.size()), &maxs[0], &global_maxs[0]);
181 Teuchos::reduceAll(*comm, Teuchos::REDUCE_MIN,
static_cast<int>(mins.size()), &mins[0], &global_mins[0]);
183 for (std::vector<ScalarT>::size_type i = 0; i < field_values.size(); ++i)
184 global_averages[i] /= global_total_volume;
186 if (comm->getRank() == 0) {
190 std::size_t precision = 8;
191 os << std::scientific << std::showpoint << std::setprecision(precision) << std::left;
193 std::size_t name_width = 0;
194 for (std::vector<ScalarT>::size_type i = 0; i < field_values.size(); ++i)
195 name_width = std::max(name_width,field_values[i].fieldTag().name().size());
197 std::size_t value_width = precision + 7;
199 os << std::setw(name_width) <<
"Field"
200 <<
" " << std::setw(value_width) <<
"Average"
201 <<
" " << std::setw(value_width) <<
"Maximum (@IP)"
202 <<
" " << std::setw(value_width) <<
"Minimum (@IP)"
205 for (std::vector<ScalarT>::size_type i = 0; i < field_values.size(); ++i) {
206 os << std::setw(name_width) << field_values[i].fieldTag().name()
207 <<
" " << std::setw(value_width) << global_averages[i]
208 <<
" " << std::setw(value_width) << global_maxs[i]
209 <<
" " << std::setw(value_width) << global_mins[i] << std::endl;
PHX::MDField< ScalarT, panzer::Cell, panzer::BASIS > field
A field to which we'll contribute, or in which we'll store, the result of computing this integral.
void StringTokenizer(std::vector< std::string > &tokens, const std::string &str, const std::string delimiters, bool trim)
Tokenize a string, put tokens in a vector.