1 #ifndef ERF_SAM_UTILS_H_
2 #define ERF_SAM_UTILS_H_
7 #include <AMReX_Array4.H>
8 #include <AMReX_GpuQualifiers.H>
157 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
164 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
170 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
181 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
197 result.theta = rho_theta /
rho;
201 result.qn = result.qcl + result.qci;
202 result.qt = result.qv + result.qn;
206 result.qp = result.qpr + result.qps + result.qpg;
212 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
214 const amrex::Array4<amrex::Real>& states_arr,
217 const int k) noexcept
222 states_arr(i,j,k,
RhoTheta_comp) = primitive.rho * primitive.theta;
231 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
234 return moisture_type == MoistureType::SAM_NoIce ||
235 moisture_type == MoistureType::SAM_NoPrecip_NoIce;
238 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
241 return moisture_type == MoistureType::SAM_NoPrecip_NoIce;
244 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
253 if (SAM_moisture_type == 2) {
262 return an *
tabs - bn;
265 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
271 if (SAM_moisture_type == 2) {
277 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
283 if (SAM_moisture_type == 2) {
289 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
310 if (SAM_moisture_type == 1) {
313 result.delta_qi =
qci;
315 result.qcl += result.delta_qi;
316 result.tabs -= fac_fus * result.delta_qi;
319 result.delta_qc =
qcl;
321 result.qci += result.delta_qc;
322 result.tabs += fac_fus * result.delta_qc;
324 result.delta_qc =
qcl -
qn * result.omn;
325 result.delta_qi =
qci -
qn * (
one - result.omn);
326 result.qcl =
qn * result.omn;
327 result.qci =
qn * (
one - result.omn);
328 result.tabs += fac_fus * result.delta_qc;
332 result.delta_qc =
qcl -
qn;
335 result.tabs += fac_cond * result.delta_qc;
338 result.qn = result.qcl + result.qci;
342 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
351 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
361 return omn * dqsatw + (
one - omn) * dqsati + domn *
qsatw - domn *
qsati;
364 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
372 return -tabs_new + tabs_old + lstar * (
qv - qsat);
375 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
383 return -
one + dlstar * (
qv - qsat) - lstar * dqsat;
386 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
397 result.delta_qc = amrex::max(-
qc, result.delta_qv * omn);
398 result.delta_qi = amrex::max(-
qi, result.delta_qv * (
one - omn));
400 result.qcl =
qc + result.delta_qc;
401 result.qci =
qi + result.delta_qi;
402 result.qn = result.qcl + result.qci;
403 result.qt = result.qv + result.qn;
407 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
419 result.dqca = dtn * auto_r * (qcc -
qcw0);
420 result.dqia = dtn * autos * (qii -
qci0);
424 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
466 result.dprc = dtn * accrcr * qcc * std::pow(
qpr, powr1);
467 result.dpsc = dtn * accrcs * qcc * std::pow(
qps, pows1);
468 result.dpgc = dtn * accrcg * qcc * std::pow(
qpg, powg1);
469 result.dpsi = dtn * accris * qii * std::pow(
qps, pows1);
470 result.dpgi = dtn * accrig * qii * std::pow(
qpg, powg1);
474 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
485 result.
dqc = result.dqca + result.dprc + result.dpsc + result.dpgc;
486 result.dqi = result.dqia + result.dpsi + result.dpgi;
488 const amrex::Real scalec = amrex::min(
qcl, result.dqc) / (result.dqc + eps);
489 const amrex::Real scalei = amrex::min(
qci, result.dqi) / (result.dqi + eps);
491 result.dqca *= scalec;
492 result.dprc *= scalec;
493 result.dpsc *= scalec;
494 result.dpgc *= scalec;
495 result.dqia *= scalei;
496 result.dpsi *= scalei;
497 result.dpgi *= scalei;
498 result.dqc = result.dqca + result.dprc + result.dpsc + result.dpgc;
499 result.dqi = result.dqia + result.dpsi + result.dpgi;
504 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
512 result.
dqpr = (result.dqca + result.dqia) * omp + result.dprc;
513 result.dqps = (result.dqca + result.dqia) * (
one - omp) * (
one - omg) + result.dpsc + result.dpsi;
514 result.dqpg = (result.dqca + result.dqia) * (
one - omp) * omg + result.dpgc + result.dpgi;
518 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
536 result.
dqpr = evapr1_k * std::sqrt(
qpr) + evapr2_k * std::pow(
qpr, powr2);
537 result.dqps = evaps1_k * std::sqrt(
qps) + evaps2_k * std::pow(
qps, pows2);
538 result.dqpg = evapg1_k * std::sqrt(
qpg) + evapg2_k * std::pow(
qpg, powg2);
542 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
551 result.
dqpr = amrex::min(
qpr, result.dqpr);
552 result.dqps = amrex::min(
qps, result.dqps);
553 result.dqpg = amrex::min(
qpg, result.dqpg);
554 result.dqp = result.dqpr + result.dqps + result.dqpg;
558 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
571 if (diagnostics !=
nullptr) {
576 state.
qt = state.
qv + state.
qn;
599 if (diagnostics !=
nullptr) {
600 diagnostics->omn = omn;
601 diagnostics->omp = omp;
602 diagnostics->omg = omg;
614 if (diagnostics !=
nullptr) {
615 diagnostics->autoconversion = source_terms;
616 diagnostics->accretion = accretion_terms;
619 source_terms.
dprc = accretion_terms.
dprc;
620 source_terms.
dpsc = accretion_terms.
dpsc;
621 source_terms.
dpgc = accretion_terms.
dpgc;
622 source_terms.
dpsi = accretion_terms.
dpsi;
623 source_terms.
dpgi = accretion_terms.
dpgi;
625 config.
eps, source_terms);
626 if (diagnostics !=
nullptr) {
627 diagnostics->limited_sources = source_terms;
631 if (diagnostics !=
nullptr) {
632 diagnostics->partitioned_sources = source_terms;
638 state.
qcl -= source_terms.
dqc;
639 state.
qci -= source_terms.
dqi;
640 state.
qpr += source_terms.
dqpr;
641 state.
qps += source_terms.
dqps;
642 state.
qpg += source_terms.
dqpg;
645 state.
qt = state.
qv + state.
qn;
652 + source_terms.
dpsc + source_terms.
dpgc);
663 if (diagnostics !=
nullptr) {
664 diagnostics->qsat = qsat;
667 if (state.
qp >
zero && state.
qv < qsat) {
676 evaporation_terms.
dqpr *= supersat_factor;
677 evaporation_terms.
dqps *= supersat_factor;
678 evaporation_terms.
dqpg *= supersat_factor;
683 if (diagnostics !=
nullptr) {
684 diagnostics->evaporation = evaporation_terms;
687 state.
qv += evaporation_terms.
dqp;
688 state.
qpr -= evaporation_terms.
dqpr;
689 state.
qps -= evaporation_terms.
dqps;
690 state.
qpg -= evaporation_terms.
dqpg;
692 state.
qt = state.
qv + state.
qn;
707 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
730 row.accrsi = coef1 * coef2 *
esicoef;
737 prefactor *= (
two /
PI);
745 row.accrgi = coef1 * coef2 *
egicoef;
767 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
775 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
791 result.tabs_avg = tabs_k;
792 result.qci_avg = qci_k;
793 result.qp_avg = qp_k;
794 }
else if (k == k_hi + 1) {
795 result.rho_avg = rho_km1;
796 result.tabs_avg = tabs_km1;
797 result.qci_avg = qci_km1;
798 result.qp_avg = qp_km1;
800 result.rho_avg =
myhalf * (rho_km1 + rho_k);
801 result.tabs_avg =
myhalf * (tabs_km1 + tabs_k);
802 result.qci_avg =
myhalf * (qci_km1 + qci_k);
803 result.qp_avg =
myhalf * (qp_km1 + qp_k);
808 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
811 const int k_hi) noexcept
813 if (face_k <= k_lo) {
816 if (face_k >= k_hi + 1) {
822 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
831 return static_cast<int>(std::ceil(reduced_flux * (dt /
dz) /
myhalf));
834 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
836 const int SAM_moisture_type,
837 const amrex::Array4<const amrex::Real>& rho_array,
838 const amrex::Array4<const amrex::Real>& tabs_array,
839 const amrex::Array4<const amrex::Real>& qp_array,
844 const int k_hi) noexcept
849 result.
rho_avg = rho_array(i,j,k);
850 result.tabs_avg = tabs_array(i,j,k);
851 result.qp_avg = qp_array(i,j,k);
852 }
else if (k == k_hi + 1) {
853 result.rho_avg = rho_array(i,j,k-1);
854 result.tabs_avg = tabs_array(i,j,k-1);
855 result.qp_avg = qp_array(i,j,k-1);
857 result.rho_avg =
myhalf * (rho_array(i,j,k-1) + rho_array(i,j,k));
858 result.tabs_avg =
myhalf * (tabs_array(i,j,k-1) + tabs_array(i,j,k));
859 result.qp_avg =
myhalf * (qp_array(i,j,k-1) + qp_array(i,j,k));
863 result.qrr = result.omp * result.qp_avg;
864 result.qss = (
one - result.omp) * (
one - result.omg) * result.qp_avg;
865 result.qgg = (
one - result.omp) * result.omg * result.qp_avg;
869 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
874 const amrex::Array4<const amrex::Real>& rho_array,
875 const amrex::Array4<const amrex::Real>& tabs_array,
876 const amrex::Array4<const amrex::Real>& qpr_array,
877 const amrex::Array4<const amrex::Real>& qps_array,
878 const amrex::Array4<const amrex::Real>& qpg_array,
883 const int k_hi) noexcept
888 result.
rho_avg = rho_array(i,j,k);
889 result.tabs_avg = tabs_array(i,j,k);
890 result.qpr_avg = qpr_array(i,j,k);
891 result.qps_avg = qps_array(i,j,k);
892 result.qpg_avg = qpg_array(i,j,k);
893 }
else if (k == k_hi + 1) {
894 result.rho_avg = rho_array(i,j,k-1);
895 result.tabs_avg = tabs_array(i,j,k-1);
896 result.qpr_avg = qpr_array(i,j,k-1);
897 result.qps_avg = qps_array(i,j,k-1);
898 result.qpg_avg = qpg_array(i,j,k-1);
900 result.rho_avg =
myhalf * (rho_array(i,j,k-1) + rho_array(i,j,k));
901 result.tabs_avg =
myhalf * (tabs_array(i,j,k-1) + tabs_array(i,j,k));
902 result.qpr_avg =
myhalf * (qpr_array(i,j,k-1) + qpr_array(i,j,k));
903 result.qps_avg =
myhalf * (qps_array(i,j,k-1) + qps_array(i,j,k));
904 result.qpg_avg =
myhalf * (qpg_array(i,j,k-1) + qpg_array(i,j,k));
909 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
922 return face_state.omp * vrain * std::pow(face_state.rho_avg * face_state.qrr,
one +
crain)
923 + (
one - face_state.omp)
924 * ((
one - face_state.omg) * vsnow * std::pow(face_state.rho_avg * face_state.qss,
one +
csnow)
925 + face_state.omg * vgrau * std::pow(face_state.rho_avg * face_state.qgg,
one +
cgrau));
928 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
942 result.
rain = face_state.omp * vrain * std::pow(face_state.rho_avg * face_state.qrr,
one +
crain);
943 result.snow = (
one - face_state.omp) * (
one - face_state.omg)
944 * vsnow * std::pow(face_state.rho_avg * face_state.qss,
one +
csnow);
945 result.graupel = (
one - face_state.omp) * face_state.omg
946 * vgrau * std::pow(face_state.rho_avg * face_state.qgg,
one +
cgrau);
950 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
962 if (face_state.qpr_avg >
zero) {
963 result.
rain = vrain * std::pow(face_state.rho_avg * face_state.qpr_avg,
one +
crain);
965 if (face_state.qps_avg >
zero) {
966 result.snow = vsnow * std::pow(face_state.rho_avg * face_state.qps_avg,
one +
csnow);
968 if (face_state.qpg_avg >
zero) {
969 result.graupel = vgrau * std::pow(face_state.rho_avg * face_state.qpg_avg,
one +
cgrau);
974 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
979 return precip_flux * std::sqrt(
rho_0 / rho_avg);
982 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
990 precip_fluxes.rain * density_correction,
991 precip_fluxes.snow * density_correction,
992 precip_fluxes.graupel * density_correction};
995 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
1007 rho_donor * amrex::max(
amrex::Real(0.0), q_donor) * detJ_donor / coef;
1008 return amrex::min(raw_flux, available_flux);
1011 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
1021 return dJinv * (
one /
rho) * (fz_hi - fz_lo) * coef;
1024 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
1034 result.snow = component_fluxes.snow * dtn /
rhos *
amrex::Real(1000.0);
1035 result.graupel = component_fluxes.graupel * dtn /
rhog *
amrex::Real(1000.0);
1039 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
constexpr amrex::Real csnow
Definition: ERF_Constants.H:101
constexpr amrex::Real rhog
Definition: ERF_Constants.H:49
constexpr amrex::Real a_bg
Definition: ERF_Constants.H:96
constexpr amrex::Real R_v
Definition: ERF_Constants.H:30
constexpr amrex::Real three
Definition: ERF_Constants.H:9
constexpr amrex::Real muelq
Definition: ERF_Constants.H:94
constexpr amrex::Real a_gr
Definition: ERF_Constants.H:98
constexpr amrex::Real qci0
Definition: ERF_Constants.H:66
constexpr amrex::Real nzerog
Definition: ERF_Constants.H:78
constexpr amrex::Real cgrau
Definition: ERF_Constants.H:102
constexpr amrex::Real tbgmax
Definition: ERF_Constants.H:51
constexpr amrex::Real betaelq
Definition: ERF_Constants.H:68
constexpr amrex::Real two
Definition: ERF_Constants.H:8
constexpr amrex::Real a_grau
Definition: ERF_Constants.H:61
constexpr amrex::Real lsub
Definition: ERF_Constants.H:87
constexpr amrex::Real alphaelq
Definition: ERF_Constants.H:67
constexpr amrex::Real esicoef
Definition: ERF_Constants.H:72
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real diffelq
Definition: ERF_Constants.H:92
constexpr amrex::Real fourth
Definition: ERF_Constants.H:12
constexpr amrex::Real therco
Definition: ERF_Constants.H:93
constexpr amrex::Real b_grau
Definition: ERF_Constants.H:62
constexpr amrex::Real egccoef
Definition: ERF_Constants.H:73
constexpr amrex::Real egicoef
Definition: ERF_Constants.H:74
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real b_rain
Definition: ERF_Constants.H:58
constexpr amrex::Real lcond
Definition: ERF_Constants.H:85
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:11
constexpr amrex::Real qcw0
Definition: ERF_Constants.H:65
constexpr amrex::Real tprmin
Definition: ERF_Constants.H:52
constexpr amrex::Real qp_threshold
Definition: ERF_Constants.H:79
constexpr amrex::Real PI
Definition: ERF_Constants.H:24
constexpr amrex::Real nzeror
Definition: ERF_Constants.H:76
constexpr amrex::Real tbgmin
Definition: ERF_Constants.H:50
constexpr amrex::Real rhos
Definition: ERF_Constants.H:48
constexpr amrex::Real esccoef
Definition: ERF_Constants.H:71
constexpr amrex::Real rhor
Definition: ERF_Constants.H:47
constexpr amrex::Real a_rain
Definition: ERF_Constants.H:57
constexpr amrex::Real nzeros
Definition: ERF_Constants.H:77
constexpr amrex::Real R_d
Definition: ERF_Constants.H:29
constexpr amrex::Real a_snow
Definition: ERF_Constants.H:59
constexpr amrex::Real crain
Definition: ERF_Constants.H:100
constexpr amrex::Real b_snow
Definition: ERF_Constants.H:60
constexpr amrex::Real erccoef
Definition: ERF_Constants.H:70
constexpr amrex::Real tgrmin
Definition: ERF_Constants.H:54
constexpr amrex::Real a_pr
Definition: ERF_Constants.H:97
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getTgivenRandRTh(const amrex::Real rho, const amrex::Real rhotheta, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:46
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getThgivenTandP(const amrex::Real T, const amrex::Real P, const amrex::Real rdOcp)
Definition: ERF_EOS.H:18
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getPgivenRTh(const amrex::Real rhotheta, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:81
#define RhoQ4_comp
Definition: ERF_IndexDefines.H:45
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define RhoQ2_comp
Definition: ERF_IndexDefines.H:43
#define RhoQ3_comp
Definition: ERF_IndexDefines.H:44
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
#define RhoQ6_comp
Definition: ERF_IndexDefines.H:47
#define RhoQ5_comp
Definition: ERF_IndexDefines.H:46
Real rho_0
Definition: ERF_InitCustomPert_ABL.H:4
const Real rdOcp
Definition: ERF_InitCustomPert_Bomex.H:16
rho
Definition: ERF_InitCustomPert_Bubble.H:106
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real erf_esati(amrex::Real t)
Definition: ERF_MicrophysicsUtils.H:31
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_qsatw(amrex::Real t, amrex::Real p, amrex::Real &qsatw)
Definition: ERF_MicrophysicsUtils.H:228
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_qsati(amrex::Real t, amrex::Real p, amrex::Real &qsati)
Definition: ERF_MicrophysicsUtils.H:218
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real erf_esatw(amrex::Real t, bool use_empirical=false)
Definition: ERF_MicrophysicsUtils.H:123
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipFaceState sam_precip_face_state(const int SAM_moisture_type, const amrex::Array4< const amrex::Real > &rho_array, const amrex::Array4< const amrex::Real > &tabs_array, const amrex::Array4< const amrex::Real > &qp_array, const int i, const int j, const int k, const int k_lo, const int k_hi) noexcept
Definition: ERF_SAMUtils.H:835
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_precip_rain_fraction(const int SAM_moisture_type, const amrex::Real tabs) noexcept
Definition: ERF_SAMUtils.H:266
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMCoefficientRow sam_compute_coefficient_row(const amrex::Real rho, const amrex::Real tabs, const amrex::Real gamr1, const amrex::Real gamr2, const amrex::Real gams1, const amrex::Real gams2, const amrex::Real gamg1, const amrex::Real gamg2) noexcept
Definition: ERF_SAMUtils.H:711
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_precip_flux_from_face_state(const SAMPrecipFaceState &face_state, const amrex::Real vrain, const amrex::Real vsnow, const amrex::Real vgrau) noexcept
Definition: ERF_SAMUtils.H:914
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMSurfaceAccumulation sam_surface_accumulation_from_component_fluxes(const SAMPrecipFluxComponents &component_fluxes, const amrex::Real dtn) noexcept
Definition: ERF_SAMUtils.H:1028
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_partition_autoconverted_precip(SAMPrecipSources result, const amrex::Real omp, const amrex::Real omg) noexcept
Definition: ERF_SAMUtils.H:505
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE int sam_precip_face_donor_k(const int face_k, const int k_lo, const int k_hi) noexcept
Definition: ERF_SAMUtils.H:809
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_precip_evaporation_rates(const amrex::Real qpr, const amrex::Real qps, const amrex::Real qpg, const amrex::Real powr2, const amrex::Real pows2, const amrex::Real powg2, const amrex::Real evapr1_k, const amrex::Real evapr2_k, const amrex::Real evaps1_k, const amrex::Real evaps2_k, const amrex::Real evapg1_k, const amrex::Real evapg2_k) noexcept
Definition: ERF_SAMUtils.H:519
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_newton_residual_derivative(const amrex::Real lstar, const amrex::Real dlstar, const amrex::Real qv, const amrex::Real qsat, const amrex::Real dqsat) noexcept
Definition: ERF_SAMUtils.H:376
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrimitiveCell sam_cons_to_primitive(const amrex::Real rho, const amrex::Real rho_theta, const amrex::Real rho_qv, const amrex::Real rho_qcl, const amrex::Real rho_qci, const amrex::Real rho_qpr, const amrex::Real rho_qps, const amrex::Real rho_qpg) noexcept
Definition: ERF_SAMUtils.H:182
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE bool sam_is_no_precip(const MoistureType moisture_type) noexcept
Definition: ERF_SAMUtils.H:239
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipFluxComponents sam_precip_flux_components_density_corrected(const SAMPrecipFluxComponents &precip_fluxes, const amrex::Real rho_0, const amrex::Real rho_avg) noexcept
Definition: ERF_SAMUtils.H:983
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMCellState sam_precip_cell_update(SAMCellState state, const SAMCoefficientRow &coeffs, const SAMPrecipConfig &config, SAMPrecipCellDiagnostics *diagnostics=nullptr) noexcept
Definition: ERF_SAMUtils.H:559
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_precip_flux_density_corrected(const amrex::Real precip_flux, const amrex::Real rho_0, const amrex::Real rho_avg) noexcept
Definition: ERF_SAMUtils.H:975
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_cloud_liquid_fraction(const int SAM_moisture_type, const amrex::Real tabs, const amrex::Real an, const amrex::Real bn) noexcept
Definition: ERF_SAMUtils.H:245
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_pa_to_mbar(const amrex::Real pres_pa) noexcept
Definition: ERF_SAMUtils.H:165
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMCloudPhaseChange sam_partition_cloud_phase(const int SAM_moisture_type, const amrex::Real tabs, const amrex::Real qn, const amrex::Real qcl, const amrex::Real qci, const amrex::Real fac_cond, const amrex::Real fac_fus, const amrex::Real an, const amrex::Real bn) noexcept
Definition: ERF_SAMUtils.H:290
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_accretion_rates(const amrex::Real dtn, const amrex::Real qcc, const amrex::Real qii, const amrex::Real qpr, const amrex::Real qps, const amrex::Real qpg, const amrex::Real powr1, const amrex::Real pows1, const amrex::Real powg1, const amrex::Real omp, const amrex::Real omg, const amrex::Real accrrc_k, const amrex::Real accrsc_k, const amrex::Real accrsi_k, const amrex::Real accrgc_k, const amrex::Real accrgi_k) noexcept
Definition: ERF_SAMUtils.H:425
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_apply_precip_evaporation_limiter(const amrex::Real qpr, const amrex::Real qps, const amrex::Real qpg, SAMPrecipSources result) noexcept
Definition: ERF_SAMUtils.H:543
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_mixed_dqsat_dT(const amrex::Real omn, const amrex::Real domn, const amrex::Real qsatw, const amrex::Real qsati, const amrex::Real dqsatw, const amrex::Real dqsati) noexcept
Definition: ERF_SAMUtils.H:352
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_mbar_to_pa(const amrex::Real pres_mbar) noexcept
Definition: ERF_SAMUtils.H:158
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE int sam_substep_count_from_reduced_flux(const amrex::Real reduced_flux, const amrex::Real dt, const amrex::Real dz) noexcept
Definition: ERF_SAMUtils.H:823
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipFluxComponents sam_precip_component_fluxes_from_face_state(const SAMPrecipComponentFaceState &face_state, const amrex::Real vrain, const amrex::Real vsnow, const amrex::Real vgrau) noexcept
Definition: ERF_SAMUtils.H:955
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipComponentFaceState sam_precip_component_face_state(const amrex::Array4< const amrex::Real > &rho_array, const amrex::Array4< const amrex::Real > &tabs_array, const amrex::Array4< const amrex::Real > &qpr_array, const amrex::Array4< const amrex::Real > &qps_array, const amrex::Array4< const amrex::Real > &qpg_array, const int i, const int j, const int k, const int k_lo, const int k_hi) noexcept
Definition: ERF_SAMUtils.H:873
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void sam_primitive_to_cons(const SAMPrimitiveCell &primitive, const amrex::Array4< amrex::Real > &states_arr, const int i, const int j, const int k) noexcept
Definition: ERF_SAMUtils.H:213
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipFluxComponents sam_precip_flux_components_from_face_state(const SAMPrecipFaceState &face_state, const amrex::Real vrain, const amrex::Real vsnow, const amrex::Real vgrau) noexcept
Definition: ERF_SAMUtils.H:932
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMCloudPhaseChange sam_apply_condensate_limiter(const amrex::Real qv, const amrex::Real qsat, const amrex::Real qc, const amrex::Real qi, const amrex::Real omn) noexcept
Definition: ERF_SAMUtils.H:387
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_newton_residual(const amrex::Real tabs_new, const amrex::Real tabs_old, const amrex::Real lstar, const amrex::Real qv, const amrex::Real qsat) noexcept
Definition: ERF_SAMUtils.H:365
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_rescale_cloud_sinks(const amrex::Real qcl, const amrex::Real qci, const amrex::Real eps, SAMPrecipSources result) noexcept
Definition: ERF_SAMUtils.H:475
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMPrecipSources sam_autoconversion_rates(const amrex::Real dtn, const amrex::Real qcc, const amrex::Real qii, const amrex::Real coefice_k) noexcept
Definition: ERF_SAMUtils.H:408
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_limit_precip_component_flux(const amrex::Real raw_flux, const amrex::Real rho_donor, const amrex::Real q_donor, const amrex::Real detJ_donor, const amrex::Real coef) noexcept
Definition: ERF_SAMUtils.H:999
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_cloud_ice_terminal_velocity(const amrex::Real qci_avg) noexcept
Definition: ERF_SAMUtils.H:768
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_graupel_fraction(const int SAM_moisture_type, const amrex::Real tabs) noexcept
Definition: ERF_SAMUtils.H:278
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE bool sam_is_no_ice(const MoistureType moisture_type) noexcept
Definition: ERF_SAMUtils.H:232
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_mixed_qsat(const amrex::Real omn, const amrex::Real qsatw, const amrex::Real qsati) noexcept
Definition: ERF_SAMUtils.H:343
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_theta_from_stored_mbar_converted_to_pa(const amrex::Real tabs, const amrex::Real pres_mbar, const amrex::Real rdOcp) noexcept
Definition: ERF_SAMUtils.H:171
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real sam_sedimentation_tendency(const amrex::Real fz_hi, const amrex::Real fz_lo, const amrex::Real rho, const amrex::Real dJinv, const amrex::Real coef) noexcept
Definition: ERF_SAMUtils.H:1015
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMFaceState sam_face_average_state(const int k, const int k_lo, const int k_hi, const amrex::Real rho_km1, const amrex::Real rho_k, const amrex::Real tabs_km1, const amrex::Real tabs_k, const amrex::Real qci_km1, const amrex::Real qci_k, const amrex::Real qp_km1, const amrex::Real qp_k) noexcept
Definition: ERF_SAMUtils.H:776
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE SAMSurfaceAccumulation sam_surface_accumulation(const SAMPrecipFaceState &face_state, const amrex::Real rho_0, const amrex::Real vrain, const amrex::Real vsnow, const amrex::Real vgrau, const amrex::Real dtn) noexcept
Definition: ERF_SAMUtils.H:1040
amrex::Real Real
Definition: ERF_ShocInterface.H:19
@ qcl
Definition: ERF_Kessler.H:30
@ tabs
Definition: ERF_Kessler.H:25
@ qv
Definition: ERF_Kessler.H:29
@ qpg
Definition: ERF_Morrison.H:41
@ qps
Definition: ERF_Morrison.H:40
@ qn
Definition: ERF_Morrison.H:33
@ qpr
Definition: ERF_Morrison.H:39
@ qci
Definition: ERF_Morrison.H:36
@ qc
Definition: ERF_SatAdj.H:40
@ qi
Definition: ERF_WSM6.H:26
@ qsatw
Definition: ERF_WSM6.H:236
@ qsati
Definition: ERF_WSM6.H:236
@ dz
Definition: ERF_AdvanceWSM6.cpp:104
Definition: ERF_SAMUtils.H:22
amrex::Real delta_qi
Definition: ERF_SAMUtils.H:26
amrex::Real qcl
Definition: ERF_SAMUtils.H:28
amrex::Real qn
Definition: ERF_SAMUtils.H:30
amrex::Real tabs
Definition: ERF_SAMUtils.H:32
amrex::Real qt
Definition: ERF_SAMUtils.H:31
amrex::Real qv
Definition: ERF_SAMUtils.H:27
amrex::Real delta_qv
Definition: ERF_SAMUtils.H:24
amrex::Real delta_qc
Definition: ERF_SAMUtils.H:25
amrex::Real omn
Definition: ERF_SAMUtils.H:23
amrex::Real qci
Definition: ERF_SAMUtils.H:29
Definition: ERF_SAMUtils.H:98
amrex::Real coefice
Definition: ERF_SAMUtils.H:102
amrex::Real evaps2
Definition: ERF_SAMUtils.H:104
amrex::Real accrsi
Definition: ERF_SAMUtils.H:100
amrex::Real accrgc
Definition: ERF_SAMUtils.H:106
amrex::Real accrgi
Definition: ERF_SAMUtils.H:105
amrex::Real accrsc
Definition: ERF_SAMUtils.H:101
amrex::Real evapg1
Definition: ERF_SAMUtils.H:107
amrex::Real evapr1
Definition: ERF_SAMUtils.H:109
amrex::Real evapg2
Definition: ERF_SAMUtils.H:108
amrex::Real accrrc
Definition: ERF_SAMUtils.H:99
amrex::Real evapr2
Definition: ERF_SAMUtils.H:110
amrex::Real evaps1
Definition: ERF_SAMUtils.H:103
Definition: ERF_SAMUtils.H:132
amrex::Real qp_avg
Definition: ERF_SAMUtils.H:136
amrex::Real qci_avg
Definition: ERF_SAMUtils.H:135
amrex::Real tabs_avg
Definition: ERF_SAMUtils.H:134
amrex::Real rho_avg
Definition: ERF_SAMUtils.H:133
Definition: ERF_SAMUtils.H:16
amrex::Real omg
Definition: ERF_SAMUtils.H:19
amrex::Real omp
Definition: ERF_SAMUtils.H:18
amrex::Real omn
Definition: ERF_SAMUtils.H:17
Definition: ERF_SAMUtils.H:86
SAMPrecipSources limited_sources
Definition: ERF_SAMUtils.H:89
amrex::Real omg
Definition: ERF_SAMUtils.H:95
amrex::Real omp
Definition: ERF_SAMUtils.H:94
SAMPrecipSources partitioned_sources
Definition: ERF_SAMUtils.H:90
amrex::Real qsat
Definition: ERF_SAMUtils.H:92
SAMPrecipSources evaporation
Definition: ERF_SAMUtils.H:91
amrex::Real omn
Definition: ERF_SAMUtils.H:93
SAMPrecipSources autoconversion
Definition: ERF_SAMUtils.H:87
SAMPrecipSources accretion
Definition: ERF_SAMUtils.H:88
Definition: ERF_SAMUtils.H:124
amrex::Real qpr_avg
Definition: ERF_SAMUtils.H:127
amrex::Real qpg_avg
Definition: ERF_SAMUtils.H:129
amrex::Real qps_avg
Definition: ERF_SAMUtils.H:128
amrex::Real tabs_avg
Definition: ERF_SAMUtils.H:126
amrex::Real rho_avg
Definition: ERF_SAMUtils.H:125
Definition: ERF_SAMUtils.H:69
bool enable_precip
Definition: ERF_SAMUtils.H:71
amrex::Real fac_cond
Definition: ERF_SAMUtils.H:74
amrex::Real rdOcp
Definition: ERF_SAMUtils.H:73
amrex::Real dtn
Definition: ERF_SAMUtils.H:72
amrex::Real eps
Definition: ERF_SAMUtils.H:77
amrex::Real powr2
Definition: ERF_SAMUtils.H:81
amrex::Real fac_sub
Definition: ERF_SAMUtils.H:76
amrex::Real pows2
Definition: ERF_SAMUtils.H:82
amrex::Real pows1
Definition: ERF_SAMUtils.H:79
amrex::Real fac_fus
Definition: ERF_SAMUtils.H:75
amrex::Real powg2
Definition: ERF_SAMUtils.H:83
amrex::Real powg1
Definition: ERF_SAMUtils.H:80
int sam_moisture_type
Definition: ERF_SAMUtils.H:70
amrex::Real powr1
Definition: ERF_SAMUtils.H:78
Definition: ERF_SAMUtils.H:113
amrex::Real omg
Definition: ERF_SAMUtils.H:118
amrex::Real qss
Definition: ERF_SAMUtils.H:120
amrex::Real qrr
Definition: ERF_SAMUtils.H:119
amrex::Real qp_avg
Definition: ERF_SAMUtils.H:116
amrex::Real rho_avg
Definition: ERF_SAMUtils.H:114
amrex::Real qgg
Definition: ERF_SAMUtils.H:121
amrex::Real tabs_avg
Definition: ERF_SAMUtils.H:115
amrex::Real omp
Definition: ERF_SAMUtils.H:117
Definition: ERF_SAMUtils.H:145
amrex::Real snow
Definition: ERF_SAMUtils.H:147
amrex::Real rain
Definition: ERF_SAMUtils.H:146
amrex::Real graupel
Definition: ERF_SAMUtils.H:148
Definition: ERF_SAMUtils.H:35
amrex::Real dqpg
Definition: ERF_SAMUtils.H:47
amrex::Real dpgc
Definition: ERF_SAMUtils.H:39
amrex::Real dqca
Definition: ERF_SAMUtils.H:36
amrex::Real dqps
Definition: ERF_SAMUtils.H:46
amrex::Real dqp
Definition: ERF_SAMUtils.H:48
amrex::Real dqc
Definition: ERF_SAMUtils.H:43
amrex::Real dpsc
Definition: ERF_SAMUtils.H:38
amrex::Real dpgi
Definition: ERF_SAMUtils.H:42
amrex::Real dprc
Definition: ERF_SAMUtils.H:37
amrex::Real dqia
Definition: ERF_SAMUtils.H:40
amrex::Real dqpr
Definition: ERF_SAMUtils.H:45
amrex::Real dpsi
Definition: ERF_SAMUtils.H:41
amrex::Real dqi
Definition: ERF_SAMUtils.H:44
Definition: ERF_SAMUtils.H:51
amrex::Real theta
Definition: ERF_SAMUtils.H:53
amrex::Real qpr
Definition: ERF_SAMUtils.H:61
amrex::Real qn
Definition: ERF_SAMUtils.H:59
amrex::Real qps
Definition: ERF_SAMUtils.H:62
amrex::Real qci
Definition: ERF_SAMUtils.H:58
amrex::Real qv
Definition: ERF_SAMUtils.H:56
amrex::Real tabs
Definition: ERF_SAMUtils.H:54
amrex::Real qpg
Definition: ERF_SAMUtils.H:63
amrex::Real qt
Definition: ERF_SAMUtils.H:60
amrex::Real qcl
Definition: ERF_SAMUtils.H:57
amrex::Real rho
Definition: ERF_SAMUtils.H:52
amrex::Real pres_mbar
Definition: ERF_SAMUtils.H:55
amrex::Real qp
Definition: ERF_SAMUtils.H:64
Definition: ERF_SAMUtils.H:139
amrex::Real rain
Definition: ERF_SAMUtils.H:140
amrex::Real snow
Definition: ERF_SAMUtils.H:141
amrex::Real graupel
Definition: ERF_SAMUtils.H:142