1418 if (u_star_arr(i,j,k) == 1.E34) { olen_arr(i,j,k) = 1.0e3; }
1419 zeta = zref / olen_arr(i,j,k);
1423 if (q_surf_arr(i,j,k) > 0.) {
1424 qv_s = q_surf_arr(i,j,k);
1428 qv_s = qvm_arr(i,j,k);
1430 qv_a = qvm_arr(i,j,k);
1440 -ustar *
mdata.
kappa * (qv_a - qv_s) / (C - psi_h);
1441 amrex::Real tflux = -ustar*tstar*(1 + 0.61*qvm_arr(i,j,k)) + 0.61*tm_arr(i,j,k)*qflux;
1442 w_star_arr(i,j,k) =
calc_wstar(tflux, pblh_arr(i,j,k), tvm_arr(i,j,k));
1444 umm = std::sqrt(umm_arr(i,j,k)*umm_arr(i,j,k) + wstar*wstar);
1445 umm = std::max(umm,
WSMIN);
1449 amrex::Real thv_s = t_surf_arr(i,j,k) * (1.0 + 0.61*qv_s);
1450 amrex::Real thv_a = tm_arr(i,j,k) * (1.0 + 0.61*qv_a);
1452 ( (thv_a - thv_s) / (umm * umm) );
1453 Rib = std::min(std::max(Rib,-4.0),4.0);
1472 C = std::log(zref / z0_old);
1477 }
while ( (std::abs(z0 - z0_old) >
tol_z) && (iter_z <= max_iters) );
1478 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(iter_z < max_iters,
1479 "Maximum number of MOST roughness iterations reached.");
1480 C = std::log(zref / z0);
1483 num = std::max(C - psi_m, 1.0);
1484 den = std::max(C - psi_h, 1.0);
1490 }
while ( (std::abs(zeta - zeta_old) >
tol) && (iter <= max_iters) );
1491 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(iter < max_iters,
1492 "Maximum number of MOST iterations reached.");
1496 olen_arr(i,j,k) = zref / zeta;
1497 u_star_arr(i,j,k) =
mdata.
kappa * umm / (C - psi_m);
1498 t_star_arr(i,j,k) =
mdata.
kappa * (tm_arr(i,j,k) - t_surf_arr(i,j,k)) / (C - psi_h);
1501 (u_star_arr(i,j,k) *
mdata.
kappa) + qvm_arr(i,j,k);
1504 q_star_arr(i,j,k) =
mdata.
kappa * (qvm_arr(i,j,k) - q_surf_arr(i,j,k)) / (C - psi_h);
@ num
Definition: ERF_DataStruct.H:24
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=0.0)
Definition: ERF_Wstar.H:13
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
similarity_funs sfuns
Definition: ERF_MOSTStress.H:1511
const amrex::Real tol
Definition: ERF_MOSTStress.H:1512
const amrex::Real tol_z
Definition: ERF_MOSTStress.H:1513
const amrex::Real WSMIN
Definition: ERF_MOSTStress.H:1515
const amrex::Real alpha
Definition: ERF_MOSTStress.H:1514