Shamrock 2025.10.0
Astrophysical Code
Loading...
Searching...
No Matches
ModifierApplyDiscWarp.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
24
26 template<class Tvec, template<class> class SPHKernel>
28 using Tscal = shambase::VecComponent<Tvec>;
30
32
33 ShamrockCtx &context;
34
35 SetupNodePtr parent;
36
37 Tscal Rwarp_;
38 Tscal Hwarp_;
39 Tscal inclination_;
40 Tscal posangle_;
41
42 public:
44 ShamrockCtx &context,
45 Config &solver_config,
46 SetupNodePtr parent,
47 Tscal Rwarp,
48 Tscal Hwarp,
49 Tscal inclination,
50 Tscal posangle)
51 : context(context), parent(parent), Rwarp_(Rwarp), Hwarp_(Hwarp),
52 inclination_(inclination), posangle_(posangle) {}
53
54 bool is_done() { return parent->is_done(); }
55
57
58 std::string get_name() { return "ApplyDiscWarp"; }
60 return ISPHSetupNode_Dot{get_name(), 2, {parent->get_dot_subgraph()}};
61 }
62 };
63} // namespace shammodels::sph::modules
std::uint32_t u32
32 bit unsigned integer
This class is an interface that all SPH setup nodes must implement. It describe an operation associat...
bool is_done()
This function return true if the setup is done.
std::string get_name()
Get the name of the node.
shamrock::patch::PatchDataLayer next_n(u32 nmax)
This function generate patchdata with at most nmax per MPI ranks This function is always assumed as c...
ISPHSetupNode_Dot get_dot_subgraph()
Get a dot subgraph describing the node and its childrens (recursively)
PatchDataLayer container class, the layout is described in patchdata_layout.
namespace for the sph model modules
std::shared_ptr< ISPHSetupNode > SetupNodePtr
Alias for a shared pointer to an ISPHSetupNode.
The configuration for a sph solver.
This struct is used to generate a dot graph of the setup tree.