/home/runner/work/kynema-sgf/kynema-sgf/src/equation_systems/tke/tke_ops.H Source File

Kynema-SGF API: /home/runner/work/kynema-sgf/kynema-sgf/src/equation_systems/tke/tke_ops.H Source File
Kynema-SGF API v0.1.0
CFD solver for wind plant simulations
Loading...
Searching...
No Matches
tke_ops.H
Go to the documentation of this file.
1#ifndef TKE_OPS_H
2#define TKE_OPS_H
3
7#include "AMReX_REAL.H"
8
9using namespace amrex::literals;
10
11namespace kynema_sgf::pde {
12
16template <>
18{
20 : m_tmodel(tmodel), m_fields(fields)
21 {}
22
24 {
25 auto& mueff = m_fields.mueff;
26 m_tmodel.update_scalar_diff(mueff, TKE::var_name());
27 }
28
31};
32
36template <>
38{
39 PostSolveOp(CFDSim& /*unused*/, PDEFields& fields) : m_fields(fields) {}
40
41 void operator()(const amrex::Real time)
42 {
43 // cppcheck-suppress constVariableReference
44 auto& field = m_fields.field;
45 const auto& repo = field.repo();
46 const int nlevels = repo.num_active_levels();
47 const auto clip_value = m_clip_value;
48 for (int lev = 0; lev < nlevels; ++lev) {
49 const auto& field_arrs = field(lev).arrays();
50 amrex::ParallelFor(
51 field(lev), [=] AMREX_GPU_DEVICE(int nbx, int i, int j, int k) {
52 field_arrs[nbx](i, j, k) =
53 (field_arrs[nbx](i, j, k) < 0.0_rt)
54 ? clip_value
55 : field_arrs[nbx](i, j, k);
56 });
57 const bool has_terrain = repo.int_field_exists("terrain_blank");
58 if (has_terrain) {
59 const IntField& m_terrain_blank =
60 repo.get_int_field("terrain_blank");
61 const auto& blank_arrs = m_terrain_blank(lev).arrays();
62 amrex::ParallelFor(
63 field(lev),
64 [=] AMREX_GPU_DEVICE(int nbx, int i, int j, int k) {
65 field_arrs[nbx](i, j, k) =
66 (blank_arrs[nbx](i, j, k) == 1)
67 ? clip_value
68 : field_arrs[nbx](i, j, k);
69 });
70 }
71 }
72 amrex::Gpu::streamSynchronize();
73 m_fields.field.fillpatch(time);
74 }
75
77 amrex::Real m_clip_value{std::numeric_limits<float>::epsilon()};
78};
79
80template <typename Scheme>
81struct FieldRegOp<TKE, Scheme>
82{
83 explicit FieldRegOp(CFDSim& sim_in) : sim(sim_in)
84 {
85 amrex::ParmParse pp("TKE");
86
87 std::string interpolation;
88 pp.query("interpolation", interpolation);
89
90 if (interpolation == "PiecewiseConstant") {
92 amrex::Print()
93 << "using PiecewiseConstant interpolation for TKE fillpatch"
94 << '\n';
95 } else {
96 amrex::Print() << "using default CellConsLinear interpolation for "
97 "TKE fillpatch"
98 << '\n';
99 }
100 }
101
103 {
104 auto& repo = sim.repo();
105 auto fields = create_fields_instance<TKE, Scheme>(time, repo, m_itype);
106
107 repo.declare_cc_field(
108 TKE::var_name() + "_lhs_src_term", TKE::ndim, 1, 1);
109
110 sim.io_manager().register_io_var(fields.field.name());
111
112 return fields;
113 }
114
117};
118
122template <typename Scheme>
123struct DiffusionOp<TKE, Scheme> : public DiffSolverIface<typename TKE::MLDiffOp>
124{
125 static_assert(
126 TKE::ndim == 1, "DiffusionOp invoked for non-scalar TKE type");
127 static_assert(
128 std::is_same_v<typename TKE::MLDiffOp, amrex::MLABecLaplacian>,
129 "Invalid linear operator for scalar diffusion operator");
130
132 PDEFields& fields, const bool has_overset, const bool mesh_mapping)
133 : DiffSolverIface<typename TKE::MLDiffOp>(
134 fields, has_overset, mesh_mapping)
136 fields.repo.get_field(TKE::var_name() + "_lhs_src_term"))
137 {
138 this->m_solver->setDomainBC(
140 this->m_pdefields.field, amrex::Orientation::low),
142 this->m_pdefields.field, amrex::Orientation::high));
143 this->m_applier->setDomainBC(
145 this->m_pdefields.field, amrex::Orientation::low),
147 this->m_pdefields.field, amrex::Orientation::high));
148
149 m_lhs_src_term.setVal(0.0_rt);
150
152 }
153
155 void compute_diff_term(const FieldState fstate)
156 {
157 this->setup_operator(*this->m_applier, 0.0_rt, -1.0_rt, fstate);
158
159 auto tau_state =
160 std::is_same_v<Scheme, fvm::Godunov> ? FieldState::New : fstate;
161 amrex::MLMG mlmg(*this->m_applier);
162 mlmg.apply(
163 this->m_pdefields.diff_term.state(tau_state).vec_ptrs(),
164 this->m_pdefields.field.vec_ptrs());
165 }
166
167 void
168 set_acoeffs(typename TKE::MLDiffOp& linop, const FieldState fstate) override
169 {
170 BL_PROFILE("kynema-sgf::pde::set_acoeffs");
171 auto& repo = m_pdefields.repo;
172
173 const int nlevels = repo.num_active_levels();
174 auto& density = m_density.state(fstate);
176 *m_lhs_total, 1.0_rt, m_lhs_src_term, 0, 1.0_rt, density, 0, 0, 1,
177 1);
178
179 for (int lev = 0; lev < nlevels; ++lev) {
180 linop.setACoeffs(lev, (*m_lhs_total)(lev));
181 }
182 }
183
185 std::unique_ptr<ScratchField> m_lhs_total;
186};
187
188} // namespace kynema_sgf::pde
189
190#endif /* TKE_OPS_H */
Definition CFDSim.H:55
Definition Field.H:112
std::unique_ptr< ScratchField > create_scratch_field(const std::string &name, int ncomp=1, int nghost=0, FieldLoc floc=FieldLoc::CELL) const
Definition FieldRepo.cpp:305
Definition IntField.H:20
Definition SimTime.H:33
virtual void setup_operator(TKE::MLDiffOp &linop, amrex::Real alpha, amrex::Real beta, FieldState fstate)
Definition DiffusionOps.cpp:57
std::unique_ptr< TKE::MLDiffOp > m_solver
Definition DiffusionOps.H:107
std::unique_ptr< TKE::MLDiffOp > m_applier
Definition DiffusionOps.H:108
PDEFields & m_pdefields
Definition DiffusionOps.H:100
DiffSolverIface(PDEFields &fields, bool has_overset, bool mesh_mapping, const std::string &prefix="diffusion")
Definition DiffusionOps.cpp:12
Field & m_density
Definition DiffusionOps.H:101
Definition TurbulenceModel.H:32
void lincomb(T1 &dst, const amrex::Real a, const T2 &x, const int xcomp, const amrex::Real b, const T3 &y, const int ycomp, const int dstcomp, const int numcomp, const amrex::IntVect &nghost)
Definition field_ops.H:320
FieldState
Definition FieldDescTypes.H:16
FieldInterpolator
Coarse-to-fine field interpolation options.
Definition FieldDescTypes.H:39
@ New
Same as FieldState::NP1.
Definition FieldDescTypes.H:22
@ PiecewiseConstant
Constant across cell.
Definition FieldDescTypes.H:40
@ CellConsLinear
Linear interpolation.
Definition FieldDescTypes.H:41
amrex::Array< amrex::LinOpBCType, AMREX_SPACEDIM > get_diffuse_scalar_bc(kynema_sgf::Field &scalar, amrex::Orientation::Side side)
Definition incflo_diffusion.cpp:72
Definition AdvOp_Godunov.H:22
PDEFields create_fields_instance(const SimTime &time, FieldRepo &repo, const FieldInterpolator itype=FieldInterpolator::CellConsLinear)
Definition PDEHelpers.H:52
Field & m_lhs_src_term
Definition tke_ops.H:184
std::unique_ptr< ScratchField > m_lhs_total
Definition tke_ops.H:185
void compute_diff_term(const FieldState fstate)
Computes the diffusion term that goes in the RHS.
Definition tke_ops.H:155
DiffusionOp(PDEFields &fields, const bool has_overset, const bool mesh_mapping)
Definition tke_ops.H:131
void set_acoeffs(typename TKE::MLDiffOp &linop, const FieldState fstate) override
Definition tke_ops.H:168
CFDSim & sim
Definition tke_ops.H:115
PDEFields operator()(const SimTime &time)
Definition tke_ops.H:102
FieldRegOp(CFDSim &sim_in)
Definition tke_ops.H:83
FieldInterpolator m_itype
Definition tke_ops.H:116
Definition PDEFields.H:27
FieldRepo & repo
Reference to the field repository instance.
Definition PDEFields.H:31
amrex::Real m_clip_value
Definition tke_ops.H:77
PostSolveOp(CFDSim &, PDEFields &fields)
Definition tke_ops.H:39
PDEFields & m_fields
Definition tke_ops.H:76
void operator()(const amrex::Real time)
Definition tke_ops.H:41
Definition TKE.H:36
amrex::MLABecLaplacian MLDiffOp
Definition TKE.H:37
static std::string var_name()
Definition TKE.H:41
static constexpr int ndim
Definition TKE.H:45
void operator()()
Definition tke_ops.H:23
TurbulenceOp(turbulence::TurbulenceModel &tmodel, PDEFields &fields)
Definition tke_ops.H:19
turbulence::TurbulenceModel & m_tmodel
Definition tke_ops.H:29
PDEFields & m_fields
Definition tke_ops.H:30