3 #ifndef ERF_EDDY_VISCOSITY_H_
4 #define ERF_EDDY_VISCOSITY_H_
6 #include "AMReX_BCRec.H"
14 #ifdef ERF_USE_EAMXX_SHOC
18 #ifdef ERF_USE_NATIVE_SHOC
24 const amrex::MultiFab&
xvel ,
25 const amrex::MultiFab&
yvel ,
26 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& Tau_lev,
27 amrex::MultiFab& cons_in,
28 const amrex::MultiFab& wdist,
29 amrex::MultiFab& eddyViscosity,
30 amrex::MultiFab& Hfx1,
31 amrex::MultiFab& Hfx2,
32 amrex::MultiFab& Hfx3,
33 amrex::MultiFab& Diss,
34 const amrex::Geometry& geom,
35 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
36 const std::unique_ptr<amrex::MultiFab>& z_phys_nd,
38 std::unique_ptr<SurfaceLayer>& SurfLayer,
39 const amrex::MultiFab*
z_0,
40 const bool& use_terrain_fitted_coords,
43 const amrex::BCRec* bc_ptr,
45 bool vert_only =
false);
49 const amrex::MultiFab& cons_in,
50 amrex::MultiFab& eddyViscosity,
51 amrex::MultiFab& Hfx1,
52 amrex::MultiFab& Hfx2,
53 amrex::MultiFab& Hfx3,
54 amrex::MultiFab& Diss,
55 const amrex::Geometry& geom,
56 bool use_terrain_fitted_coords,
57 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
58 const std::unique_ptr<amrex::MultiFab>& z_phys_nd,
61 std::unique_ptr<SurfaceLayer>& SurfLayer,
63 const amrex::MultiFab*
xvel =
nullptr,
64 const amrex::MultiFab*
yvel =
nullptr);
68 const amrex::MultiFab& cons_in,
69 amrex::MultiFab& eddyViscosity,
70 amrex::MultiFab& Hfx1,
71 amrex::MultiFab& Hfx2,
72 amrex::MultiFab& Hfx3,
73 const amrex::Geometry& geom,
74 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
78 std::unique_ptr<SurfaceLayer>& SurfLayer,
81 const amrex::MultiFab*
xvel =
nullptr,
82 const amrex::MultiFab*
yvel =
nullptr);
88 const amrex::Array4<amrex::Real const>&
tau11,
89 const amrex::Array4<amrex::Real const>&
tau22,
90 const amrex::Array4<amrex::Real const>&
tau33,
91 const amrex::Array4<amrex::Real const>&
tau12,
92 const amrex::Array4<amrex::Real const>&
tau13,
93 const amrex::Array4<amrex::Real const>&
tau23)
105 amrex::Real SmnSmn = s11bar*s11bar + s22bar*s22bar + s33bar*s33bar
106 +
two*s12bar*s12bar +
two*s13bar*s13bar +
two*s23bar*s23bar;
115 const amrex::Array4<amrex::Real const>&
tau11,
116 const amrex::Array4<amrex::Real const>&
tau22,
117 const amrex::Array4<amrex::Real const>&
tau33,
118 const amrex::Array4<amrex::Real const>&
tau12,
119 const amrex::Array4<amrex::Real const>&
tau13,
120 const amrex::Array4<amrex::Real const>&
tau23,
121 const amrex::Array4<const amrex::EBCellFlag>& c_cflag,
122 const amrex::Array4<const amrex::EBCellFlag>& u_cflag,
123 const amrex::Array4<const amrex::EBCellFlag>& v_cflag,
124 const amrex::Array4<const amrex::EBCellFlag>& w_cflag)
127 if (!c_cflag(i,j,k).isCovered()) {
136 if (!u_cflag(i,j,k).isCovered() || !v_cflag(i,j,k).isCovered()) {
137 s12bar +=
tau12(i,j,k);
140 if (!u_cflag(i+1,j,k).isCovered() || !v_cflag(i,j,k).isCovered()) {
141 s12bar +=
tau12(i+1,j,k);
144 if (!u_cflag(i,j,k).isCovered() || !v_cflag(i,j+1,k).isCovered()) {
145 s12bar +=
tau12(i,j+1,k);
148 if (!u_cflag(i+1,j,k).isCovered() || !v_cflag(i,j+1,k).isCovered()) {
149 s12bar +=
tau12(i+1,j+1,k);
152 if (count_s12 >
zero) {
157 if (!u_cflag(i,j,k).isCovered() || !w_cflag(i,j,k).isCovered()) {
158 s13bar +=
tau13(i, j, k);
161 if (!u_cflag(i,j,k).isCovered() || !w_cflag(i,j,k+1).isCovered()) {
162 s13bar +=
tau13(i, j, k+1);
165 if (!u_cflag(i+1,j,k).isCovered() || !w_cflag(i,j,k).isCovered()) {
166 s13bar +=
tau13(i+1, j, k);
169 if (!u_cflag(i+1,j,k).isCovered() || !w_cflag(i,j,k+1).isCovered()) {
170 s13bar +=
tau13(i+1, j, k+1);
173 if (count_s13 >
zero) {
178 if (!v_cflag(i,j,k).isCovered() || !w_cflag(i,j,k).isCovered()) {
179 s23bar +=
tau23(i, j, k);
182 if (!v_cflag(i,j,k).isCovered() || !w_cflag(i,j,k+1).isCovered()) {
183 s23bar +=
tau23(i, j, k+1);
186 if (!v_cflag(i,j+1,k).isCovered() || !w_cflag(i,j,k).isCovered()) {
187 s23bar +=
tau23(i, j+1, k);
190 if (!v_cflag(i,j+1,k).isCovered() || !w_cflag(i,j,k+1).isCovered()) {
191 s23bar +=
tau23(i, j+1, k+1);
194 if (count_s23 >
zero) {
198 SmnSmn = s11bar*s11bar + s22bar*s22bar + s33bar*s33bar
199 +
two*s12bar*s12bar +
two*s13bar*s13bar +
two*s23bar*s23bar;
209 const amrex::Array4<amrex::Real const>&
tau11,
210 const amrex::Array4<amrex::Real const>&
tau22,
211 const amrex::Array4<amrex::Real const>&
tau12)
216 return myhalf * sdiff*sdiff +
two*s12bar*s12bar;
constexpr amrex::Real two
Definition: ERF_Constants.H:10
constexpr amrex::Real one
Definition: ERF_Constants.H:9
constexpr amrex::Real fourth
Definition: ERF_Constants.H:14
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:13
@ tau12
Definition: ERF_DataStruct.H:32
@ tau23
Definition: ERF_DataStruct.H:32
@ tau33
Definition: ERF_DataStruct.H:32
@ tau22
Definition: ERF_DataStruct.H:32
@ tau11
Definition: ERF_DataStruct.H:32
@ tau13
Definition: ERF_DataStruct.H:32
void ComputeTurbulentViscosity(amrex::Real dt, const amrex::MultiFab &xvel, const amrex::MultiFab &yvel, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Tau_lev, amrex::MultiFab &cons_in, const amrex::MultiFab &wdist, amrex::MultiFab &eddyViscosity, amrex::MultiFab &Hfx1, amrex::MultiFab &Hfx2, amrex::MultiFab &Hfx3, amrex::MultiFab &Diss, const amrex::Geometry &geom, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &mapfac, const std::unique_ptr< amrex::MultiFab > &z_phys_nd, const SolverChoice &solverChoice, std::unique_ptr< SurfaceLayer > &SurfLayer, const amrex::MultiFab *z_0, const bool &use_terrain_fitted_coords, const bool &use_moisture, int level, const amrex::BCRec *bc_ptr, const eb_ &ebfact, bool vert_only=false)
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real ComputeSmnSmn2D(int &i, int &j, int &k, const amrex::Array4< amrex::Real const > &tau11, const amrex::Array4< amrex::Real const > &tau22, const amrex::Array4< amrex::Real const > &tau12)
Definition: ERF_EddyViscosity.H:208
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real ComputeSmnSmn_EB(int &i, int &j, int &k, const amrex::Array4< amrex::Real const > &tau11, const amrex::Array4< amrex::Real const > &tau22, const amrex::Array4< amrex::Real const > &tau33, const amrex::Array4< amrex::Real const > &tau12, const amrex::Array4< amrex::Real const > &tau13, const amrex::Array4< amrex::Real const > &tau23, const amrex::Array4< const amrex::EBCellFlag > &c_cflag, const amrex::Array4< const amrex::EBCellFlag > &u_cflag, const amrex::Array4< const amrex::EBCellFlag > &v_cflag, const amrex::Array4< const amrex::EBCellFlag > &w_cflag)
Definition: ERF_EddyViscosity.H:114
void ComputeTurbulentViscosityLES(amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Tau_lev, const amrex::MultiFab &cons_in, amrex::MultiFab &eddyViscosity, amrex::MultiFab &Hfx1, amrex::MultiFab &Hfx2, amrex::MultiFab &Hfx3, amrex::MultiFab &Diss, const amrex::Geometry &geom, bool use_terrain_fitted_coords, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &mapfac, const std::unique_ptr< amrex::MultiFab > &z_phys_nd, const TurbChoice &turbChoice, const amrex::Real const_grav, std::unique_ptr< SurfaceLayer > &SurfLayer, const MoistureComponentIndices &moisture_indices, const amrex::MultiFab *xvel=nullptr, const amrex::MultiFab *yvel=nullptr)
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real ComputeSmnSmn(int &i, int &j, int &k, const amrex::Array4< amrex::Real const > &tau11, const amrex::Array4< amrex::Real const > &tau22, const amrex::Array4< amrex::Real const > &tau33, const amrex::Array4< amrex::Real const > &tau12, const amrex::Array4< amrex::Real const > &tau13, const amrex::Array4< amrex::Real const > &tau23)
Definition: ERF_EddyViscosity.H:87
void ComputeTurbulentViscosityLES_EB(amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Tau_lev, const amrex::MultiFab &cons_in, amrex::MultiFab &eddyViscosity, amrex::MultiFab &Hfx1, amrex::MultiFab &Hfx2, amrex::MultiFab &Hfx3, const amrex::Geometry &geom, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &mapfac, const TurbChoice &turbChoice, const amrex::Real const_grav, const SolverChoice &solverChoice, std::unique_ptr< SurfaceLayer > &SurfLayer, const MoistureComponentIndices &moisture_indices, const eb_ &ebfact, const amrex::MultiFab *xvel=nullptr, const amrex::MultiFab *yvel=nullptr)
const bool use_moisture
Definition: ERF_InitCustomPert_Bomex.H:14
TurbChoice turbChoice
Definition: ERF_SetupVertDiff.H:6
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Real z_0
Definition: ERF_UpdateWSubsidence_Bomex.H:10
@ xvel
Definition: ERF_IndexDefines.H:175
@ yvel
Definition: ERF_IndexDefines.H:176
Definition: ERF_DataStruct.H:106
Definition: ERF_DataStruct.H:141
Definition: ERF_TurbStruct.H:82