1272 zeta = zref / olen_arr(i,j,k);
1276 if (q_surf_arr(i,j,k) >
zero) {
1277 qv_s = q_surf_arr(i,j,k);
1281 qv_s = qvm_arr(i,j,k);
1283 qv_a = qvm_arr(i,j,k);
1293 -ustar *
mdata.
kappa * (qv_a - qv_s) / (C - psi_h);
1295 w_star_arr(i,j,k) =
calc_wstar(tflux, pblh_arr(i,j,k), tvm_arr(i,j,k));
1297 umm = std::sqrt(umm_arr(i,j,k)*umm_arr(i,j,k) + wstar*wstar);
1298 umm = std::max(umm,
WSMIN);
1305 ( (thv_a - thv_s) / (umm * umm) );
1325 C = std::log(zref / z0_old);
1337 }
while ( (std::abs(
z0 - z0_old) >
tol_z) && (iter_z <= max_iters) );
1338 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(iter_z < max_iters,
1339 "Maximum number of MOST roughness iterations reached.");
1340 C = std::log(zref /
z0);
1350 }
while ( (std::abs(zeta - zeta_old) >
tol) && (iter <= max_iters) );
1351 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(iter < max_iters,
1352 "Maximum number of MOST iterations reached.");
1356 olen_arr(i,j,k) = zref / zeta;
1357 u_star_arr(i,j,k) =
mdata.
kappa * umm / (C - psi_m);
1358 t_star_arr(i,j,k) =
mdata.
kappa * (tm_arr(i,j,k) - t_surf_arr(i,j,k)) / (C - psi_h);
1361 (u_star_arr(i,j,k) *
mdata.
kappa) + qvm_arr(i,j,k);
1364 q_star_arr(i,j,k) =
mdata.
kappa * (qvm_arr(i,j,k) - q_surf_arr(i,j,k)) / (C - psi_h);
constexpr amrex::Real bogus_large_value
Definition: ERF_Constants.H:26
constexpr amrex::Real one
Definition: ERF_Constants.H:9
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
@ num
Definition: ERF_DataStruct.H:24
Real z0
Definition: ERF_InitCustomPertVels_ScalarAdvDiff.H:8
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real COARE3_roughness(amrex::Real zref, amrex::Real umm, amrex::Real ustar)
Definition: ERF_MOSTRoughness.H:9
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real air_viscosity(amrex::Real T_degK)
Definition: ERF_MOSTStress.H:129
amrex::Real Real
Definition: ERF_ShocInterface.H:19
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real calc_wstar(const amrex::Real &ust, const amrex::Real &tst, const amrex::Real &qst, const amrex::Real &pblh, const amrex::Real &th, const amrex::Real &thv, const amrex::Real &qv=amrex::Real(0))
Definition: ERF_Wstar.H:13
@ den
Definition: ERF_AdvanceWSM6.cpp:109
amrex::Real kappa
von Karman constant
Definition: ERF_MOSTStress.H:16
amrex::Real gravity
Acceleration due to gravity (m/s^2)
Definition: ERF_MOSTStress.H:17
const amrex::Real Bjr_beta
Definition: ERF_MOSTStress.H:32
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_h2(amrex::Real zeta) const
Definition: ERF_MOSTStress.H:67
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_m2(amrex::Real zeta) const
Definition: ERF_MOSTStress.H:47
const amrex::Real tol_z
Definition: ERF_MOSTStress.H:1376
const amrex::Real alpha
Definition: ERF_MOSTStress.H:1378
const amrex::Real WSMIN
Definition: ERF_MOSTStress.H:1379
const amrex::Real tol
Definition: ERF_MOSTStress.H:1372
similarity_funs sfuns
Definition: ERF_MOSTStress.H:1371