Shamrock
2025.10.0
Astrophysical Code
Loading...
Searching...
No Matches
shammodels
ramses
include
shammodels
ramses
modules
AnalysisSodTube.hpp
Go to the documentation of this file.
1
// -------------------------------------------------------//
2
//
3
// SHAMROCK code for hydrodynamics
4
// Copyright (c) 2021-2026 Timothée David--Cléris <tim.shamrock@proton.me>
5
// SPDX-License-Identifier: CeCILL Free Software License Agreement v2.1
6
// Shamrock is licensed under the CeCILL 2.1 License, see LICENSE for more information
7
//
8
// -------------------------------------------------------//
9
10
#pragma once
11
19
#include "
shambackends/typeAliasVec.hpp
"
20
#include "
shambackends/vec.hpp
"
21
#include "
shammodels/ramses/Solver.hpp
"
22
#include "
shamphys/SodTube.hpp
"
23
#include "
shamrock/scheduler/ShamrockCtx.hpp
"
24
25
namespace
shammodels::basegodunov::modules
{
26
27
template
<
class
Tvec,
class
Tgr
id
Vec>
28
class
AnalysisSodTube
{
29
public
:
30
using
Tscal = shambase::VecComponent<Tvec>;
31
using
Tgridscal = shambase::VecComponent<TgridVec>;
32
static
constexpr
u32
dim =
shambase::VectorProperties<Tvec>::dimension
;
33
static
constexpr
u32
split_count =
shambase::pow_constexpr<dim>
(2);
34
35
using
Config
=
SolverConfig<Tvec, TgridVec>
;
36
using
Storage
=
SolverStorage<Tvec, TgridVec, u64>
;
37
using
u_morton =
u64
;
38
using
AMRBlock =
typename
Config::AMRBlock
;
39
40
ShamrockCtx
&context;
41
Config
&solver_config;
42
Storage
&storage;
43
44
shamphys::SodTube
solution;
45
Tvec direction;
46
Tscal time_val;
47
Tscal x_ref;
// shock centered on x_ref
48
Tscal x_min, x_max;
// check only between [x_min, x_max ]
49
50
AnalysisSodTube
(
51
ShamrockCtx
&context,
52
Config
&solver_config,
53
Storage
&storage,
54
shamphys::SodTube
&solution,
55
Tvec direction,
56
Tscal time_val,
57
Tscal x_ref,
58
Tscal x_min,
59
Tscal x_max)
60
: context(context), solver_config(solver_config), storage(storage), solution(solution),
61
direction(direction), time_val(time_val), x_ref(x_ref), x_min(x_min), x_max(x_max) {}
62
63
struct
field_val
{
64
Tscal rho;
65
Tvec v;
66
Tscal P;
67
};
68
69
field_val
compute_L2_dist();
70
71
private
:
72
inline
PatchScheduler
&scheduler() {
return
shambase::get_check_ref
(context.sched); }
73
};
74
75
}
// namespace shammodels::basegodunov::modules
ShamrockCtx.hpp
SodTube.hpp
u32
std::uint32_t u32
32 bit unsigned integer
Definition
aliases_int.hpp:27
u64
std::uint64_t u64
64 bit unsigned integer
Definition
aliases_int.hpp:26
PatchScheduler
The MPI scheduler.
Definition
PatchScheduler.hpp:85
ShamrockCtx
Definition
ShamrockCtx.hpp:42
shammodels::basegodunov::SolverStorage
Definition
SolverStorage.hpp:60
shammodels::basegodunov::modules::AnalysisSodTube
Definition
AnalysisSodTube.hpp:28
shamphys::SodTube
Definition
SodTube.hpp:22
shambase::throw_with_loc
void throw_with_loc(std::string message, SourceLocation loc=SourceLocation{})
Throw an exception and append the source location to it.
Definition
exception.hpp:132
shambase::get_check_ref
T & get_check_ref(const std::unique_ptr< T > &ptr, SourceLocation loc=SourceLocation())
Takes a std::unique_ptr and returns a reference to the object it holds. It throws a std::runtime_erro...
Definition
memory.hpp:110
shammodels::basegodunov::modules
namespace for the basegodunov model modules
Definition
AMRCellInfos.hpp:20
Solver.hpp
sham::VectorProperties
Definition
vec.hpp:25
shammodels::amr::AMRBlock
utility class to handle AMR blocks
Definition
AMRBlock.hpp:35
shammodels::basegodunov::SolverConfig
Definition
SolverConfig.hpp:145
shammodels::basegodunov::modules::AnalysisSodTube::field_val
Definition
AnalysisSodTube.hpp:63
typeAliasVec.hpp
vec.hpp
Generated on Wed May 13 2026 13:21:49 for Shamrock by
1.9.8