1 #ifndef ERF_BUOYANCY_UTILS_H_
2 #define ERF_BUOYANCY_UTILS_H_
12 const amrex::Array4<const amrex::Real>& r0_arr,
13 const amrex::Array4<const amrex::Real>& th0_arr,
14 const amrex::Array4<const amrex::Real>& cell_data)
24 return (-rho0_wface * grav_gpu * (theta_d_wface - theta_d0_wface) / theta_d0_wface);
32 const amrex::Array4<const amrex::Real>& r0_arr,
33 const amrex::Array4<const amrex::Real>& th0_arr,
34 const amrex::Array4<const amrex::Real>& cell_data,
35 amrex::Array4<amrex::EBCellFlag const>
const& flag)
38 if (flag(i,j,k).isRegular()) {
44 buoyancy = -rho0_wface * grav_gpu * (theta_d_wface - theta_d0_wface) / theta_d0_wface;
45 }
else if (flag(i,j,k).isSingleValued()) {
46 if (flag(i,j,k-1).isCovered()) {
52 buoyancy = -rho0_wface * grav_gpu * (theta_d_wface - theta_d0_wface) / theta_d0_wface;
53 }
else if (flag(i,j,k).isCovered()) {
59 buoyancy = -rho0_wface * grav_gpu * (theta_d_wface - theta_d0_wface) / theta_d0_wface;
66 buoyancy = -rho0_wface * grav_gpu * (theta_d_wface - theta_d0_wface) / theta_d0_wface;
78 const amrex::Array4<const amrex::Real>& r0_arr,
79 const amrex::Array4<const amrex::Real>& th0_arr,
80 const amrex::Array4<const amrex::Real>& qv0_arr,
81 const amrex::Array4<const amrex::Real>& cell_data,
82 const amrex::Array4<const amrex::Real>& qt_arr)
93 amrex::Real th_v_hi = th_d_hi * (
one - Fact*qt_hi - rv_over_rd*qt_hi);
96 amrex::Real th_v_lo = th_d_lo * (
one - Fact*qt_lo - rv_over_rd*qt_lo);
98 amrex::Real th_v0_hi = th0_arr(i,j,k ) * (
one - Fact*qv0_arr(i,j,k ));
99 amrex::Real th_v0_lo = th0_arr(i,j,k-1) * (
one - Fact*qv0_arr(i,j,k-1));
104 amrex::Real q_hi = (qv_hi-qv0_hi) - qt_hi + (th_v_hi - th_v0_hi) / th_v0_hi;
105 amrex::Real q_lo = (qv_lo-qv0_lo) - qt_lo + (th_v_lo - th_v0_lo) / th_v0_lo;
111 return (-r0avg * grav_gpu * qavg);
119 const amrex::Array4<const amrex::Real>& r0_arr,
120 const amrex::Array4<const amrex::Real>& qv0_arr,
121 const amrex::Array4<const amrex::Real>& cell_data,
122 const amrex::Array4<const amrex::Real>& qt_arr)
125 r0_arr(i,j,k ) * (
one + qv0_arr(i,j,k ));
127 r0_arr(i,j,k-1 ) * (
one + qv0_arr(i,j,k-1));
128 return( grav_gpu *
myhalf * ( rhop_hi + rhop_lo ) );
136 const amrex::Array4<const amrex::Real>& r0_arr,
137 const amrex::Array4<const amrex::Real>& qv0_arr,
138 const amrex::Array4<const amrex::Real>& cell_data,
139 const amrex::Array4<const amrex::Real>& qt_arr,
140 amrex::Array4<amrex::EBCellFlag const>
const& flag)
143 if (flag(i,j,k).isRegular()) {
145 r0_arr(i,j,k ) * (
one + qv0_arr(i,j,k ));
147 r0_arr(i,j,k-1 ) * (
one + qv0_arr(i,j,k-1));
148 buoyancy = grav_gpu *
myhalf * ( rhop_hi + rhop_lo );
149 }
else if (flag(i,j,k).isSingleValued()) {
150 if (flag(i,j,k-1).isCovered()) {
152 r0_arr(i,j,k+1 ) * (
one + qv0_arr(i,j,k+1));
154 r0_arr(i,j,k ) * (
one + qv0_arr(i,j,k ));
155 buoyancy = grav_gpu *
myhalf * (
three * rhop_hi - rhop_hihi );
157 }
else if (flag(i,j,k).isCovered()) {
159 r0_arr(i,j,k-1 ) * (
one + qv0_arr(i,j,k-1));
161 r0_arr(i,j,k-2 ) * (
one + qv0_arr(i,j,k-2));
162 buoyancy = grav_gpu *
myhalf * (
three * rhop_lo - rhop_lolo );
166 r0_arr(i,j,k ) * (
one + qv0_arr(i,j,k ));
168 r0_arr(i,j,k-1 ) * (
one + qv0_arr(i,j,k-1));
169 buoyancy = grav_gpu *
myhalf * ( rhop_hi + rhop_lo );
181 const amrex::Array4<const amrex::Real>& r0_arr,
182 const amrex::Array4<const amrex::Real>& p0_arr,
183 const amrex::Array4<const amrex::Real>& th0_arr,
184 const amrex::Array4<const amrex::Real>& cell_data)
198 return ( -r0_avg * grav_gpu * tp_avg);
206 const amrex::Array4<const amrex::Real>& r0_arr,
207 const amrex::Array4<const amrex::Real>& th0_arr,
208 const amrex::Array4<const amrex::Real>& cell_prim)
216 return ( -r0_avg * grav_gpu * thp_avg);
226 const amrex::Array4<const amrex::Real>& r0_arr,
227 const amrex::Array4<const amrex::Real>& th0_arr,
228 const amrex::Array4<const amrex::Real>& qv0_arr,
229 const amrex::Array4<const amrex::Real>& p0_arr,
230 const amrex::Array4<const amrex::Real>& cell_prim,
231 const amrex::Array4<const amrex::Real>& cell_data,
232 const amrex::Array4<const amrex::Real>& qt_arr)
253 return ( -r0avg * grav_gpu * qavg);
262 const amrex::Array4<const amrex::Real>& r0_arr,
263 const amrex::Array4<const amrex::Real>& th0_arr,
264 const amrex::Array4<const amrex::Real>& qv0_arr,
265 const amrex::Array4<const amrex::Real>& cell_prim,
266 const amrex::Array4<const amrex::Real>& qt_arr)
287 return ( -r0avg * grav_gpu * qavg);
300 const amrex::Array4<const amrex::Real>& r0_arr,
301 const amrex::Array4<const amrex::Real>& p0_arr,
302 const amrex::Array4<const amrex::Real>& cell_data)
315 return (-r0_q_avg * grav_gpu);
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_moist_anelastic(int &i, int &j, int &k, amrex::Real const &grav_gpu, amrex::Real const &rv_over_rd, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &qv0_arr, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr)
Definition: ERF_BuoyancyUtils.H:75
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_moist_Tpert(int &i, int &j, int &k, const int &n_qstate, amrex::Real const &grav_gpu, amrex::Real const &rd_over_cp, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &qv0_arr, const amrex::Array4< const amrex::Real > &p0_arr, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr)
Definition: ERF_BuoyancyUtils.H:222
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_moist_Thpert(int &i, int &j, int &k, const int &n_qstate, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &qv0_arr, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< const amrex::Real > &qt_arr)
Definition: ERF_BuoyancyUtils.H:259
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_dry_anelastic(int &i, int &j, int &k, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &cell_data)
Definition: ERF_BuoyancyUtils.H:10
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_rhopert_eb(int &i, int &j, int &k, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &qv0_arr, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr, amrex::Array4< amrex::EBCellFlag const > const &flag)
Definition: ERF_BuoyancyUtils.H:134
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_dry_Thpert(int &i, int &j, int &k, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &cell_prim)
Definition: ERF_BuoyancyUtils.H:204
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_dry_Tpert(int &i, int &j, int &k, amrex::Real const &grav_gpu, amrex::Real const &rd_over_cp, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &p0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &cell_data)
Definition: ERF_BuoyancyUtils.H:178
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_rhopert(int &i, int &j, int &k, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &qv0_arr, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr)
Definition: ERF_BuoyancyUtils.H:117
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_dry_anelastic_T(int &i, int &j, int &k, amrex::Real const &grav_gpu, amrex::Real const &rd_over_cp, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &p0_arr, const amrex::Array4< const amrex::Real > &cell_data)
Definition: ERF_BuoyancyUtils.H:297
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real buoyancy_dry_anelastic_eb(int &i, int &j, int &k, amrex::Real const &grav_gpu, const amrex::Array4< const amrex::Real > &r0_arr, const amrex::Array4< const amrex::Real > &th0_arr, const amrex::Array4< const amrex::Real > &cell_data, amrex::Array4< amrex::EBCellFlag const > const &flag)
Definition: ERF_BuoyancyUtils.H:30
constexpr amrex::Real three
Definition: ERF_Constants.H:11
constexpr amrex::Real one
Definition: ERF_Constants.H:9
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:13
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getRhoThetagivenP(const amrex::Real p, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:172
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getTgivenRandRTh(const amrex::Real rho, const amrex::Real rhotheta, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:46
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getTgivenPandTh(const amrex::Real P, const amrex::Real th, const amrex::Real rdOcp)
Definition: ERF_EOS.H:32
#define PrimQ1_comp
Definition: ERF_IndexDefines.H:58
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define PrimTheta_comp
Definition: ERF_IndexDefines.H:55
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
amrex::Real Real
Definition: ERF_ShocInterface.H:19