3 #ifndef ERF_EDDY_VISCOSITY_H_
4 #define ERF_EDDY_VISCOSITY_H_
6 #include "AMReX_BCRec.H"
15 const amrex::MultiFab&
yvel ,
16 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& Tau_lev,
17 const amrex::MultiFab& cons_in,
18 const amrex::MultiFab& wdist,
19 amrex::MultiFab& eddyViscosity,
20 amrex::MultiFab& Hfx1,
21 amrex::MultiFab& Hfx2,
22 amrex::MultiFab& Hfx3,
23 amrex::MultiFab& Diss,
24 const amrex::Geometry& geom,
25 amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
26 const std::unique_ptr<amrex::MultiFab>& z_phys_nd,
28 std::unique_ptr<SurfaceLayer>& SurfLayer,
29 const amrex::FArrayBox* z_0,
30 const bool& use_terrain_fitted_coords,
31 const bool& use_moisture,
33 const amrex::BCRec* bc_ptr,
34 bool vert_only =
false);
40 const amrex::Array4<amrex::Real const>&
tau11,
41 const amrex::Array4<amrex::Real const>&
tau22,
42 const amrex::Array4<amrex::Real const>&
tau33,
43 const amrex::Array4<amrex::Real const>&
tau12,
44 const amrex::Array4<amrex::Real const>&
tau13,
45 const amrex::Array4<amrex::Real const>&
tau23)
47 amrex::Real s11bar =
tau11(i,j,k);
48 amrex::Real s22bar =
tau22(i,j,k);
49 amrex::Real s33bar =
tau33(i,j,k);
50 amrex::Real s12bar = 0.25 * (
tau12(i , j , k ) +
tau12(i , j+1, k )
52 amrex::Real s13bar = 0.25 * (
tau13(i , j , k ) +
tau13(i , j , k+1)
54 amrex::Real s23bar = 0.25 * (
tau23(i , j , k ) +
tau23(i , j , k+1)
57 amrex::Real SmnSmn = s11bar*s11bar + s22bar*s22bar + s33bar*s33bar
58 + 2.0*s12bar*s12bar + 2.0*s13bar*s13bar + 2.0*s23bar*s23bar;
67 const amrex::Array4<amrex::Real const>&
tau11,
68 const amrex::Array4<amrex::Real const>&
tau22,
69 const amrex::Array4<amrex::Real const>&
tau12)
71 amrex::Real sdiff =
tau11(i,j,k) -
tau22(i,j,k);
72 amrex::Real s12bar = 0.25 * (
tau12(i , j , k ) +
tau12(i , j+1, k )
74 return 0.5 * sdiff*sdiff + 2.0*s12bar*s12bar;
@ tau12
Definition: ERF_DataStruct.H:30
@ tau23
Definition: ERF_DataStruct.H:30
@ tau33
Definition: ERF_DataStruct.H:30
@ tau22
Definition: ERF_DataStruct.H:30
@ tau11
Definition: ERF_DataStruct.H:30
@ tau13
Definition: ERF_DataStruct.H:30
void ComputeTurbulentViscosity(const amrex::MultiFab &xvel, const amrex::MultiFab &yvel, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Tau_lev, const 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::FArrayBox *z_0, const bool &use_terrain_fitted_coords, const bool &use_moisture, int level, const amrex::BCRec *bc_ptr, 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:66
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:39
@ xvel
Definition: ERF_IndexDefines.H:141
@ yvel
Definition: ERF_IndexDefines.H:142
Definition: ERF_DataStruct.H:123