Function for computing the slow RHS for the evolution equations for the density, potential temperature and momentum.
59 BL_PROFILE_REGION(
"erf_make_sources()");
73 const bool l_use_KE = tc.
use_tke;
76 const Box& domain = geom.Domain();
78 const GpuArray<Real, AMREX_SPACEDIM>
dxInv = geom.InvCellSizeArray();
79 const GpuArray<Real, AMREX_SPACEDIM>
dx = geom.CellSizeArray();
93 bool has_moisture = (solverChoice.
moisture_type != MoistureType::None);
98 Table1D<Real> dptr_r_plane, dptr_t_plane, dptr_qv_plane, dptr_qc_plane;
99 TableData<Real, 1> r_plane_tab, t_plane_tab, qv_plane_tab, qc_plane_tab;
100 bool compute_averages =
false;
101 compute_averages = compute_averages ||
104 if (compute_averages)
112 IntVect ng_c(S_data[
IntVars::cons].nGrowVect()); ng_c[2] = 1;
117 int ncomp = (!has_moisture) ? 2 :
RhoQ2_comp+1;
121 cons_ave.compute_averages(
ZDir(), cons_ave.field());
123 int ncell = cons_ave.ncell_line();
125 Gpu::HostVector< Real> r_plane_h(ncell);
126 Gpu::DeviceVector< Real> r_plane_d(ncell);
128 Gpu::HostVector< Real> t_plane_h(ncell);
129 Gpu::DeviceVector< Real> t_plane_d(ncell);
131 cons_ave.line_average(
Rho_comp , r_plane_h);
134 Gpu::copyAsync(Gpu::hostToDevice, r_plane_h.begin(), r_plane_h.end(), r_plane_d.begin());
135 Gpu::copyAsync(Gpu::hostToDevice, t_plane_h.begin(), t_plane_h.end(), t_plane_d.begin());
137 Real* dptr_r = r_plane_d.data();
138 Real* dptr_t = t_plane_d.data();
140 Box tdomain = domain; tdomain.grow(2,ng_c[2]);
141 r_plane_tab.resize({tdomain.smallEnd(2)}, {tdomain.bigEnd(2)});
142 t_plane_tab.resize({tdomain.smallEnd(2)}, {tdomain.bigEnd(2)});
146 dptr_r_plane = r_plane_tab.table();
147 dptr_t_plane = t_plane_tab.table();
148 ParallelFor(ncell, [=] AMREX_GPU_DEVICE (
int k) noexcept
150 dptr_r_plane(k-
offset) = dptr_r[k];
151 dptr_t_plane(k-
offset) = dptr_t[k];
156 Gpu::HostVector< Real> qv_plane_h(ncell), qc_plane_h(ncell);
157 Gpu::DeviceVector<Real> qv_plane_d(ncell), qc_plane_d(ncell);
160 cons_ave.line_average(
RhoQ1_comp, qv_plane_h);
161 Gpu::copyAsync(Gpu::hostToDevice, qv_plane_h.begin(), qv_plane_h.end(), qv_plane_d.begin());
164 cons_ave.line_average(
RhoQ2_comp, qc_plane_h);
165 Gpu::copyAsync(Gpu::hostToDevice, qc_plane_h.begin(), qc_plane_h.end(), qc_plane_d.begin());
167 Real* dptr_qv = qv_plane_d.data();
168 Real* dptr_qc = qc_plane_d.data();
170 qv_plane_tab.resize({tdomain.smallEnd(2)}, {tdomain.bigEnd(2)});
171 qc_plane_tab.resize({tdomain.smallEnd(2)}, {tdomain.bigEnd(2)});
173 dptr_qv_plane = qv_plane_tab.table();
174 dptr_qc_plane = qc_plane_tab.table();
175 ParallelFor(ncell, [=] AMREX_GPU_DEVICE (
int k) noexcept
177 dptr_qv_plane(k-
offset) = dptr_qv[k];
178 dptr_qc_plane(k-
offset) = dptr_qc[k];
187 int klo = domain.smallEnd(0);
188 int khi = domain.bigEnd(2);
189 int nk =
khi - klo + 2;
190 Gpu::DeviceVector<Real> radiation_flux(nk,
zero);
191 Gpu::DeviceVector<Real> q_integral(nk,
zero);
192 Real* rad_flux = radiation_flux.data();
193 Real* q_int = q_integral.data();
215 #pragma omp parallel if (Gpu::notInLaunchRegion())
220 Box bx = mfi.tilebox();
222 const Array4<const Real>& cell_data = S_data[
IntVars::cons].array(mfi);
223 const Array4<const Real>& cell_prim = S_prim.array(mfi);
224 const Array4<Real> & cell_src = source.array(mfi);
226 const Array4<const Real>&
r0 = r_hse.const_array(mfi);
227 const Array4<const Real>& th0 = th_hse.const_array(mfi);
228 const Array4<const Real>& qv0 = qv_hse.const_array(mfi);
230 const Array4<const Real>& z_cc_arr = z_phys_cc->const_array(mfi);
232 const Array4<const Real>& t_blank_arr = (terrain_blank) ? terrain_blank->const_array(mfi) :
233 Array4<const Real>{};
239 if (solverChoice.
rad_type != RadiationType::None && is_slow_step) {
240 auto const& qheating_arr = qheating_rates->const_array(mfi);
241 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
244 cell_src(i,j,k,
RhoTheta_comp) += cell_data(i,j,k,
Rho_comp) * ( qheating_arr(i,j,k,0) + qheating_arr(i,j,k,1) );
255 if ((is_slow_step && !use_Rayleigh_fast) || (!is_slow_step && use_Rayleigh_fast)) {
260 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
263 Real sinesq = d_sinesq_at_lev[k];
264 cell_src(i, j, k, n) -= dampcoef*sinesq * (
theta -
thetabar[k]) * cell_data(i,j,k,
nr);
274 auto const& rhotheta_src_arr = rhotheta_src->const_array(mfi);
279 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
281 cell_src(i, j, k, n) += cell_data(i,j,k,
nr) * rhotheta_src_arr(i, j, k);
284 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
286 cell_src(i, j, k, n) += rhotheta_src_arr(i, j, k);
292 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
294 cell_src(i, j, k, n) += cell_data(i,j,k,
nr) * rhotheta_src_arr(0, 0, k);
297 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
299 cell_src(i, j, k, n) += rhotheta_src_arr(0, 0, k);
310 auto const& rhoqt_src_arr = rhoqt_src->const_array(mfi);
315 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
317 cell_src(i, j, k, n) += cell_data(i,j,k,
nr) * rhoqt_src_arr(i, j, k);
320 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
322 cell_src(i, j, k, n) += rhoqt_src_arr(i, j, k);
328 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
330 cell_src(i, j, k, n) += cell_data(i,j,k,
nr) * rhoqt_src_arr(0, 0, k);
333 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
335 cell_src(i, j, k, n) += rhoqt_src_arr(0, 0, k);
348 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
350 Real dzInv = (z_cc_arr) ?
one/ (z_cc_arr(i,j,k+1) - z_cc_arr(i,j,k-1)) :
myhalf*
dxInv[2];
351 Real T_hi = dptr_t_plane(k+1) / dptr_r_plane(k+1);
352 Real T_lo = dptr_t_plane(k-1) / dptr_r_plane(k-1);
353 Real wbar_cc =
myhalf * (dptr_wbar_sub[k] + dptr_wbar_sub[k+1]);
354 cell_src(i, j, k, n) -= cell_data(i,j,k,
nr) * wbar_cc * (T_hi - T_lo) * dzInv;
357 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
359 Real dzInv = (z_cc_arr) ?
one/ (z_cc_arr(i,j,k+1) - z_cc_arr(i,j,k-1)) :
myhalf*
dxInv[2];
360 Real T_hi = dptr_t_plane(k+1) / dptr_r_plane(k+1);
361 Real T_lo = dptr_t_plane(k-1) / dptr_r_plane(k-1);
362 Real wbar_cc =
myhalf * (dptr_wbar_sub[k] + dptr_wbar_sub[k+1]);
363 cell_src(i, j, k, n) -= wbar_cc * (T_hi - T_lo) * dzInv;
375 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
377 Real dzInv = (z_cc_arr) ?
one/ (z_cc_arr(i,j,k+1) - z_cc_arr(i,j,k-1)) :
myhalf*
dxInv[2];
378 Real Qv_hi = dptr_qv_plane(k+1) / dptr_r_plane(k+1);
379 Real Qv_lo = dptr_qv_plane(k-1) / dptr_r_plane(k-1);
380 Real Qc_hi = dptr_qc_plane(k+1) / dptr_r_plane(k+1);
381 Real Qc_lo = dptr_qc_plane(k-1) / dptr_r_plane(k-1);
382 Real wbar_cc =
myhalf * (dptr_wbar_sub[k] + dptr_wbar_sub[k+1]);
383 cell_src(i, j, k, nv ) -= cell_data(i,j,k,
nr) * wbar_cc * (Qv_hi - Qv_lo) * dzInv;
384 cell_src(i, j, k, nv+1) -= cell_data(i,j,k,
nr) * wbar_cc * (Qc_hi - Qc_lo) * dzInv;
387 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
389 Real dzInv = (z_cc_arr) ?
one/ (z_cc_arr(i,j,k+1) - z_cc_arr(i,j,k-1)) :
myhalf*
dxInv[2];
390 Real Qv_hi = dptr_qv_plane(k+1) / dptr_r_plane(k+1);
391 Real Qv_lo = dptr_qv_plane(k-1) / dptr_r_plane(k-1);
392 Real Qc_hi = dptr_qc_plane(k+1) / dptr_r_plane(k+1);
393 Real Qc_lo = dptr_qc_plane(k-1) / dptr_r_plane(k-1);
394 Real wbar_cc =
myhalf * (dptr_wbar_sub[k] + dptr_wbar_sub[k+1]);
395 cell_src(i, j, k, nv ) -= wbar_cc * (Qv_hi - Qv_lo) * dzInv;
396 cell_src(i, j, k, nv+1) -= wbar_cc * (Qc_hi - Qc_lo) * dzInv;
404 if (l_use_ndiff && is_slow_step) {
408 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
409 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
413 cell_data, cell_data, cell_src, mf_mx, mf_my);
417 cell_prim, cell_data, cell_src, mf_mx, mf_my);
420 if (l_use_KE && l_diff_KE) {
422 cell_prim, cell_data, cell_src, mf_mx, mf_my);
426 cell_prim, cell_data, cell_src, mf_mx, mf_my);
438 const Array4<const Real>& surface_state_arr = (*surface_state_at_lev).array(mfi);
446 if (solverChoice.
pert_type == PerturbationType::Source && is_slow_step) {
448 const amrex::Array4<const amrex::Real>& pert_cell = turbPert.
pb_cell[level].const_array(mfi);
466 for (
int nt = 1; nt < n_sounding_times; nt++) {
469 if (itime_n == n_sounding_times-1) {
472 itime_np1 = itime_n+1;
475 coeff_n =
one - coeff_np1;
484 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
486 Real nudge = (coeff_n*theta_inp_sound_n[k] + coeff_np1*theta_inp_sound_np1[k]) - (dptr_t_plane(k)/dptr_r_plane(k));
488 cell_src(i, j, k, n) += cell_data(i, j, k,
nr) * nudge;
495 if (solverChoice.
terrain_type == TerrainType::ImmersedForcing &&
496 ((is_slow_step && !use_ImmersedForcing_fast) || (!is_slow_step && use_ImmersedForcing_fast)))
498 const Array4<const Real>& u =
xvel.array(mfi);
499 const Array4<const Real>& v =
yvel.array(mfi);
502 const Real* dx_arr = geom.CellSize();
503 const Real dx_x = dx_arr[0];
504 const Real dx_y = dx_arr[1];
505 const Real dx_z = dx_arr[2];
508 const Real drag_coefficient = alpha_h / std::pow(dx_x*dx_y*dx_z,
one/
three);
522 ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
524 const Real t_blank = t_blank_arr(i, j, k);
525 const Real t_blank_above = t_blank_arr(i, j, k+1);
526 const Real ux_cc_2r =
myhalf * (u(i ,j ,k+1) + u(i+1,j ,k+1));
527 const Real uy_cc_2r =
myhalf * (v(i ,j ,k+1) + v(i ,j+1,k+1));
528 const Real h_windspeed2r = std::sqrt(ux_cc_2r * ux_cc_2r + uy_cc_2r * uy_cc_2r);
534 if (init_surf_temp >
zero) {
535 if (t_blank > 0 && (t_blank_above ==
zero)) {
536 const Real surf_temp = init_surf_temp + surf_heating_rate*time/3600;
538 cell_src(i, j, k-1,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
544 if (t_blank > 0 && (t_blank_above ==
zero)) {
548 Real ustar = h_windspeed2r * kappa / (std::log((
Real(1.5)) * dx_z /
z0) - psi_m);
549 const Real Olen = -ustar * ustar * ustar *
theta / (kappa * ggg * tflux + tiny);
551 const Real zeta_neighbor = (
Real(1.5)) * dx_z / Olen;
556 psi_h_neighbor = sfuns.
calc_psi_h(zeta_neighbor);
557 ustar = h_windspeed2r * kappa / (std::log((
Real(1.5)) * dx_z /
z0) - psi_m);
560 if (!(ustar >
zero && !std::isnan(ustar))) { ustar =
zero; }
561 if (!(ustar <
two && !std::isnan(ustar))) { ustar =
two; }
562 if (psi_h_neighbor > std::log(
Real(1.5) * dx_z /
z0)) { psi_h_neighbor = std::log(
Real(1.5) * dx_z /
z0); }
563 if (psi_h > std::log(
myhalf * dx_z /
z0)) { psi_h = std::log(
myhalf * dx_z /
z0); }
566 const Real thetastar =
theta * ustar * ustar / (kappa * ggg * Olen);
567 const Real surf_temp = theta_neighbor - thetastar / kappa * (std::log((
Real(1.5)) * dx_z /
z0) - psi_h_neighbor);
568 const Real tTarget = surf_temp + thetastar / kappa * (std::log((
myhalf) * dx_z /
z0) - psi_h);
571 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt;
576 if (Olen_in != 1e-8){
577 if (t_blank > 0 && (t_blank_above ==
zero)) {
578 const Real Olen = Olen_in;
580 const Real zeta_neighbor = (
Real(1.5)) * dx_z / Olen;
586 const Real ustar = h_windspeed2r * kappa / (std::log((
Real(1.5)) * dx_z /
z0) - psi_m);
589 const Real thetastar =
theta * ustar * ustar / (kappa * ggg * Olen);
590 const Real surf_temp = theta_neighbor - thetastar / kappa * (std::log((
Real(1.5)) * dx_z /
z0) - psi_h_neighbor);
591 const Real tTarget = surf_temp + thetastar / kappa * (std::log((
myhalf) * dx_z /
z0) - psi_h);
594 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt;
604 if ((solverChoice.
buildings_type == BuildingsType::ImmersedForcing ) &&
605 ((is_slow_step && !use_ImmersedForcing_fast) || (!is_slow_step && use_ImmersedForcing_fast)))
608 const Real* dx_arr = geom.CellSize();
609 const Real dx_x = dx_arr[0];
610 const Real dx_y = dx_arr[1];
614 const Real min_t_blank =
Real(0.005);
619 ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
621 Real t_blank = t_blank_arr(i, j, k);
622 Real t_blank_below = t_blank_arr(i, j, k-1);
623 Real t_blank_above = t_blank_arr(i, j, k+1);
624 Real t_blank_north = t_blank_arr(i , j+1, k);
625 Real t_blank_south = t_blank_arr(i , j-1, k);
626 Real t_blank_east = t_blank_arr(i+1, j , k);
627 Real t_blank_west = t_blank_arr(i-1, j , k);
628 if (t_blank < min_t_blank) { t_blank =
zero; }
629 if (t_blank_below < min_t_blank) { t_blank_below =
zero; }
630 if (t_blank_north < min_t_blank) { t_blank_north =
zero; }
631 if (t_blank_south < min_t_blank) { t_blank_south =
zero; }
632 if (t_blank_east < min_t_blank) { t_blank_east =
zero; }
633 if (t_blank_west < min_t_blank) { t_blank_west =
zero; }
635 Real dx_z = (z_cc_arr) ? (z_cc_arr(i,j,k) - z_cc_arr(i,j,k-1)) :
dx[2];
636 Real drag_coefficient = alpha_h / std::pow(dx_x*dx_y*dx_z,
one/
three);
639 if (init_surf_temp >
zero) {
640 const Real surf_temp = init_surf_temp + surf_heating_rate*time/3600;
641 if (t_blank > 0 && (t_blank_above ==
zero) && (t_blank_below ==
one)) {
643 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
645 }
else if (((t_blank > 0 && t_blank < t_blank_west && t_blank_east ==
zero) ||
646 (t_blank > 0 && t_blank < t_blank_east && t_blank_west ==
zero) ||
647 (t_blank > 0 && t_blank < t_blank_north && t_blank_south ==
zero) ||
648 (t_blank > 0 && t_blank < t_blank_south && t_blank_north ==
zero))) {
653 if ((t_blank < t_blank_north) && (t_blank_north ==
one)) {
655 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
659 if ((t_blank < t_blank_south) && (t_blank_south ==
one)) {
661 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
665 if ((t_blank < t_blank_east) && (t_blank_east ==
one)) {
667 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
671 if ((t_blank < t_blank_west) && (t_blank_west ==
one)) {
673 cell_src(i, j, k,
RhoTheta_comp) -= drag_coefficient * U_s * bc_forcing_rt_srf;
693 Box xybx = makeSlab(bx,2,klo);
694 ParallelFor(xybx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int ) noexcept
700 for (
int k(klo+1); k<=
khi+1; ++k) {
703 Real dz = (z_cc_arr) ?
myhalf * (z_cc_arr(i,j,k) - z_cc_arr(i,j,k-2)) :
dx[2];
704 q_int[lk] = q_int[lk-1] + krad * cell_data(i,j,k-1,
Rho_comp) * cell_data(i,j,k-1,
RhoQ2_comp) *
dz;
707 if ( (qt_lo > qt_i) && (qt_hi < qt_i) ) {
708 zi =
myhalf * (z_cc_arr(i,j,k) + z_cc_arr(i,j,k-1));
715 for (
int k(klo); k<=
khi+1; ++k) {
717 Real z =
myhalf * (z_cc_arr(i,j,k) + z_cc_arr(i,j,k-1));
718 rad_flux[lk] = F1*std::exp(-q_int[lk]) + F0*std::exp(-(q_int_inf - q_int[lk]));
725 for (
int k(klo); k<=
khi; ++k) {
728 Real dzInv = (z_cc_arr) ?
one/ (
myhalf * (z_cc_arr(i,j,k+1) - z_cc_arr(i,j,k-1))) :
dxInv[2];
731 Real dTdt = (rad_flux[lk+1] - rad_flux[lk]) * dzInv / (-cell_data(i,j,k,
Rho_comp)*
Cp_d);
void ApplySpongeZoneBCsForCC(const SpongeChoice &spongeChoice, const Geometry geom, const Box &bx, const Array4< Real > &cell_rhs, const Array4< const Real > &cell_data, const Array4< const Real > &r0, const Array4< const Real > &th0, const Array4< const Real > &qv0, const Array4< const Real > &z_phys_cc, int n_qstate)
Definition: ERF_ApplySpongeZoneBCs.cpp:7
void ApplySurfaceTreatment_BulkCoeff_CC(const Box &bx, const Array4< Real > &cell_rhs, const Array4< const Real > &cons_state, const Array4< const Real > &z_phys_cc, const Array4< const Real > &surface_state_arr)
Definition: ERF_ApplySurfaceTreatment_BulkCoeff.cpp:60
constexpr amrex::Real three
Definition: ERF_Constants.H:9
constexpr amrex::Real KAPPA
Definition: ERF_Constants.H:30
constexpr amrex::Real Cp_d
Definition: ERF_Constants.H:22
constexpr amrex::Real two
Definition: ERF_Constants.H:8
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:11
constexpr amrex::Real CONST_GRAV
Definition: ERF_Constants.H:31
constexpr amrex::Real R_d
Definition: ERF_Constants.H:20
@ thetabar
Definition: ERF_DataStruct.H:98
@ m_y
Definition: ERF_DataStruct.H:25
@ m_x
Definition: ERF_DataStruct.H:24
DirectionSelector< 2 > ZDir
Definition: ERF_DirectionSelector.H:38
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getExnergivenRTh(const amrex::Real rhotheta, const amrex::Real rdOcp, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:156
#define RhoScalar_comp
Definition: ERF_IndexDefines.H:40
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define NDRY
Definition: ERF_IndexDefines.H:13
#define RhoQ2_comp
Definition: ERF_IndexDefines.H:43
#define NSCALARS
Definition: ERF_IndexDefines.H:16
#define PrimTheta_comp
Definition: ERF_IndexDefines.H:50
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
amrex::GpuArray< Real, AMREX_SPACEDIM > dxInv
Definition: ERF_InitCustomPertVels_ParticleTests.H:17
Real z0
Definition: ERF_InitCustomPertVels_ScalarAdvDiff.H:8
const Real dx
Definition: ERF_InitCustomPert_ABL.H:23
const int khi
Definition: ERF_InitCustomPert_Bubble.H:21
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
const Real dz
Definition: ERF_InitCustomPert_Bubble.H:25
ParallelFor(bx, [=] AMREX_GPU_DEVICE(int i, int j, int k) noexcept { const auto prob_lo=geomdata.ProbLo();const auto dx=geomdata.CellSize();const Real x=(prob_lo[0]+(i+myhalf) *dx[0])/mf_m(i, j, 0);const Real z=z_cc(i, j, k);Real L=std::sqrt(std::pow((x - x_c)/x_r, 2)+std::pow((z - z_c)/z_r, 2));if(L<=one) { Real dT=T_pert *(std::cos(PI *L)+one)/two;Real Tbar_hse=p_hse(i, j, k)/(R_d *r_hse(i, j, k));Real theta_perturbed=(Tbar_hse+dT) *std::pow(p_0/p_hse(i, j, k), rdOcp);Real theta_0=(Tbar_hse) *std::pow(p_0/p_hse(i, j, k), rdOcp);if(const_rho) { state_pert(i, j, k, RhoTheta_comp)=r_hse(i, j, k) *(theta_perturbed - theta_0);} else { state_pert(i, j, k, Rho_comp)=getRhoThetagivenP(p_hse(i, j, k))/theta_perturbed - r_hse(i, j, k);} } })
void NumericalDiffusion_Scal(const Box &bx, const int start_comp, const int num_comp, const Real dt, const Real num_diff_coeff, const Array4< const Real > &prim_data, const Array4< const Real > &cell_data, const Array4< Real > &rhs, const Array4< const Real > &mfx_arr, const Array4< const Real > &mfy_arr)
Definition: ERF_NumericalDiffusion.cpp:18
AMREX_FORCE_INLINE IntVect offset(const int face_dir, const int normal)
Definition: ERF_ReadBndryPlanes.cpp:28
amrex::Real Real
Definition: ERF_ShocInterface.H:19
AMREX_FORCE_INLINE amrex::IntVect TileNoZ()
Definition: ERF_TileNoZ.H:11
Definition: ERF_PlaneAverage.H:14
@ qv0_comp
Definition: ERF_IndexDefines.H:67
@ th0_comp
Definition: ERF_IndexDefines.H:66
@ r0_comp
Definition: ERF_IndexDefines.H:63
@ cons
Definition: ERF_IndexDefines.H:176
@ theta
Definition: ERF_MM5.H:20
@ qv
Definition: ERF_Kessler.H:28
@ nc
Definition: ERF_Morrison.H:44
@ nr
Definition: ERF_Morrison.H:45
@ xvel
Definition: ERF_IndexDefines.H:159
@ cons
Definition: ERF_IndexDefines.H:158
@ yvel
Definition: ERF_IndexDefines.H:160
real(c_double), parameter epsilon
Definition: ERF_module_model_constants.F90:12
real(c_double), private rhoi
Definition: ERF_module_mp_morr_two_moment.F90:188
real(kind=kind_phys), parameter, private r0
Definition: ERF_module_mp_wsm6.F90:21
bool rayleigh_damp_T
Definition: ERF_DampingStruct.H:87
amrex::Real rayleigh_dampcoef
Definition: ERF_DampingStruct.H:88
RayleighDampingType rayleigh_damping_type
Definition: ERF_DampingStruct.H:101
amrex::Real if_init_surf_temp
Definition: ERF_DataStruct.H:1145
amrex::Real if_surf_temp_flux
Definition: ERF_DataStruct.H:1144
DampingChoice dampingChoice
Definition: ERF_DataStruct.H:1089
bool spatial_moisture_forcing
Definition: ERF_DataStruct.H:1177
RadiationType rad_type
Definition: ERF_DataStruct.H:1210
amrex::Real if_z0
Definition: ERF_DataStruct.H:1143
bool do_theta_advection
Definition: ERF_DataStruct.H:1172
bool custom_rhotheta_forcing
Definition: ERF_DataStruct.H:1169
bool custom_w_subsidence
Definition: ERF_DataStruct.H:1171
bool nudging_from_input_sounding
Definition: ERF_DataStruct.H:1181
amrex::Real if_Cd_scalar
Definition: ERF_DataStruct.H:1140
bool immersed_forcing_substep
Definition: ERF_DataStruct.H:1136
amrex::Real if_Olen_in
Definition: ERF_DataStruct.H:1147
bool use_num_diff
Definition: ERF_DataStruct.H:1199
bool four_stream_radiation
Definition: ERF_DataStruct.H:1133
bool custom_moisture_forcing
Definition: ERF_DataStruct.H:1170
amrex::Real num_diff_coeff
Definition: ERF_DataStruct.H:1200
amrex::Real if_surf_heating_rate
Definition: ERF_DataStruct.H:1146
amrex::Vector< TurbChoice > turbChoice
Definition: ERF_DataStruct.H:1091
MoistureType moisture_type
Definition: ERF_DataStruct.H:1206
bool custom_forcing_prim_vars
Definition: ERF_DataStruct.H:1175
static BuildingsType buildings_type
Definition: ERF_DataStruct.H:1070
static TerrainType terrain_type
Definition: ERF_DataStruct.H:1067
PerturbationType pert_type
Definition: ERF_DataStruct.H:1196
SpongeChoice spongeChoice
Definition: ERF_DataStruct.H:1090
static InitType init_type
Definition: ERF_DataStruct.H:1061
bool hindcast_surface_bcs
Definition: ERF_DataStruct.H:1252
bool spatial_rhotheta_forcing
Definition: ERF_DataStruct.H:1176
int ave_plane
Definition: ERF_DataStruct.H:1220
std::string sponge_type
Definition: ERF_SpongeStruct.H:60
Definition: ERF_TurbStruct.H:42
bool use_tke
Definition: ERF_TurbStruct.H:430
bool diffuse_tke_3D
Definition: ERF_TurbStruct.H:462
amrex::Vector< amrex::MultiFab > pb_cell
Definition: ERF_TurbPertStruct.H:640
void apply_tpi(const int &lev, const amrex::Box &vbx, const int &comp, const amrex::IndexType &m_ixtype, const amrex::Array4< amrex::Real > &src_arr, const amrex::Array4< amrex::Real const > &pert_cell)
Definition: ERF_TurbPertStruct.H:324
Definition: ERF_MOSTStress.H:40
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_m(amrex::Real zeta) const
Definition: ERF_MOSTStress.H:90
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_h(amrex::Real zeta) const
Definition: ERF_MOSTStress.H:104