Function for computing the fast RHS with no terrain and variable vertical spacing
77 BL_PROFILE_REGION(
"erf_substep_S()");
87 bool l_rayleigh_impl_for_w = (sinesq_stag_d !=
nullptr);
89 const Real*
dx = geom.CellSize();
90 const GpuArray<Real, AMREX_SPACEDIM>
dxInv = geom.InvCellSizeArray();
95 auto dz_ptr = stretched_dz_d.data();
98 const auto& dm = S_stage_data[
IntVars::cons].DistributionMap();
100 MultiFab Delta_rho_theta( ba , dm, 1, 1);
101 MultiFab Delta_rho_w (convert(ba,IntVect(0,0,1)), dm, 1, IntVect(1,1,0));
103 MultiFab coeff_A_mf(fast_coeffs, make_alias, 0, 1);
104 MultiFab inv_coeff_B_mf(fast_coeffs, make_alias, 1, 1);
105 MultiFab coeff_C_mf(fast_coeffs, make_alias, 2, 1);
106 MultiFab coeff_P_mf(fast_coeffs, make_alias, 3, 1);
107 MultiFab coeff_Q_mf(fast_coeffs, make_alias, 4, 1);
111 const Array<Real,AMREX_SPACEDIM> grav{
zero,
zero, -gravity};
112 const GpuArray<Real,AMREX_SPACEDIM> grav_gpu{grav[0], grav[1], grav[2]};
132 #pragma omp parallel if (Gpu::notInLaunchRegion())
134 for ( MFIter mfi(S_stage_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
136 const Array4<const Real>& prev_cons = S_prev[
IntVars::cons].const_array(mfi);
137 const Array4<const Real>& prev_zmom = S_prev[
IntVars::zmom].const_array(mfi);
139 const Array4<const Real>& stage_cons = S_stage_data[
IntVars::cons].const_array(mfi);
140 const Array4<const Real>& stage_zmom = S_stage_data[
IntVars::zmom].const_array(mfi);
142 const Array4<Real>& prev_drho_w = Delta_rho_w.array(mfi);
143 const Array4<Real>& prev_drho_theta = Delta_rho_theta.array(mfi);
144 const Array4<Real>& lagged_arr = lagged_delta_rt.array(mfi);
145 const Array4<Real>& theta_extrap = extrap.array(mfi);
146 const Array4<const Real>& prim = S_stage_prim.const_array(mfi);
148 Box gbx = mfi.growntilebox(1);
149 ParallelFor(gbx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
154 theta_extrap(i,j,k) = prev_drho_theta(i,j,k);
156 theta_extrap(i,j,k) = prev_drho_theta(i,j,k) + beta_d *
157 ( prev_drho_theta(i,j,k) - lagged_arr(i,j,k) );
162 theta_extrap(i,j,k) *= (
one + RvOverRd*
qv);
166 lagged_arr(i,j,k) = prev_drho_theta(i,j,k);
171 Box gtbz = mfi.nodaltilebox(2);
172 gtbz.grow(IntVect(1,1,0));
173 ParallelFor(gtbz, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
174 prev_drho_w(i,j,k) = prev_zmom(i,j,k) - stage_zmom(i,j,k);
183 #pragma omp parallel if (Gpu::notInLaunchRegion())
185 for ( MFIter mfi(S_stage_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
187 Box tbx = mfi.nodaltilebox(0);
188 Box tby = mfi.nodaltilebox(1);
190 const Array4<Real const>& xmom_src_arr = xmom_src.const_array(mfi);
191 const Array4<Real const>& ymom_src_arr = ymom_src.const_array(mfi);
193 const Array4<const Real> & stage_xmom = S_stage_data[
IntVars::xmom].const_array(mfi);
194 const Array4<const Real> & stage_ymom = S_stage_data[
IntVars::ymom].const_array(mfi);
195 const Array4<const Real> & qt_arr =
qt.const_array(mfi);
197 const Array4<const Real>& slow_rhs_rho_u = S_slow_rhs[
IntVars::xmom].const_array(mfi);
198 const Array4<const Real>& slow_rhs_rho_v = S_slow_rhs[
IntVars::ymom].const_array(mfi);
200 const Array4<Real>& temp_cur_xmom_arr = temp_cur_xmom.array(mfi);
201 const Array4<Real>& temp_cur_ymom_arr = temp_cur_ymom.array(mfi);
203 const Array4<const Real>& prev_xmom = S_prev[
IntVars::xmom].const_array(mfi);
204 const Array4<const Real>& prev_ymom = S_prev[
IntVars::ymom].const_array(mfi);
207 const Array4< Real>& avg_xmom_arr = avg_xmom.array(mfi);
208 const Array4< Real>& avg_ymom_arr = avg_ymom.array(mfi);
210 const Array4<const Real>& pi_stage_ca = pi_stage.const_array(mfi);
212 const Array4<Real>& theta_extrap = extrap.array(mfi);
215 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
216 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
221 if (nrk == 0 and step == 0) {
223 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
225 Real new_drho_u = dtau * slow_rhs_rho_u(i,j,k) + dtau * xmom_src_arr(i,j,k);;
226 avg_xmom_arr(i,j,k) += facinv*new_drho_u;
227 temp_cur_xmom_arr(i,j,k) = stage_xmom(i,j,k) + new_drho_u;
229 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
231 Real new_drho_v = dtau * slow_rhs_rho_v(i,j,k) + dtau * ymom_src_arr(i,j,k);
232 avg_ymom_arr(i,j,k) += facinv*new_drho_v;
233 temp_cur_ymom_arr(i,j,k) = stage_ymom(i,j,k) + new_drho_v;
237 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
240 Real gpx = (theta_extrap(i,j,k) - theta_extrap(i-1,j,k))*dxi;
243 Real q = (l_use_moisture) ?
myhalf * (qt_arr(i,j,k) + qt_arr(i-1,j,k)) :
zero;
245 Real pi_c =
myhalf * (pi_stage_ca(i-1,j,k,0) + pi_stage_ca(i,j,k,0));
248 Real new_drho_u = prev_xmom(i,j,k) - stage_xmom(i,j,k)
249 + dtau * fast_rhs_rho_u + dtau * slow_rhs_rho_u(i,j,k)
250 + dtau * xmom_src_arr(i,j,k);
252 avg_xmom_arr(i,j,k) += facinv*new_drho_u;
254 temp_cur_xmom_arr(i,j,k) = stage_xmom(i,j,k) + new_drho_u;
256 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
259 Real gpy = (theta_extrap(i,j,k) - theta_extrap(i,j-1,k))*dyi;
262 Real q = (l_use_moisture) ?
myhalf * (qt_arr(i,j,k) + qt_arr(i,j-1,k)) :
zero;
264 Real pi_c =
myhalf * (pi_stage_ca(i,j-1,k,0) + pi_stage_ca(i,j,k,0));
267 Real new_drho_v = prev_ymom(i,j,k) - stage_ymom(i,j,k)
268 + dtau * fast_rhs_rho_v + dtau * slow_rhs_rho_v(i,j,k)
269 + dtau * ymom_src_arr(i,j,k);
271 avg_ymom_arr(i,j,k) += facinv*new_drho_v;
273 temp_cur_ymom_arr(i,j,k) = stage_ymom(i,j,k) + new_drho_v;
279 #pragma omp parallel if (Gpu::notInLaunchRegion())
282 std::array<FArrayBox,AMREX_SPACEDIM> flux;
285 Box bx = mfi.tilebox();
286 Box tbz = surroundingNodes(bx,2);
288 Box vbx = mfi.validbox();
289 const auto& vbx_hi = ubound(vbx);
291 const Array4<Real const>& zmom_src_arr = zmom_src.const_array(mfi);
293 const Array4<const Real>& stage_xmom = S_stage_data[
IntVars::xmom].const_array(mfi);
294 const Array4<const Real>& stage_ymom = S_stage_data[
IntVars::ymom].const_array(mfi);
295 const Array4<const Real>& stage_zmom = S_stage_data[
IntVars::zmom].const_array(mfi);
296 const Array4<const Real> & prim = S_stage_prim.const_array(mfi);
298 const Array4<const Real>& prev_drho_theta = Delta_rho_theta.array(mfi);
300 const Array4<const Real>& prev_cons = S_prev[
IntVars::cons].const_array(mfi);
301 const Array4<const Real>& stage_cons = S_stage_data[
IntVars::cons].const_array(mfi);
303 const Array4<const Real>& slow_rhs_cons = S_slow_rhs[
IntVars::cons].const_array(mfi);
304 const Array4<const Real>& slow_rhs_rho_w = S_slow_rhs[
IntVars::zmom].const_array(mfi);
306 const Array4<const Real>& prev_zmom = S_prev[
IntVars::zmom].const_array(mfi);
307 const Array4< Real>& cur_zmom = S_data[
IntVars::zmom].array(mfi);
309 const Array4<Real>& temp_cur_xmom_arr = temp_cur_xmom.array(mfi);
310 const Array4<Real>& temp_cur_ymom_arr = temp_cur_ymom.array(mfi);
313 const Array4< Real>& avg_zmom_arr = avg_zmom.array(mfi);
316 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
317 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
318 const Array4<const Real>& mf_uy = mapfac[
MapFacType::u_y]->const_array(mfi);
319 const Array4<const Real>& mf_vx = mapfac[
MapFacType::v_x]->const_array(mfi);
322 RHS_fab.resize(tbz,1, The_Async_Arena());
325 soln_fab.resize(tbz,1, The_Async_Arena());
327 auto const& RHS_a = RHS_fab.array();
328 auto const& soln_a = soln_fab.array();
330 auto const& temp_rhs_arr = temp_rhs.array(mfi);
332 auto const& coeffA_a = coeff_A_mf.array(mfi);
333 auto const& inv_coeffB_a = inv_coeff_B_mf.array(mfi);
334 auto const& coeffC_a = coeff_C_mf.array(mfi);
335 auto const& coeffP_a = coeff_P_mf.array(mfi);
336 auto const& coeffQ_a = coeff_Q_mf.array(mfi);
341 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
342 flux[dir].resize(surroundingNodes(bx,dir),2,The_Async_Arena());
343 flux[dir].setVal<RunOn::Device>(0);
345 const GpuArray<const Array4<Real>, AMREX_SPACEDIM>
346 flx_arr{{AMREX_D_DECL(flux[0].array(), flux[1].array(), flux[2].array())}};
349 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
350 Real xflux_lo = (temp_cur_xmom_arr(i ,j,k) - stage_xmom(i ,j,k)) / mf_uy(i ,j,0);
351 Real xflux_hi = (temp_cur_xmom_arr(i+1,j,k) - stage_xmom(i+1,j,k)) / mf_uy(i+1,j,0);
352 Real yflux_lo = (temp_cur_ymom_arr(i,j ,k) - stage_ymom(i,j ,k)) / mf_vx(i,j ,0);
353 Real yflux_hi = (temp_cur_ymom_arr(i,j+1,k) - stage_ymom(i,j+1,k)) / mf_vx(i,j+1,0);
355 Real mfsq = mf_mx(i,j,0) * mf_my(i,j,0);
357 temp_rhs_arr(i,j,k,
Rho_comp ) = ( xflux_hi - xflux_lo ) * dxi * mfsq
358 + ( yflux_hi - yflux_lo ) * dyi * mfsq;
359 temp_rhs_arr(i,j,k,
RhoTheta_comp) = (( xflux_hi * (prim(i,j,k,0) + prim(i+1,j,k,0)) -
360 xflux_lo * (prim(i,j,k,0) + prim(i-1,j,k,0)) ) * dxi * mfsq +
361 ( yflux_hi * (prim(i,j,k,0) + prim(i,j+1,k,0)) -
362 yflux_lo * (prim(i,j,k,0) + prim(i,j-1,k,0)) ) * dyi * mfsq) *
myhalf;
365 (flx_arr[0])(i,j,k,0) = xflux_lo;
366 (flx_arr[0])(i,j,k,1) = (flx_arr[0])(i ,j,k,0) *
myhalf * (prim(i,j,k,0) + prim(i-1,j,k,0));
368 (flx_arr[1])(i,j,k,0) = yflux_lo;
369 (flx_arr[1])(i,j,k,1) = (flx_arr[1])(i,j ,k,0) *
myhalf * (prim(i,j,k,0) + prim(i,j-1,k,0));
372 (flx_arr[0])(i+1,j,k,0) = xflux_hi;
373 (flx_arr[0])(i+1,j,k,1) = (flx_arr[0])(i+1,j,k,0) *
myhalf * (prim(i,j,k,0) + prim(i+1,j,k,0));
376 (flx_arr[1])(i,j+1,k,0) = yflux_hi;
377 (flx_arr[1])(i,j+1,k,1) = (flx_arr[1])(i,j+1,k,0) *
myhalf * (prim(i,j,k,0) + prim(i,j+1,k,0));
382 Box bx_shrunk_in_k = bx;
383 int klo = tbz.smallEnd(2);
384 int khi = tbz.bigEnd(2);
385 bx_shrunk_in_k.setSmall(2,klo+1);
386 bx_shrunk_in_k.setBig(2,
khi-1);
397 ParallelFor(bx_shrunk_in_k, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
399 Real coeff_P = coeffP_a(i,j,k);
400 Real coeff_Q = coeffQ_a(i,j,k);
406 Real Omega_kp1 = prev_zmom(i,j,k+1) - stage_zmom(i,j,k+1);
407 Real Omega_k = prev_zmom(i,j,k ) - stage_zmom(i,j,k );
408 Real Omega_km1 = prev_zmom(i,j,k-1) - stage_zmom(i,j,k-1);
413 Real R0_tmp = coeff_P * prev_drho_theta(i,j,k) + coeff_Q * prev_drho_theta(i,j,k-1)
414 - halfg * ( old_drho_k + old_drho_km1 );
419 +temp_rhs_arr(i,j,k,0) + temp_rhs_arr(i,j,k-1) )
425 R1_tmp += beta_1 * dz_inv * ( (Omega_kp1 - Omega_km1) * halfg
426 -(Omega_kp1*theta_t_hi - Omega_k *theta_t_mid) * coeff_P
427 -(Omega_k *theta_t_mid - Omega_km1*theta_t_lo ) * coeff_Q );
430 RHS_a(i,j,k) = Omega_k + dtau * (slow_rhs_rho_w(i,j,k) + R0_tmp + dtau * beta_2 * R1_tmp + zmom_src_arr(i,j,k));
437 auto const lo = lbound(bx);
438 auto const hi = ubound(bx);
440 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int)
443 RHS_a (i,j,lo.z) = prev_zmom(i,j,lo.z) - stage_zmom(i,j,lo.z)
444 + dtau * slow_rhs_rho_w(i,j,lo.z)
445 + dtau * zmom_src_arr(i,j,lo.z);
448 RHS_a (i,j,hi.z+1) = prev_zmom(i,j,hi.z+1) - stage_zmom(i,j,hi.z+1)
449 + dtau * slow_rhs_rho_w(i,j,hi.z+1)
450 + dtau * zmom_src_arr(i,j,hi.z+1);
454 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int)
457 soln_a(i,j,lo.z) = RHS_a(i,j,lo.z) * inv_coeffB_a(i,j,lo.z);
458 cur_zmom(i,j,lo.z) = stage_zmom(i,j,lo.z) + soln_a(i,j,lo.z);
460 for (
int k = lo.z+1; k <= hi.z+1; k++) {
461 soln_a(i,j,k) = (RHS_a(i,j,k)-coeffA_a(i,j,k)*soln_a(i,j,k-1)) * inv_coeffB_a(i,j,k);
464 cur_zmom(i,j,hi.z+1) = stage_zmom(i,j,hi.z+1) + soln_a(i,j,hi.z+1);
466 for (
int k = hi.z; k >= lo.z; k--) {
467 soln_a(i,j,k) -= ( coeffC_a(i,j,k) * inv_coeffB_a(i,j,k) ) *soln_a(i,j,k+1);
468 cur_zmom(i,j,k) = stage_zmom(i,j,k) + soln_a(i,j,k);
472 for (
int j = lo.y; j <= hi.y; ++j) {
474 for (
int i = lo.x; i <= hi.x; ++i) {
475 soln_a(i,j,lo.z) = RHS_a(i,j,lo.z) * inv_coeffB_a(i,j,lo.z);
478 for (
int k = lo.z+1; k <= hi.z+1; ++k) {
479 for (
int j = lo.y; j <= hi.y; ++j) {
481 for (
int i = lo.x; i <= hi.x; ++i) {
482 soln_a(i,j,k) = (RHS_a(i,j,k)-coeffA_a(i,j,k)*soln_a(i,j,k-1)) * inv_coeffB_a(i,j,k);
486 for (
int j = lo.y; j <= hi.y; ++j) {
488 for (
int i = lo.x; i <= hi.x; ++i) {
489 cur_zmom(i,j,hi.z+1) = stage_zmom(i,j,hi.z+1) + soln_a(i,j,hi.z+1);
492 for (
int k = hi.z; k >= lo.z; --k) {
493 for (
int j = lo.y; j <= hi.y; ++j) {
495 for (
int i = lo.x; i <= hi.x; ++i) {
496 soln_a(i,j,k) -= ( coeffC_a(i,j,k) * inv_coeffB_a(i,j,k) ) * soln_a(i,j,k+1);
497 cur_zmom(i,j,k) = stage_zmom(i,j,k) + soln_a(i,j,k);
502 if (l_rayleigh_impl_for_w) {
503 ParallelFor(bx_shrunk_in_k, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
505 Real damping_coeff = l_damp_coef * dtau * sinesq_stag_d[k];
506 cur_zmom(i,j,k) /= (
one + damping_coeff);
513 const Array4<Real>& prev_drho_w = Delta_rho_w.array(mfi);
514 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
516 Real zflux_lo = beta_2 * soln_a(i,j,k ) + beta_1 * prev_drho_w(i,j,k );
517 Real zflux_hi = beta_2 * soln_a(i,j,k+1) + beta_1 * prev_drho_w(i,j,k+1);
519 avg_zmom_arr(i,j,k) += facinv*zflux_lo / (mf_mx(i,j,0) * mf_my(i,j,0));
521 (flx_arr[2])(i,j,k,0) = zflux_lo / (mf_mx(i,j,0) * mf_my(i,j,0));
522 (flx_arr[2])(i,j,k,1) = (flx_arr[2])(i,j,k,0) *
myhalf * (prim(i,j,k) + prim(i,j,k-1));
526 avg_zmom_arr(i,j,k+1) += facinv * zflux_hi / (mf_mx(i,j,0) * mf_my(i,j,0));
528 (flx_arr[2])(i,j,k+1,0) = zflux_hi / (mf_mx(i,j,0) * mf_my(i,j,0));
529 (flx_arr[2])(i,j,k+1,1) = (flx_arr[2])(i,j,k+1,0) *
myhalf * (prim(i,j,k) + prim(i,j,k+1));
534 temp_rhs_arr(i,j,k,
Rho_comp ) += dz_inv * ( zflux_hi - zflux_lo );
535 temp_rhs_arr(i,j,k,
RhoTheta_comp) +=
myhalf * dz_inv * ( zflux_hi * (prim(i,j,k) + prim(i,j,k+1))
536 - zflux_lo * (prim(i,j,k) + prim(i,j,k-1)) );
541 int strt_comp_reflux = 0;
543 int num_comp_reflux = 1;
544 if (level < finest_level) {
545 fr_as_crse->CrseAdd(mfi,
546 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
547 dx, dtau, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
550 fr_as_fine->FineAdd(mfi,
551 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
552 dx, dtau, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
558 Gpu::streamSynchronize();
565 #pragma omp parallel if (Gpu::notInLaunchRegion())
567 for ( MFIter mfi(S_stage_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
569 const Box& bx = mfi.tilebox();
571 const Array4< Real>& cur_cons = S_data[
IntVars::cons].array(mfi);
572 const Array4<const Real>& prev_cons = S_prev[
IntVars::cons].const_array(mfi);
573 auto const& temp_rhs_arr = temp_rhs.const_array(mfi);
574 auto const& slow_rhs_cons = S_slow_rhs[
IntVars::cons].const_array(mfi);
575 const Array4<Real const>& cc_src_arr = cc_src.const_array(mfi);
578 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
590 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
604 const Array4<Real>& cur_xmom = S_data[
IntVars::xmom].array(mfi);
605 const Array4<Real>& cur_ymom = S_data[
IntVars::ymom].array(mfi);
607 const Array4<Real const>& temp_cur_xmom_arr = temp_cur_xmom.const_array(mfi);
608 const Array4<Real const>& temp_cur_ymom_arr = temp_cur_ymom.const_array(mfi);
610 Box tbx = surroundingNodes(bx,0);
611 Box tby = surroundingNodes(bx,1);
614 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
616 cur_xmom(i,j,k) = temp_cur_xmom_arr(i,j,k);
618 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
620 cur_ymom(i,j,k) = temp_cur_ymom_arr(i,j,k);
constexpr amrex::Real R_v
Definition: ERF_Constants.H:21
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 R_d
Definition: ERF_Constants.H:20
constexpr amrex::Real Gamma
Definition: ERF_Constants.H:29
@ v_x
Definition: ERF_DataStruct.H:24
@ u_y
Definition: ERF_DataStruct.H:25
@ v_y
Definition: ERF_DataStruct.H:25
@ m_y
Definition: ERF_DataStruct.H:25
@ u_x
Definition: ERF_DataStruct.H:24
@ m_x
Definition: ERF_DataStruct.H:24
#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
amrex::GpuArray< Real, AMREX_SPACEDIM > dxInv
Definition: ERF_InitCustomPertVels_ParticleTests.H:17
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)
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);} } })
amrex::Real Real
Definition: ERF_ShocInterface.H:19
AMREX_FORCE_INLINE amrex::IntVect TileNoZ()
Definition: ERF_TileNoZ.H:11
@ gpy
Definition: ERF_IndexDefines.H:169
@ gpx
Definition: ERF_IndexDefines.H:168
@ ymom
Definition: ERF_IndexDefines.H:178
@ cons
Definition: ERF_IndexDefines.H:176
@ zmom
Definition: ERF_IndexDefines.H:179
@ xmom
Definition: ERF_IndexDefines.H:177
@ qt
Definition: ERF_Kessler.H:27
@ qv
Definition: ERF_Kessler.H:28