10#include <compile_time_options.h>
16 namespace EulerInitialStates
29 template <
typename Description,
int dim,
typename Number>
39 const std::string subsection)
41 , hyperbolic_system_(hyperbolic_system)
44 if constexpr (!View::have_gamma) {
45 this->add_parameter(
"gamma", gamma_,
"The ratio of specific heats");
48 primitive_inside_[0] = 0.1;
49 primitive_inside_[1] = 0.0;
50 primitive_inside_[2] = 1.0;
52 "primitive state inside",
54 "Initial primitive state (rho, u, p) inside perturbed interface");
56 primitive_outside_[0] = 1.0;
57 primitive_outside_[1] = 0.0;
58 primitive_outside_[2] = 1.0;
60 "primitive state outside",
62 "Initial primitive state (rho, u, p) outside perturbed interface");
64 interface_radius_ = 1.0;
66 "interface radius", interface_radius_,
"Radius of interface");
69 this->add_parameter(
"number of modes",
71 "Number of modes for pertburation of interface");
75 "amplitude", amplitude_,
"Amplitude for interface pertburation");
79 "mach number", mach_number_,
"Mach number of incoming shock front");
82 this->add_parameter(
"shock radius",
84 "Radial location of incoming shock front");
86 const auto convert_states = [&]() {
87 const auto view = hyperbolic_system_.template view<dim, Number>();
88 state_inside_ = view.from_initial_state(primitive_inside_);
89 state_outside_ = view.from_initial_state(primitive_outside_);
91 this->parse_parameters_call_back.connect(convert_states);
97 const auto view = hyperbolic_system_.template view<dim, Number>();
101 const auto r_hat = point / point.norm();
104 if constexpr (View::have_eos_interpolation_b)
105 b = view.eos_interpolation_b();
107 const auto &rho_R = primitive_outside_[0];
108 const auto &u_R = primitive_outside_[1];
109 const auto &p_R = primitive_outside_[2];
111 const Number a_R = std::sqrt(gamma_ * p_R / rho_R / (1 - b * rho_R));
112 const Number mach_R = u_R / a_R;
114 auto S3_ = mach_number_ * a_R;
115 const Number delta_mach = mach_R - mach_number_;
118 rho_R * (gamma_ + Number(1.)) * delta_mach * delta_mach /
119 ((gamma_ - Number(1.)) * delta_mach * delta_mach + Number(2.));
121 (Number(1.) - rho_R / rho_L) * S3_ + rho_R / rho_L * u_R;
122 const Number p_L = p_R *
123 (Number(2.) * gamma_ * delta_mach * delta_mach -
124 (gamma_ - Number(1.))) /
125 (gamma_ + Number(1.));
128 primitive_shock_state[0] = rho_L;
130 for (
unsigned int i = 0; i < dim; ++i) {
131 primitive_shock_state[i + 1] = 0.;
134 if (point.norm() > 0.) {
135 for (
unsigned int i = 0; i < dim; ++i) {
136 primitive_shock_state[i + 1] = -u_L * r_hat[i];
139 primitive_shock_state[1 + dim] = p_L;
141 conserved_shock_state =
142 view.from_initial_state(primitive_shock_state);
146 const auto x = point[0];
147 const auto y = dim > 1 ? point[1] : 0.;
149 const double theta = std::atan2(y, x);
152 if constexpr (dim == 3)
153 phi = std::atan2(point[2], std::sqrt(x * x + y * y));
156 const auto omega = num_modes_;
157 const double perturbation =
158 amplitude_ * std::cos(omega * theta) * std::cos(omega * phi);
162 (point.norm() > interface_radius_ + perturbation ? state_outside_
165 if (point.norm() > shock_radius_) {
166 full_state = conserved_shock_state;
178 dealii::Tensor<1, 3, Number> primitive_inside_;
179 dealii::Tensor<1, 3, Number> primitive_outside_;
183 double interface_radius_;
186 double shock_radius_;
ICFLike(const HyperbolicSystem &hyperbolic_system, const std::string subsection)
state_type compute(const dealii::Point< dim > &point, Number) final
typename View::state_type state_type
typename Description::HyperbolicSystem HyperbolicSystem
typename Description::template HyperbolicSystemView< dim, Number > View
Euler::HyperbolicSystem HyperbolicSystem