16 #include <AMReX_FArrayBox.H>
17 #include <AMReX_Geometry.H>
18 #include <AMReX_TableData.H>
19 #include <AMReX_MultiFabUtil.H>
56 using FabPtr = std::shared_ptr<amrex::MultiFab>;
91 Init (
const amrex::MultiFab& cons_in,
92 const amrex::BoxArray& grids,
93 const amrex::Geometry& geom,
95 std::unique_ptr<amrex::MultiFab>& z_phys_nd,
96 std::unique_ptr<amrex::MultiFab>& detJ_cc)
override;
122 const amrex::MultiFab& )
override
147 const amrex::MultiFab*
171 std::vector<int>& a_idx,
172 std::vector<std::string>& a_names)
const override
178 a_idx.push_back(0); a_names.push_back(
"RainAccum");
179 a_idx.push_back(1); a_names.push_back(
"SnowAccum");
180 a_idx.push_back(2); a_names.push_back(
"GraupAccum");
183 AMREX_GPU_HOST_DEVICE
187 const int& SAM_moisture_type,
193 const amrex::Array4<amrex::Real>& tabs_array,
194 const amrex::Array4<amrex::Real>& pres_array,
195 const amrex::Array4<amrex::Real>& qv_array,
196 const amrex::Array4<amrex::Real>& qc_array,
197 const amrex::Array4<amrex::Real>& qi_array,
198 const amrex::Array4<amrex::Real>& qn_array,
199 const amrex::Array4<amrex::Real>& qt_array)
240 if (SAM_moisture_type == 1) {
252 }
else if (SAM_moisture_type == 2) {
259 lstar = omn * lstarw + (
one-omn) * lstari;
260 dlstar = domn * lstarw - domn * lstari;
275 }
while(std::abs(dtabs) > tol && niter < 20);
283 qc_array(i,j,k), qi_array(i,j,k), omn);
288 qv_array(i,j,k) = phase_change.
qv;
289 qc_array(i,j,k) += delta_qc;
290 qi_array(i,j,k) += delta_qi;
291 qn_array(i,j,k) = qc_array(i,j,k) + qi_array(i,j,k);
292 qt_array(i,j,k) = qv_array(i,j,k) + qn_array(i,j,k);
358 amrex::TableData<amrex::Real, 1>
rho1d;
361 amrex::TableData<amrex::Real, 1>
qt1d;
362 amrex::TableData<amrex::Real, 1>
qv1d;
363 amrex::TableData<amrex::Real, 1>
qn1d;
constexpr amrex::Real lfus
Definition: ERF_Constants.H:86
constexpr amrex::Real tbgmax
Definition: ERF_Constants.H:51
constexpr amrex::Real lsub
Definition: ERF_Constants.H:87
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real lcond
Definition: ERF_Constants.H:85
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:11
constexpr amrex::Real tbgmin
Definition: ERF_Constants.H:50
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_dtqsatw(amrex::Real t, amrex::Real p, amrex::Real &dtqsatw)
Definition: ERF_MicrophysicsUtils.H:244
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_dtqsati(amrex::Real t, amrex::Real p, amrex::Real &dtqsati)
Definition: ERF_MicrophysicsUtils.H:235
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 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 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_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 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 amrex::Real sam_mixed_qsat(const amrex::Real omn, const amrex::Real qsatw, const amrex::Real qsati) noexcept
Definition: ERF_SAMUtils.H:343
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_NullMoist.H:8
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateSAM.cpp:15
void Advance(const amrex::Real &dt_advance, const SolverChoice &sc) override
Definition: ERF_SAM.H:129
int zlo
Definition: ERF_SAM.H:321
void Precip(const SolverChoice &sc)
Definition: ERF_Precip.cpp:11
amrex::TableData< amrex::Real, 1 > rho1d
Definition: ERF_SAM.H:358
amrex::TableData< amrex::Real, 1 > evapr2
Definition: ERF_SAM.H:355
SAM()
Definition: ERF_SAM.H:60
amrex::MultiFab * m_detJ_cc
Definition: ERF_SAM.H:338
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitSAM.cpp:94
int n_qstate_moist_numconc_size
Definition: ERF_SAM.H:306
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_SAM.H:121
amrex::TableData< amrex::Real, 1 > evapg1
Definition: ERF_SAM.H:352
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_SAM.H:114
amrex::TableData< amrex::Real, 1 > accrgi
Definition: ERF_SAM.H:350
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_SAM.H:56
amrex::TableData< amrex::Real, 1 > evapg2
Definition: ERF_SAM.H:353
void IceFall(const SolverChoice &sc)
Definition: ERF_IceFall.cpp:13
amrex::Array< FabPtr, MicVar::NumVars > mic_fab_vars
Definition: ERF_SAM.H:341
int m_axis
Definition: ERF_SAM.H:324
amrex::Real m_rdOcp
Definition: ERF_SAM.H:330
void Cloud(const SolverChoice &sc)
Definition: ERF_CloudSAM.cpp:13
int m_qmoist_size
Definition: ERF_SAM.H:300
amrex::MultiFab * m_z_phys_nd
Definition: ERF_SAM.H:337
amrex::Real m_fac_fus
Definition: ERF_SAM.H:328
amrex::TableData< amrex::Real, 1 > evaps1
Definition: ERF_SAM.H:348
amrex::Vector< int > MicVarMap
Definition: ERF_SAM.H:312
bool m_do_cond
Definition: ERF_SAM.H:331
amrex::TableData< amrex::Real, 1 > qv1d
Definition: ERF_SAM.H:362
amrex::Real m_fac_cond
Definition: ERF_SAM.H:327
const amrex::MultiFab * Qmoist_Ptr(const int &varIdx) const
Definition: ERF_SAM.H:148
amrex::TableData< amrex::Real, 1 > accrsi
Definition: ERF_SAM.H:345
amrex::TableData< amrex::Real, 1 > accrrc
Definition: ERF_SAM.H:344
void Compute_Coefficients()
Definition: ERF_InitSAM.cpp:150
amrex::TableData< amrex::Real, 1 > pres1d
Definition: ERF_SAM.H:359
int nlev
Definition: ERF_SAM.H:321
int Qstate_Moist_Size() override
Definition: ERF_SAM.H:164
amrex::Geometry m_geom
Definition: ERF_SAM.H:315
amrex::TableData< amrex::Real, 1 > evapr1
Definition: ERF_SAM.H:354
amrex::Real m_fac_sub
Definition: ERF_SAM.H:329
amrex::TableData< amrex::Real, 1 > evaps2
Definition: ERF_SAM.H:349
void Init(const amrex::MultiFab &cons_in, const amrex::BoxArray &grids, const amrex::Geometry &geom, const amrex::Real &dt_advance, std::unique_ptr< amrex::MultiFab > &z_phys_nd, std::unique_ptr< amrex::MultiFab > &detJ_cc) override
Definition: ERF_InitSAM.cpp:37
void Set_dzmin(const amrex::Real dz_min) override
Definition: ERF_SAM.H:100
amrex::TableData< amrex::Real, 1 > qn1d
Definition: ERF_SAM.H:363
amrex::TableData< amrex::Real, 1 > accrgc
Definition: ERF_SAM.H:351
amrex::TableData< amrex::Real, 1 > accrsc
Definition: ERF_SAM.H:346
int n_qstate_moist_size
Definition: ERF_SAM.H:303
amrex::TableData< amrex::Real, 1 > qt1d
Definition: ERF_SAM.H:361
amrex::TableData< amrex::Real, 1 > coefice
Definition: ERF_SAM.H:347
int zhi
Definition: ERF_SAM.H:321
static constexpr amrex::Real CFL_MAX
Definition: ERF_SAM.H:309
void Define(SolverChoice &sc) override
Definition: ERF_SAM.H:79
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_SAM.H:170
AMREX_GPU_HOST_DEVICE static AMREX_FORCE_INLINE amrex::Real NewtonIterSat(int &i, int &j, int &k, const int &SAM_moisture_type, const amrex::Real &fac_cond, const amrex::Real &, const amrex::Real &fac_sub, const amrex::Real &an, const amrex::Real &bn, const amrex::Array4< amrex::Real > &tabs_array, const amrex::Array4< amrex::Real > &pres_array, const amrex::Array4< amrex::Real > &qv_array, const amrex::Array4< amrex::Real > &qc_array, const amrex::Array4< amrex::Real > &qi_array, const amrex::Array4< amrex::Real > &qn_array, const amrex::Array4< amrex::Real > &qt_array)
Definition: ERF_SAM.H:186
int Qmoist_Size() override
Definition: ERF_SAM.H:161
SAMCoefficientRow CoefficientRowAt(int k) const
Definition: ERF_InitSAM.cpp:244
void PrecipFall(const SolverChoice &sc)
Definition: ERF_PrecipFall.cpp:17
amrex::TableData< amrex::Real, 1 > tabs1d
Definition: ERF_SAM.H:360
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_SAM.H:141
int Qstate_Moist_NumConc_Size() override
Definition: ERF_SAM.H:167
amrex::Real dt
Definition: ERF_SAM.H:318
amrex::Real m_dzmin
Definition: ERF_SAM.H:334
@ NumVars
Definition: ERF_SAM.H:50
@ pres
Definition: ERF_SAM.H:34
@ qpr
Definition: ERF_SAM.H:43
@ qci
Definition: ERF_SAM.H:40
@ qv
Definition: ERF_SAM.H:38
@ rho
Definition: ERF_SAM.H:31
@ snow_accum
Definition: ERF_SAM.H:48
@ qpg
Definition: ERF_SAM.H:45
@ qt
Definition: ERF_SAM.H:36
@ qn
Definition: ERF_SAM.H:37
@ rain_accum
Definition: ERF_SAM.H:47
@ theta
Definition: ERF_SAM.H:32
@ qcl
Definition: ERF_SAM.H:39
@ graup_accum
Definition: ERF_SAM.H:49
@ tabs
Definition: ERF_SAM.H:33
@ qps
Definition: ERF_SAM.H:44
@ qp
Definition: ERF_SAM.H:42
@ qsatw
Definition: ERF_WSM6.H:236
@ qsati
Definition: ERF_WSM6.H:236
Definition: ERF_SAMUtils.H:22
amrex::Real delta_qi
Definition: ERF_SAMUtils.H:26
amrex::Real qv
Definition: ERF_SAMUtils.H:27
amrex::Real delta_qc
Definition: ERF_SAMUtils.H:25
Definition: ERF_SAMUtils.H:98
Definition: ERF_DataStruct.H:141
amrex::Real rdOcp
Definition: ERF_DataStruct.H:1222
amrex::Real c_p
Definition: ERF_DataStruct.H:1221
bool use_shoc
Definition: ERF_DataStruct.H:1253
int ave_plane
Definition: ERF_DataStruct.H:1313