Function for computing the implicit contribution to the vertical diffusion of momentum, over terrain.
This function (explicitly instantiated below) handles staggering in x, y, or z through the template parameter, stagdir. NOTE: implicit diffusion of w has remains an experimental feature and has not been tested yet with terrain.
239 BL_PROFILE_VAR(
"ImplicitDiffForMom_T()",ImplicitDiffForMom_T);
256 constexpr
int ioff = (stagdir == 0) ? 1 : 0;
257 constexpr
int joff = (stagdir == 1) ? 1 : 0;
260 int ilo = bx.smallEnd(0);
261 int ihi = bx.bigEnd(0);
262 int jlo = bx.smallEnd(1);
263 int jhi = bx.bigEnd(1);
264 int klo = bx.smallEnd(2);
265 int khi = bx.bigEnd(2);
266 amrex::ignore_unused(ilo, ihi, jlo, jhi);
270 amrex::FArrayBox RHS_fab, soln_fab, coeffG_fab;
271 RHS_fab.resize(bx,1, amrex::The_Async_Arena());
272 soln_fab.resize(bx,1, amrex::The_Async_Arena());
273 coeffG_fab.resize(bx,1, amrex::The_Async_Arena());
274 auto const& RHS_a = RHS_fab.array();
275 auto const& soln_a = soln_fab.array();
276 auto const& coeffG_a = coeffG_fab.array();
278 Real dz_inv = cellSizeInv[2];
287 amrex::ignore_unused(foextrap_on_zlo,foextrap_on_zhi);
290 "Unexpected lower BC for momentum used with implicit vertical diffusion");
292 "Unexpected upper BC for momentum used with implicit vertical diffusion");
294 Real Fact = implicit_fac * dt * dz_inv;
297 ParallelFor(makeSlab(bx,2,0), [=] AMREX_GPU_DEVICE (
int i,
int j,
int)
300 for (
int j(jlo); j<=jhi; ++j) {
301 for (
int i(ilo); i<=ihi; ++i) {
342 Real rhoface, rhoAlpha_lo, rhoAlpha_hi;
343 Real detJface, met_h_zeta_lo, met_h_zeta_hi;
344 Real a_tmp, b_tmp, c_tmp, inv_b2_tmp;
346 detJface =
myhalf * (detJ(i,j,klo) + detJ(i-ioff,j-joff,klo));
349 cell_data, mu_turb, mu_eff,
358 c_tmp = -Fact * gfac * rhoAlpha_hi * dz_inv / met_h_zeta_hi;
360 RHS_a(i,j,klo) = detJface * face_data(i,j,klo);
363 if (ext_dir_on_zlo) {
364 RHS_a(i,j,klo) += Fact * gfac * (tau_corr(i,j,klo+1) - tau_corr(i,j,klo));
367 RHS_a(i,j,klo) =
zero;
370 a_tmp = -
two * Fact * rhoAlpha_lo * dz_inv / met_h_zeta_lo;
371 RHS_a(i,j,klo) +=
two * rhoAlpha_lo * face_data(i,j,klo-1) * dz_inv * dz_inv / met_h_zeta_lo;
373 }
else if (use_SurfLayer) {
375 RHS_a(i,j,klo) += Fact * gfac * (tau_corr(i,j,klo+1) - tau(i,j,klo));
376 RHS_a(i,j,klo) += Fact * tau(i,j,klo);
379 RHS_a(i,j,klo) += Fact * gfac * (tau_corr(i,j,klo+1) - tau_corr(i,j,klo));
382 b_tmp = detJface * rhoface - a_tmp - c_tmp;
385 RHS_a(i,j,klo) /= b_tmp;
386 coeffG_a(i,j,klo) = c_tmp / b_tmp;
391 for (
int k(klo+1); k <
khi; k++) {
392 detJface =
myhalf * (detJ(i,j,k) + detJ(i-ioff,j-joff,k));
395 cell_data, mu_turb, mu_eff,
403 a_tmp = -Fact * rhoAlpha_lo * dz_inv / met_h_zeta_lo;
404 c_tmp = -Fact * rhoAlpha_hi * dz_inv / met_h_zeta_hi;
405 b_tmp = detJface * rhoface - a_tmp - c_tmp;
406 inv_b2_tmp =
one / (b_tmp - a_tmp * coeffG_a(i,j,k-1));
408 RHS_a(i,j,k) = detJface * face_data(i,j,k);
409 RHS_a(i,j,k) += Fact * gfac * (tau_corr(i,j,k+1) - tau_corr(i,j,k));
411 RHS_a(i,j,k) = (RHS_a(i,j,k) - a_tmp * RHS_a(i,j,k-1)) * inv_b2_tmp;
412 coeffG_a(i,j,k) = c_tmp * inv_b2_tmp;
418 detJface =
myhalf * (detJ(i,j,
khi) + detJ(i-ioff,j-joff,
khi));
421 cell_data, mu_turb, mu_eff,
429 a_tmp = -Fact * gfac * rhoAlpha_lo * dz_inv / met_h_zeta_lo;
432 RHS_a(i,j,
khi) = detJface * face_data(i,j,
khi);
433 RHS_a(i,j,
khi) += Fact * gfac * (tau_corr(i,j,
khi+1) - tau_corr(i,j,
khi));
436 if (ext_dir_on_zhi) {
442 c_tmp = -
two * Fact * rhoAlpha_hi * dz_inv / met_h_zeta_hi;
443 RHS_a(i,j,
khi) +=
two * rhoAlpha_hi * face_data(i,j,
khi+1) * dz_inv * dz_inv / met_h_zeta_hi;
447 b_tmp = detJface * rhoface - a_tmp - c_tmp;
448 inv_b2_tmp =
one / (b_tmp - a_tmp * coeffG_a(i,j,
khi-1));
451 soln_a(i,j,
khi) = (RHS_a(i,j,
khi) - a_tmp * RHS_a(i,j,
khi-1)) * inv_b2_tmp;
456 for (
int k(
khi-1); k>=klo; --k) {
457 soln_a(i,j,k) = RHS_a(i,j,k) - coeffG_a(i,j,k) * soln_a(i,j,k+1);
462 for (
int k(klo); k<=
khi; ++k) {
464 face_data(i,j,k) = rhoface * soln_a(i,j,k);
constexpr amrex::Real three
Definition: ERF_Constants.H:11
constexpr amrex::Real two
Definition: ERF_Constants.H:10
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 void getRhoAlphaForFaces(int i, int j, int k, int ioff, int joff, amrex::Real &rhoAlpha_lo, amrex::Real &rhoAlpha_hi, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &mu_turb, const amrex::Real mu_eff, bool l_consA, bool l_turb)
Definition: ERF_GetRhoAlphaForFaces.H:5
#define Rho_comp
Definition: ERF_IndexDefines.H:36
const int khi
Definition: ERF_InitCustomPert_Bubble.H:21
ParallelFor(grown_box, [=] AMREX_GPU_DEVICE(int i, int j, int k) { qrcuten_arr(i, j, k)=Real(0);qscuten_arr(i, j, k)=Real(0);qicuten_arr(i, j, k)=Real(0);})
bool l_turb
Definition: ERF_SetupVertDiff.H:9
bool l_consA
Definition: ERF_SetupVertDiff.H:8
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real Compute_h_zeta_AtKface(const int &i, const int &j, const int &k, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &z_nd)
Definition: ERF_TerrainMetrics.H:184
AMREX_ASSERT_WITH_MESSAGE(wbar_cutoff_min > wbar_cutoff_max, "ERROR: wbar_cutoff_min < wbar_cutoff_max")
@ xvel_bc
Definition: ERF_IndexDefines.H:102
@ foextrap
Definition: ERF_IndexDefines.H:242
@ ext_dir
Definition: ERF_IndexDefines.H:243
@ ext_dir_prim
Definition: ERF_IndexDefines.H:246
Definition: ERF_DiffStruct.H:19
amrex::Real rho0_trans
Definition: ERF_DiffStruct.H:91
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:84
amrex::Real dynamic_viscosity
Definition: ERF_DiffStruct.H:96
DiffChoice diffChoice
Definition: ERF_DataStruct.H:1220
amrex::Vector< TurbChoice > turbChoice
Definition: ERF_DataStruct.H:1223
Definition: ERF_TurbStruct.H:82
bool use_kturb
Definition: ERF_TurbStruct.H:513