ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_EddyViscosity.H
Go to the documentation of this file.
1 /** \file ERF_EddyViscosity.H */
2 
3 #ifndef ERF_EDDY_VISCOSITY_H_
4 #define ERF_EDDY_VISCOSITY_H_
5 
6 #include "AMReX_BCRec.H"
7 #include "ERF_SurfaceLayer.H"
8 #include "ERF_DataStruct.H"
9 #include "ERF_IndexDefines.H"
10 #include "ERF_Constants.H"
11 #include "ERF_EOS.H"
12 
13 #ifdef ERF_USE_SHOC
14 #include "ERF_ShocInterface.H"
15 #endif
16 
17 void
19  const amrex::MultiFab& xvel ,
20  const amrex::MultiFab& yvel ,
21  amrex::Vector<std::unique_ptr<amrex::MultiFab>>& Tau_lev,
22  amrex::MultiFab& cons_in,
23  const amrex::MultiFab& wdist,
24  amrex::MultiFab& eddyViscosity,
25  amrex::MultiFab& Hfx1,
26  amrex::MultiFab& Hfx2,
27  amrex::MultiFab& Hfx3,
28  amrex::MultiFab& Diss,
29  const amrex::Geometry& geom,
30  amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
31  const std::unique_ptr<amrex::MultiFab>& z_phys_nd,
32  const SolverChoice& solverChoice,
33  std::unique_ptr<SurfaceLayer>& SurfLayer,
34  const amrex::MultiFab* z_0,
35  const bool& use_terrain_fitted_coords,
36  const bool& use_moisture,
37  int level,
38  const amrex::BCRec* bc_ptr,
39  bool vert_only = false);
40 
41 void
42 ComputeTurbulentViscosityLES (amrex::Vector<std::unique_ptr<amrex::MultiFab>>& Tau_lev,
43  const amrex::MultiFab& cons_in,
44  amrex::MultiFab& eddyViscosity,
45  amrex::MultiFab& Hfx1,
46  amrex::MultiFab& Hfx2,
47  amrex::MultiFab& Hfx3,
48  amrex::MultiFab& Diss,
49  const amrex::Geometry& geom,
50  bool use_terrain_fitted_coords,
51  amrex::Vector<std::unique_ptr<amrex::MultiFab>>& mapfac,
52  const std::unique_ptr<amrex::MultiFab>& z_phys_nd,
53  const TurbChoice& turbChoice,
54  const amrex::Real const_grav,
55  std::unique_ptr<SurfaceLayer>& SurfLayer,
56  const MoistureComponentIndices& moisture_indices,
57  const amrex::MultiFab* xvel = nullptr,
58  const amrex::MultiFab* yvel = nullptr);
59 
60 AMREX_GPU_DEVICE
61 AMREX_FORCE_INLINE
63 ComputeSmnSmn (int& i, int& j, int& k,
64  const amrex::Array4<amrex::Real const>& tau11,
65  const amrex::Array4<amrex::Real const>& tau22,
66  const amrex::Array4<amrex::Real const>& tau33,
67  const amrex::Array4<amrex::Real const>& tau12,
68  const amrex::Array4<amrex::Real const>& tau13,
69  const amrex::Array4<amrex::Real const>& tau23)
70 {
71  amrex::Real s11bar = tau11(i,j,k);
72  amrex::Real s22bar = tau22(i,j,k);
73  amrex::Real s33bar = tau33(i,j,k);
74  amrex::Real s12bar = 0.25 * ( tau12(i , j , k ) + tau12(i , j+1, k )
75  + tau12(i+1, j , k ) + tau12(i+1, j+1, k ) );
76  amrex::Real s13bar = 0.25 * ( tau13(i , j , k ) + tau13(i , j , k+1)
77  + tau13(i+1, j , k ) + tau13(i+1, j , k+1) );
78  amrex::Real s23bar = 0.25 * ( tau23(i , j , k ) + tau23(i , j , k+1)
79  + tau23(i , j+1, k ) + tau23(i , j+1, k+1) );
80 
81  amrex::Real SmnSmn = s11bar*s11bar + s22bar*s22bar + s33bar*s33bar
82  + 2.0*s12bar*s12bar + 2.0*s13bar*s13bar + 2.0*s23bar*s23bar;
83 
84  return SmnSmn;
85 }
86 
87 AMREX_GPU_DEVICE
88 AMREX_FORCE_INLINE
90 ComputeSmnSmn2D (int& i, int& j, int& k,
91  const amrex::Array4<amrex::Real const>& tau11,
92  const amrex::Array4<amrex::Real const>& tau22,
93  const amrex::Array4<amrex::Real const>& tau12)
94 {
95  amrex::Real sdiff = tau11(i,j,k) - tau22(i,j,k);
96  amrex::Real s12bar = 0.25 * ( tau12(i , j , k ) + tau12(i , j+1, k )
97  + tau12(i+1, j , k ) + tau12(i+1, j+1, k ) );
98  return 0.5 * sdiff*sdiff + 2.0*s12bar*s12bar;
99 }
100 #endif
@ 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
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:90
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, bool vert_only=false)
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:63
TurbChoice turbChoice
Definition: ERF_SetupVertDiff.H:5
amrex::Real Real
Definition: ERF_ShocInterface.H:19
@ xvel
Definition: ERF_IndexDefines.H:141
@ yvel
Definition: ERF_IndexDefines.H:142
Definition: ERF_DataStruct.H:99
Definition: ERF_DataStruct.H:123
Definition: ERF_TurbStruct.H:41