10#include <compile_time_options.h>
16#include <deal.II/base/parameter_acceptor.h>
17#include <deal.II/base/vectorization.h>
22 namespace ShallowWater
24 template <
typename ScalarNumber =
double>
29 : ParameterAcceptor(subsection)
31 evc_factor_ = ScalarNumber(1.);
32 add_parameter(
"evc factor",
34 "Factor for scaling the entropy viscocity commuator");
40 ScalarNumber evc_factor_;
50 template <
int dim,
typename Number =
double>
101 : hyperbolic_system(hyperbolic_system)
102 , parameters(parameters)
103 , precomputed_values(precomputed_values)
119 const dealii::Tensor<1, dim, Number> &c_ij);
124 Number
alpha(
const Number h_i);
142 Number pressure_i = 0.;
157 template <
int dim,
typename Number>
158 DEAL_II_ALWAYS_INLINE
inline void
163 const auto view = hyperbolic_system.view<dim, Number>();
165 const auto &[eta_m, h_star] =
166 precomputed_values.template get_tensor<Number, precomputed_type>(i);
168 h_i = view.water_depth(U_i);
170 d_eta_i = view.mathematical_entropy_derivative(U_i);
172 pressure_i = view.pressure(U_i);
179 template <
int dim,
typename Number>
181 const unsigned int *js,
183 const dealii::Tensor<1, dim, Number> &c_ij)
187 const auto view = hyperbolic_system.view<dim, Number>();
189 const auto &[eta_j, h_star_j] =
190 precomputed_values.template get_tensor<Number, precomputed_type>(js);
192 const auto velocity_j =
193 view.momentum(U_j) * view.inverse_water_depth_sharp(U_j);
194 const auto f_j = view.f(U_j);
195 const auto pressure_j = view.pressure(U_j);
197 left += (eta_j + pressure_j) * (velocity_j * c_ij);
199 for (
unsigned int k = 0; k < problem_dimension; ++k)
200 right[k] += (f_j[k] - f_i[k]) * c_ij;
204 template <
int dim,
typename Number>
205 DEAL_II_ALWAYS_INLINE
inline Number
209 for (
unsigned int k = 0; k < problem_dimension; ++k) {
210 my_sum += d_eta_i[k] * right[k];
213 Number numerator = std::abs(left - my_sum);
214 Number denominator = std::abs(left) + std::abs(my_sum);
216 const auto regularization =
217 Number(100. * std::numeric_limits<ScalarNumber>::min());
219 const auto quotient =
220 std::abs(numerator) /
221 (denominator + std::max(hd_i * std::abs(eta_i), regularization));
223 return std::min(Number(1.), parameters.evc_factor() * quotient);
dealii::Tensor< 1, problem_dimension, dealii::Tensor< 1, dim, Number > > flux_type
typename get_value_type< Number >::type ScalarNumber
Vectors::MultiComponentVector< ScalarNumber, n_precomputed_values > PrecomputedVector
dealii::Tensor< 1, problem_dimension, Number > state_type
std::array< Number, n_precomputed_values > precomputed_type
static constexpr unsigned int problem_dimension
IndicatorParameters(const std::string &subsection="/Indicator")
ACCESSOR_READ_ONLY(evc_factor)
typename View::PrecomputedVector PrecomputedVector
typename View::state_type state_type
typename View::flux_type flux_type
typename View::precomputed_type precomputed_type
void reset(const unsigned int, const state_type &U_i)
void accumulate(const unsigned int *js, const state_type &U_j, const dealii::Tensor< 1, dim, Number > &c_ij)
static constexpr auto problem_dimension
typename View::ScalarNumber ScalarNumber
Indicator(const HyperbolicSystem &hyperbolic_system, const Parameters ¶meters, const PrecomputedVector &precomputed_values)
Number alpha(const Number h_i)
IndicatorParameters< ScalarNumber > Parameters