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 * (1.0 - Fact*qt_hi - rv_over_rd*qt_hi);
96 amrex::Real th_v_lo = th_d_lo * (1.0 - Fact*qt_lo - rv_over_rd*qt_lo);
98 amrex::Real th_v0_hi = th0_arr(i,j,k ) * (1.0 - Fact*qv0_arr(i,j,k ));
99 amrex::Real th_v0_lo = th0_arr(i,j,k-1) * (1.0 - 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>& cell_data,
121 const amrex::Array4<const amrex::Real>& qt_arr)
124 amrex::Real rhop_lo = cell_data(i,j,k-1,
Rho_comp) * (1.0 + qt_arr(i,j,k-1))- r0_arr(i,j,k-1);
125 return( grav_gpu *
amrex::Real(0.5) * ( rhop_hi + rhop_lo ) );
133 const amrex::Array4<const amrex::Real>& r0_arr,
134 const amrex::Array4<const amrex::Real>& cell_data,
135 const amrex::Array4<const amrex::Real>& qt_arr,
136 amrex::Array4<amrex::EBCellFlag const>
const& flag)
139 if (flag(i,j,k).isRegular()) {
141 amrex::Real rhop_lo = cell_data(i,j,k-1,
Rho_comp) * (1.0 + qt_arr(i,j,k-1))- r0_arr(i,j,k-1);
142 buoyancy = grav_gpu *
amrex::Real(0.5) * ( rhop_hi + rhop_lo );
143 }
else if (flag(i,j,k).isSingleValued()) {
144 if (flag(i,j,k-1).isCovered()) {
145 amrex::Real rhop_hihi = cell_data(i,j,k+1,
Rho_comp) * (1.0 + qt_arr(i,j,k+1))- r0_arr(i,j,k+1);
147 buoyancy = grav_gpu * 0.5 * ( 3.0 * rhop_hi - rhop_hihi );
149 }
else if (flag(i,j,k).isCovered()) {
150 amrex::Real rhop_lo = cell_data(i,j,k-1,
Rho_comp) * (1.0 + qt_arr(i,j,k-1))- r0_arr(i,j,k-1);
151 amrex::Real rhop_lolo = cell_data(i,j,k-2,
Rho_comp) * (1.0 + qt_arr(i,j,k-2))- r0_arr(i,j,k-2);
152 buoyancy = grav_gpu * 0.5 * ( 3.0 * rhop_lo - rhop_lolo );
156 amrex::Real rhop_lo = cell_data(i,j,k-1,
Rho_comp) * (1.0 + qt_arr(i,j,k-1))- r0_arr(i,j,k-1);
157 buoyancy = grav_gpu *
amrex::Real(0.5) * ( rhop_hi + rhop_lo );
169 const amrex::Array4<const amrex::Real>& r0_arr,
170 const amrex::Array4<const amrex::Real>& p0_arr,
171 const amrex::Array4<const amrex::Real>& th0_arr,
172 const amrex::Array4<const amrex::Real>& cell_data)
186 return ( -r0_avg * grav_gpu * tp_avg);
194 const amrex::Array4<const amrex::Real>& r0_arr,
195 const amrex::Array4<const amrex::Real>& th0_arr,
196 const amrex::Array4<const amrex::Real>& cell_prim)
204 return ( -r0_avg * grav_gpu * thp_avg);
214 const amrex::Array4<const amrex::Real>& r0_arr,
215 const amrex::Array4<const amrex::Real>& th0_arr,
216 const amrex::Array4<const amrex::Real>& qv0_arr,
217 const amrex::Array4<const amrex::Real>& p0_arr,
218 const amrex::Array4<const amrex::Real>& cell_prim,
219 const amrex::Array4<const amrex::Real>& cell_data,
220 const amrex::Array4<const amrex::Real>& qt_arr)
241 return ( -r0avg * grav_gpu * qavg);
250 const amrex::Array4<const amrex::Real>& r0_arr,
251 const amrex::Array4<const amrex::Real>& th0_arr,
252 const amrex::Array4<const amrex::Real>& qv0_arr,
253 const amrex::Array4<const amrex::Real>& cell_prim,
254 const amrex::Array4<const amrex::Real>& qt_arr)
275 return ( -r0avg * grav_gpu * qavg);
288 const amrex::Array4<const amrex::Real>& r0_arr,
289 const amrex::Array4<const amrex::Real>& p0_arr,
290 const amrex::Array4<const amrex::Real>& cell_data)
303 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:210
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:247
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_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:192
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 > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr, amrex::Array4< amrex::EBCellFlag const > const &flag)
Definition: ERF_BuoyancyUtils.H:131
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:166
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:285
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
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 > &cell_data, const amrex::Array4< const amrex::Real > &qt_arr)
Definition: ERF_BuoyancyUtils.H:117
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getRhoThetagivenP(const amrex::Real p, const amrex::Real qv=0.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=0.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:53
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define PrimTheta_comp
Definition: ERF_IndexDefines.H:50
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
amrex::Real Real
Definition: ERF_ShocInterface.H:19