Shamrock 2025.10.0
Astrophysical Code
Loading...
Searching...
No Matches
SourceStep.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/vec.hpp"
22
24
25 template<class Tvec, class TgridVec>
26 class SourceStep {
27 public:
28 using Tscal = shambase::VecComponent<Tvec>;
29 using Tgridscal = shambase::VecComponent<TgridVec>;
31
34
35 ShamrockCtx &context;
36 Config &solver_config;
37 Storage &storage;
38
39 SourceStep(ShamrockCtx &context, Config &solver_config, Storage &storage)
40 : context(context), solver_config(solver_config), storage(storage) {}
41
49 void compute_forces();
50
58 void apply_force(Tscal dt);
59
70 void compute_AV();
71
72 void apply_AV(Tscal dt);
73
74 void compute_div_v();
75
76 void update_eint_eos(Tscal dt);
77
78 private:
79 inline PatchScheduler &scheduler() { return shambase::get_check_ref(context.sched); }
80 };
81} // namespace shammodels::zeus::modules
std::uint32_t u32
32 bit unsigned integer
The MPI scheduler.
void compute_forces()
compute general forces (pressure + external and store them into SolverStorage::forces)
void apply_force(Tscal dt)
apply the generalized forces
void compute_AV()
Compute the values of the artificial viscosity terms ( equations 33,34)
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
namespace for the zeus model modules
Definition AMRTree.hpp:23