12 namespace EulerInitialStates
26 template <
typename Description,
int dim,
typename Number>
38 const std::string subsection)
40 , hyperbolic_system_(hyperbolic_system)
43 if constexpr (!View::have_gamma) {
44 this->add_parameter(
"gamma", gamma_,
"The ratio of specific heats");
50 const auto speed_of_sound = [&](
const Number rho,
const Number p) {
51 return std::sqrt(gamma_ * p / rho);
57 const auto rarefaction_right_state = [
this, speed_of_sound](
58 const auto primitive_left,
59 const Number rho_right) {
60 const auto &[rho_left, u_left, p_left, c_left] = primitive_left;
64 primitive_right[2] =
std::pow(rho_right / rho_left, gamma_) * p_left;
66 const auto c_right = speed_of_sound(rho_right, primitive_right[2]);
67 primitive_right[3] = c_right;
71 u_left + 2.0 * (c_left - c_right) / (gamma_ - 1.0);
73 return primitive_right;
76 const auto compute_constants =
77 [
this, speed_of_sound, rarefaction_right_state]() {
78 const auto view = hyperbolic_system_.template view<dim, Number>();
79 if constexpr (View::have_gamma) {
80 gamma_ = view.gamma();
87 const Number rho_left = 3.0;
88 const Number p_left = 1.0;
89 const Number c_left = speed_of_sound(rho_left, p_left);
90 const Number u_left = c_left;
91 const Number rho_right = 0.5;
93 primitive_left_ = {rho_left, c_left, p_left, c_left};
95 rarefaction_right_state(primitive_left_, rho_right);
101 k1 = 2.0 / (gamma_ + 1.0);
102 k2 = ((gamma_ - 1.0) / ((gamma_ + 1.0) * c_left));
103 density_exponent = 2.0 / (gamma_ - 1.0);
104 k3 = c_left + ((gamma_ - 1.0) / 2.0) * u_left;
105 pressure_exponent = 2.0 * gamma_ / (gamma_ - 1.0);
108 this->parse_parameters_call_back.connect(compute_constants);
118 const auto &[rho_left, u_left, p_left, c_left] = primitive_left_;
119 const auto &[rho_right, u_right, p_right, c_right] = primitive_right_;
121 const double x = point[0];
122 const auto t_0 = 0.2 / (u_right - u_left);
123 const auto t = t_0 + delta_t;
127 if (x <= t * (u_left - c_left)) {
128 primitive = primitive_left_;
130 }
else if (x <= t * (u_right - c_right)) {
133 const double chi = x / t;
136 rho_left *
std::pow(k1 + k2 * (u_left - chi), density_exponent);
137 primitive[1] = k1 * (k3 + chi);
139 p_left *
std::pow(k1 + k2 * (u_left - chi), pressure_exponent);
142 primitive = primitive_right_;
147 const auto &[rho, u, p, c] = primitive;
148 conserved_state[0] = rho;
149 conserved_state[1] = rho * u;
150 conserved_state[dim + 1] =
151 p / Number(gamma_ - 1.) + Number(0.5) * rho * u * u;
153 return conserved_state;
164 Number density_exponent;
166 Number pressure_exponent;
std::array< Number, 4 > state_type_1d
Rarefaction(const HyperbolicSystem &hyperbolic_system, const std::string subsection)
state_type compute(const dealii::Point< dim > &point, Number delta_t) final
typename Description::template HyperbolicSystemView< dim, Number > View
typename Description::HyperbolicSystem HyperbolicSystem
typename View::state_type state_type
T pow(const T x, const T b)
Euler::HyperbolicSystem HyperbolicSystem