ryujin 2.1.1 revision 46bf70e400e423a8ffffe8300887eeb35b8dfb2c
initial_state_uniform.h
Go to the documentation of this file.
1//
2// SPDX-License-Identifier: Apache-2.0
3// [LANL Copyright Statement]
4// Copyright (C) 2022 - 2024 by the ryujin authors
5// Copyright (C) 2023 - 2024 by Triad National Security, LLC
6//
7
8#pragma once
9
10#include <compile_time_options.h>
11
13
14namespace ryujin
15{
16 namespace ShallowWaterInitialStates
17 {
27 template <typename Description, int dim, typename Number>
28 class Uniform : public InitialState<Description, dim, Number>
29 {
30 public:
32 using View =
33 typename Description::template HyperbolicSystemView<dim, Number>;
34 using state_type = typename View::state_type;
35
36 Uniform(const HyperbolicSystem &hyperbolic_system,
37 const std::string subsection)
38 : InitialState<Description, dim, Number>("uniform", subsection)
39 , hyperbolic_system_(hyperbolic_system)
40 {
41 primitive_[0] = 1.;
42 primitive_[1] = 1.;
43 this->add_parameter(
44 "primitive state", primitive_, "Initial 1d primitive state (h, u)");
45 }
46
47 state_type compute(const dealii::Point<dim> & /*point*/,
48 Number /*t*/) final
49 {
50 const auto view = hyperbolic_system_.template view<dim, Number>();
51 return view.from_initial_state(primitive_);
52 }
53
54 /* Default bathymetry of 0 */
55
56 private:
57 const HyperbolicSystem &hyperbolic_system_;
58
59 dealii::Tensor<1, 2, Number> primitive_;
60 };
61
62 } // namespace ShallowWaterInitialStates
63} // namespace ryujin
Uniform(const HyperbolicSystem &hyperbolic_system, const std::string subsection)
typename Description::HyperbolicSystem HyperbolicSystem
state_type compute(const dealii::Point< dim > &, Number) final
typename Description::template HyperbolicSystemView< dim, Number > View
Euler::HyperbolicSystem HyperbolicSystem
Definition: description.h:34