12 #include <AMReX_AmrCore.H>
13 #include <AMReX_BCRec.H>
14 #include <AMReX_Print.H>
16 #include <AMReX_ParallelDescriptor.H>
17 #include <AMReX_ParmParse.H>
18 #include <AMReX_MultiFabUtil.H>
19 #include <AMReX_FillPatchUtil.H>
20 #include <AMReX_VisMF.H>
21 #include <AMReX_PhysBCFunct.H>
22 #include <AMReX_YAFluxRegister.H>
23 #include <AMReX_ErrorList.H>
24 #include <AMReX_EBFabFactory.H>
25 #include <AMReX_EBMultiFabUtil.H>
30 #include <AMReX_FFT_Poisson.H>
33 #ifdef AMREX_MEM_PROFILING
34 #include <AMReX_MemProfiler.H>
54 #ifdef ERF_USE_PARTICLES
62 #ifdef ERF_USE_WINDFARM
68 #ifdef ERF_USE_EAMXX_SHOC
72 #ifdef ERF_USE_NATIVE_SHOC
77 #include "ERF_P3Interface.H"
83 #include <AMReX_Lazy.H>
87 using amrex::MPI_COMM_WORLD;
88 using amrex::MPI_Comm;
91 #ifdef ERF_USE_MULTIBLOCK
92 class MultiBlockContainer;
99 FullState, Perturbational
114 :
public amrex::AmrCore
133 ERF& operator=(
ERF&& other) noexcept = delete;
139 ERF& operator=(const
ERF& other) = delete;
158 const
amrex::MultiFab& cc_vel,
160 amrex::TagBoxArray* tags =
nullptr);
163 const
amrex::MultiFab& cc_vel,
201 const
amrex::
Real& hurricane_eye_latitude,
202 const
amrex::
Real& hurricane_eye_longitude);
206 MoistureType moisture_type);
237 amrex::Geometry const& geom_at_lev);
252 void build_fft_solvers (
int lev);
253 void solve_with_fft (
int lev,
int isub,
const amrex::Box& subdomain,
254 amrex::MultiFab& rhs, amrex::MultiFab&
p,
255 amrex::Array<amrex::MultiFab,AMREX_SPACEDIM>& fluxes);
258 amrex::MultiFab& rhs, amrex::MultiFab&
p,
259 amrex::Array<amrex::MultiFab,AMREX_SPACEDIM>& fluxes,
260 amrex::MultiFab& ax_sub, amrex::MultiFab& ay_sub,
261 amrex::MultiFab& az_sub,
262 amrex::MultiFab& , amrex::MultiFab& znd_sub);
264 void ImposeBCsOnPhi (
int lev, amrex::MultiFab& phi,
const amrex::Box& subdomain);
284 bool writeNow (
double cur_time,
const int nstep,
const int plot_int,
307 void FillBdyCCVels (amrex::MultiFab& mf_cc_vel, amrex::Geometry& lev_geom);
313 amrex::Gpu::HostVector<amrex::Real>& h_avg_u , amrex::Gpu::HostVector<amrex::Real>& h_avg_v,
314 amrex::Gpu::HostVector<amrex::Real>& h_avg_w , amrex::Gpu::HostVector<amrex::Real>& h_avg_rho,
315 amrex::Gpu::HostVector<amrex::Real>& h_avg_th , amrex::Gpu::HostVector<amrex::Real>& h_avg_ksgs,
316 amrex::Gpu::HostVector<amrex::Real>& h_avg_Kmv , amrex::Gpu::HostVector<amrex::Real>& h_avg_Khv,
317 amrex::Gpu::HostVector<amrex::Real>& h_avg_qv , amrex::Gpu::HostVector<amrex::Real>& h_avg_qc,
318 amrex::Gpu::HostVector<amrex::Real>& h_avg_qr ,
319 amrex::Gpu::HostVector<amrex::Real>& h_avg_wqv , amrex::Gpu::HostVector<amrex::Real>& h_avg_wqc,
320 amrex::Gpu::HostVector<amrex::Real>& h_avg_wqr ,
321 amrex::Gpu::HostVector<amrex::Real>& h_avg_qi , amrex::Gpu::HostVector<amrex::Real>& h_avg_qs,
322 amrex::Gpu::HostVector<amrex::Real>& h_avg_qg ,
323 amrex::Gpu::HostVector<amrex::Real>& h_avg_uu , amrex::Gpu::HostVector<amrex::Real>& h_avg_uv,
324 amrex::Gpu::HostVector<amrex::Real>& h_avg_uw,
325 amrex::Gpu::HostVector<amrex::Real>& h_avg_vv , amrex::Gpu::HostVector<amrex::Real>& h_avg_vw,
326 amrex::Gpu::HostVector<amrex::Real>& h_avg_ww,
327 amrex::Gpu::HostVector<amrex::Real>& h_avg_uth , amrex::Gpu::HostVector<amrex::Real>& h_avg_vth,
328 amrex::Gpu::HostVector<amrex::Real>& h_avg_wth, amrex::Gpu::HostVector<amrex::Real>& h_avg_thth,
329 amrex::Gpu::HostVector<amrex::Real>& h_avg_ku, amrex::Gpu::HostVector<amrex::Real>& h_avg_kv,
330 amrex::Gpu::HostVector<amrex::Real>& h_avg_kw,
331 amrex::Gpu::HostVector<amrex::Real>& h_avg_p,
332 amrex::Gpu::HostVector<amrex::Real>& h_avg_pu, amrex::Gpu::HostVector<amrex::Real>& h_avg_pv,
333 amrex::Gpu::HostVector<amrex::Real>& h_avg_pw, amrex::Gpu::HostVector<amrex::Real>& h_avg_wthv);
335 amrex::Gpu::HostVector<amrex::Real>& h_avg_u , amrex::Gpu::HostVector<amrex::Real>& h_avg_v,
336 amrex::Gpu::HostVector<amrex::Real>& h_avg_w , amrex::Gpu::HostVector<amrex::Real>& h_avg_rho,
337 amrex::Gpu::HostVector<amrex::Real>& h_avg_th , amrex::Gpu::HostVector<amrex::Real>& h_avg_ksgs,
338 amrex::Gpu::HostVector<amrex::Real>& h_avg_Kmv , amrex::Gpu::HostVector<amrex::Real>& h_avg_Khv,
339 amrex::Gpu::HostVector<amrex::Real>& h_avg_qv , amrex::Gpu::HostVector<amrex::Real>& h_avg_qc,
340 amrex::Gpu::HostVector<amrex::Real>& h_avg_qr ,
341 amrex::Gpu::HostVector<amrex::Real>& h_avg_wqv , amrex::Gpu::HostVector<amrex::Real>& h_avg_wqc,
342 amrex::Gpu::HostVector<amrex::Real>& h_avg_wqr ,
343 amrex::Gpu::HostVector<amrex::Real>& h_avg_qi , amrex::Gpu::HostVector<amrex::Real>& h_avg_qs,
344 amrex::Gpu::HostVector<amrex::Real>& h_avg_qg ,
345 amrex::Gpu::HostVector<amrex::Real>& h_avg_uu , amrex::Gpu::HostVector<amrex::Real>& h_avg_uv,
346 amrex::Gpu::HostVector<amrex::Real>& h_avg_uw,
347 amrex::Gpu::HostVector<amrex::Real>& h_avg_vv , amrex::Gpu::HostVector<amrex::Real>& h_avg_vw,
348 amrex::Gpu::HostVector<amrex::Real>& h_avg_ww,
349 amrex::Gpu::HostVector<amrex::Real>& h_avg_uth , amrex::Gpu::HostVector<amrex::Real>& h_avg_vth,
350 amrex::Gpu::HostVector<amrex::Real>& h_avg_wth, amrex::Gpu::HostVector<amrex::Real>& h_avg_thth,
351 amrex::Gpu::HostVector<amrex::Real>& h_avg_ku, amrex::Gpu::HostVector<amrex::Real>& h_avg_kv,
352 amrex::Gpu::HostVector<amrex::Real>& h_avg_kw,
353 amrex::Gpu::HostVector<amrex::Real>& h_avg_p,
354 amrex::Gpu::HostVector<amrex::Real>& h_avg_pu, amrex::Gpu::HostVector<amrex::Real>& h_avg_pv,
355 amrex::Gpu::HostVector<amrex::Real>& h_avg_pw, amrex::Gpu::HostVector<amrex::Real>& h_avg_wthv);
357 void derive_stress_profiles (amrex::Gpu::HostVector<amrex::Real>& h_avg_tau11, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau12,
358 amrex::Gpu::HostVector<amrex::Real>& h_avg_tau13, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau22,
359 amrex::Gpu::HostVector<amrex::Real>& h_avg_tau23, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau33,
360 amrex::Gpu::HostVector<amrex::Real>& h_avg_hfx3, amrex::Gpu::HostVector<amrex::Real>& h_avg_q1fx3,
361 amrex::Gpu::HostVector<amrex::Real>& h_avg_q2fx3, amrex::Gpu::HostVector<amrex::Real>& h_avg_diss);
362 void derive_stress_profiles_stag (amrex::Gpu::HostVector<amrex::Real>& h_avg_tau11, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau12,
363 amrex::Gpu::HostVector<amrex::Real>& h_avg_tau13, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau22,
364 amrex::Gpu::HostVector<amrex::Real>& h_avg_tau23, amrex::Gpu::HostVector<amrex::Real>& h_avg_tau33,
365 amrex::Gpu::HostVector<amrex::Real>& h_avg_hfx3, amrex::Gpu::HostVector<amrex::Real>& h_avg_q1fx3,
366 amrex::Gpu::HostVector<amrex::Real>& h_avg_q2fx3, amrex::Gpu::HostVector<amrex::Real>& h_avg_diss);
370 volWgtSumMF (
int lev,
const amrex::MultiFab& mf,
int comp,
371 const amrex::MultiFab& dJ,
const amrex::MultiFab& mfx,
const amrex::MultiFab& mfy,
372 bool finemask,
bool local =
true);
376 amrex::MultiFab& mf_2d,
const amrex::MultiFab& dJ);
386 const amrex::DistributionMapping& dm)
override;
392 const amrex::DistributionMapping& dm)
override;
402 const amrex::DistributionMapping& dm)
override;
407 #ifdef ERF_USE_WW3_COUPLING
409 void send_to_ww3(
int lev);
411 void read_waves(
int lev);
420 amrex::Vector<amrex::MultiFab>& state_old,
421 amrex::Vector<amrex::MultiFab>& state_new,
422 amrex::MultiFab& xvel_old, amrex::MultiFab& yvel_old, amrex::MultiFab& zvel_old,
423 amrex::MultiFab& xvel_new, amrex::MultiFab& yvel_new, amrex::MultiFab& zvel_new,
424 amrex::MultiFab& source, amrex::MultiFab& xmom_src,
425 amrex::MultiFab& ymom_src, amrex::MultiFab& zmom_src,
426 amrex::MultiFab& buoyancy, amrex::Geometry fine_geom,
430 amrex::MultiFab& cons_in,
432 const int& iteration,
436 amrex::MultiFab& cons_in,
437 amrex::MultiFab& xvel_in,
438 amrex::MultiFab& yvel_in,
443 amrex::MultiFab& cons_in,
446 #ifdef ERF_USE_EAMXX_SHOC
447 void compute_shoc_tendencies (
int lev,
448 amrex::MultiFab*
cons,
449 amrex::MultiFab*
xvel,
450 amrex::MultiFab*
yvel,
451 amrex::MultiFab*
zvel,
453 amrex::MultiFab*
tau13,
454 amrex::MultiFab*
tau23,
455 amrex::MultiFab* hfx3,
456 amrex::MultiFab* qfx3,
457 amrex::MultiFab* eddyDiffs,
462 #ifdef ERF_USE_NATIVE_SHOC
463 void compute_native_shoc_tendencies (
int lev,
464 amrex::MultiFab*
cons,
465 amrex::MultiFab*
xvel,
466 amrex::MultiFab*
yvel,
467 amrex::MultiFab*
zvel,
469 amrex::MultiFab*
tau13,
470 amrex::MultiFab*
tau23,
471 amrex::MultiFab* hfx3,
472 amrex::MultiFab* qfx3,
473 amrex::MultiFab* eddyDiffs,
479 void compute_p3_tendencies (
int lev,
480 amrex::MultiFab& cons_in,
481 amrex::MultiFab& source,
492 void Write3DPlotFile (
int which, PlotFileType plotfile_type, amrex::Vector<std::string> plot_var_names);
493 void Write2DPlotFile (
int which, PlotFileType plotfile_type, amrex::Vector<std::string> plot_var_names);
500 const amrex::Vector<const amrex::MultiFab*> &mf,
501 const amrex::Vector<const amrex::MultiFab*> &mf_nd,
502 const amrex::Vector<std::string> &varnames,
503 const amrex::Vector<amrex::Geometry>& my_geom,
505 const amrex::Vector<int> &level_steps,
506 const amrex::Vector<amrex::IntVect>& my_ref_ratio,
507 const std::string &versionName =
"HyperCLaw-V1.1",
508 const std::string &levelPrefix =
"Level_",
509 const std::string &mfPrefix =
"Cell",
510 const amrex::Vector<std::string>& extra_dirs = amrex::Vector<std::string>())
const;
515 const amrex::Vector<amrex::BoxArray> &bArray,
516 const amrex::Vector<std::string> &varnames,
517 const amrex::Vector<amrex::Geometry>& my_geom,
519 const amrex::Vector<int> &level_steps,
520 const amrex::Vector<amrex::IntVect>& my_ref_ratio,
521 const std::string &versionName,
522 const std::string &levelPrefix,
523 const std::string &mfPrefix)
const;
526 amrex::MultiFab&
dens, amrex::MultiFab&
pres, amrex::MultiFab&
pi,
527 amrex::MultiFab& th, amrex::MultiFab&
qv,
528 std::unique_ptr<amrex::MultiFab>& z_cc);
530 #ifdef ERF_USE_NETCDF
532 void writeToNCColumnFile (
int lev,
545 void init_thin_body (
int lev,
const amrex::BoxArray& ba,
const amrex::DistributionMapping& dm);
548 const std::string& filename,
549 const std::unique_ptr<amrex::MultiFab>&
z_phys_nd,
550 amrex::Vector<amrex::Vector<amrex::MultiFab>>& forecast_state);
553 const std::string& filename,
554 amrex::Vector<amrex::MultiFab>& surface_state);
559 amrex::Vector<std::unique_ptr<amrex::MultiFab>>&
z_phys_nd,
560 bool regrid_forces_file_read);
564 amrex::Vector<std::unique_ptr<amrex::MultiFab>>&
z_phys_nd,
565 bool regrid_forces_file_read);
568 amrex::MultiFab& mf_cc_pert,
569 amrex::MultiFab& cons_pert,
570 amrex::MultiFab& xvel_pert,
571 amrex::MultiFab& yvel_pert,
572 amrex::MultiFab& zvel_pert);
575 amrex::MultiFab& mf_cc_pert);
578 amrex::MultiFab& mf_cc_pert);
586 #ifdef ERF_USE_MULTIBLOCK
589 ERF (
const amrex::RealBox& rb,
int max_level_in,
590 const amrex::Vector<int>& n_cell_in,
int coord,
591 const amrex::Vector<amrex::IntVect>& ref_ratio,
592 const amrex::Array<int,AMREX_SPACEDIM>& is_per,
596 void Evolve_MB (
int MBstep,
int max_block_step);
599 void SetParmParsePrefix (std::string name) {
pp_prefix = name; }
602 void SetMultiBlockPointer (MultiBlockContainer *mbc) { m_mbc = mbc; }
605 std::vector<amrex::Box> domain_p;
608 amrex::Vector<amrex::Vector<amrex::MultiFab> >
vars_new;
609 amrex::Vector<amrex::Vector<amrex::MultiFab> >
vars_old;
612 amrex::Vector<amrex::Vector<amrex::MultiFab> >
gradp;
615 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
vel_t_avg;
624 #ifdef ERF_USE_NETCDF
626 void fill_from_realbdy (
const amrex::Vector<amrex::MultiFab*>& mfs,
631 amrex::IntVect ngvect_cons,
632 amrex::IntVect ngvect_vels);
635 #ifdef ERF_USE_NETCDF
636 void init_from_wrfinput (
int lev, amrex::MultiFab&
mf_PSFC);
637 void init_from_metgrid (
int lev);
638 void init_from_ncfile (
int lev);
641 #ifdef ERF_USE_WINDFARM
642 void init_windfarm(
int lev);
643 void advance_windfarm (
const amrex::Geometry& a_geom,
645 amrex::MultiFab& cons_in,
646 amrex::MultiFab& U_old,
647 amrex::MultiFab& V_old,
648 amrex::MultiFab& W_old,
649 amrex::MultiFab& mf_vars_windfarm,
650 const amrex::MultiFab& mf_Nturb,
651 const amrex::MultiFab& mf_SMark,
663 bool do_perturbational_and_momenta =
true);
683 void remake_zphys (
int lev, std::unique_ptr<amrex::MultiFab>& temp_zphys_nd);
710 void init_stuff (
int lev,
const amrex::BoxArray& ba,
const amrex::DistributionMapping& dm,
711 amrex::Vector<amrex::MultiFab>& lev_new, amrex::Vector<amrex::MultiFab>& lev_old,
712 amrex::MultiFab& tmp_base_state,
713 std::unique_ptr<amrex::MultiFab>& tmp_zphys_nd);
728 #ifdef ERF_USE_WINDFARM
730 void initializeWindFarm (
const int&);
739 const amrex::Vector<amrex::MultiFab*>& mfs_vel,
740 bool cons_only=
false);
744 const amrex::Vector<amrex::MultiFab*>& mfs_vel,
745 const amrex::Vector<amrex::MultiFab*>& mfs_mom,
746 const amrex::MultiFab& old_base_state,
747 const amrex::MultiFab& new_base_state,
748 bool fillset=
true,
bool cons_only=
false);
759 const amrex::Vector<amrex::MultiFab*>& mfs_vel,
760 const amrex::Vector<amrex::MultiFab*>& mfs_mom,
761 int ng_cons,
int ng_vel,
bool cons_only,
int icomp_cons,
int ncomp_cons);
769 void timeStep (
int lev,
double time,
int iteration);
791 void ComputeDt (
int step = -1,
double cur_time_d = 0.0);
797 static amrex::Vector<std::string>
PlotFileVarNames (amrex::Vector<std::string> plot_var_names);
800 void setPlotVariables (
const std::string& pp_plot_var_names, amrex::Vector<std::string>& plot_var_names);
801 void setPlotVariables2D (
const std::string& pp_plot_var_names, amrex::Vector<std::string>& plot_var_names);
803 void appendPlotVariables (
const std::string& pp_plot_var_names, amrex::Vector<std::string>& plot_var_names);
805 void setSubVolVariables (
const std::string& pp_subvol_var_names, amrex::Vector<std::string>& subvol_var_names);
807 #ifdef ERF_USE_NETCDF
809 void createNCColumnFile (
int lev,
813 void init_from_wrfbdy (amrex::Vector<amrex::FArrayBox*> x_vel_lateral,
814 amrex::Vector<amrex::FArrayBox*> y_vel_lateral,
815 amrex::Vector<amrex::FArrayBox*> z_vel_lateral,
816 amrex::Vector<amrex::FArrayBox*> T_lateral);
818 static double start_bdy_time;
819 static double final_bdy_time;
821 static double start_low_time;
822 static double final_low_time;
824 static double bdy_time_interval;
825 static double low_time_interval;
837 amrex::Vector<amrex::Vector<amrex::FArrayBox>> bdy_data_xlo;
838 amrex::Vector<amrex::Vector<amrex::FArrayBox>> bdy_data_xhi;
839 amrex::Vector<amrex::Vector<amrex::FArrayBox>> bdy_data_ylo;
840 amrex::Vector<amrex::Vector<amrex::FArrayBox>> bdy_data_yhi;
842 amrex::Vector<amrex::Vector<amrex::FArrayBox>> low_data_zlo;
849 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
lat_m,
lon_m;
863 amrex::Vector<amrex::Gpu::DeviceVector<amrex::Real>>
th_bc_data;
881 void fill_rhs (amrex::MultiFab& rhs_mf,
const amrex::MultiFab& state_mf,
amrex::Real time,
const amrex::Geometry& geom);
886 std::unique_ptr<ProblemBase>
prob =
nullptr;
898 amrex::Vector<amrex::Real>
dt;
901 #ifndef ERF_USE_MULTIBLOCK
904 amrex::Vector<amrex::Vector<amrex::MultiFab> >
vars_new;
905 amrex::Vector<amrex::Vector<amrex::MultiFab> >
vars_old;
908 amrex::Vector<amrex::Vector<amrex::MultiFab> >
gradp;
911 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
vel_t_avg;
914 amrex::Vector<std::unique_ptr<MRISplitIntegrator<amrex::Vector<amrex::MultiFab> > > >
mri_integrator_mem;
927 amrex::Vector<std::unique_ptr<ERFPhysBCFunct_u>>
physbcs_u;
928 amrex::Vector<std::unique_ptr<ERFPhysBCFunct_v>>
physbcs_v;
929 amrex::Vector<std::unique_ptr<ERFPhysBCFunct_w>>
physbcs_w;
934 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
Qv_prim;
935 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
Qr_prim;
949 std::unique_ptr<Microphysics>
micro;
950 amrex::Vector<amrex::Vector<amrex::MultiFab*>>
qmoist;
954 #ifdef ERF_USE_WINDFARM
955 std::unique_ptr<WindFarm> windfarm;
956 amrex::Vector<amrex::MultiFab> Nturb;
957 amrex::Vector<amrex::MultiFab> vars_windfarm;
960 amrex::Vector<amrex::MultiFab> SMark;
967 amrex::Vector<amrex::Vector<amrex::MultiFab*>>
lsm_data;
969 amrex::Vector<amrex::Vector<amrex::MultiFab*>>
lsm_flux;
971 amrex::Vector<std::unique_ptr<IRadiation>>
rad;
974 #ifdef ERF_USE_EAMXX_SHOC
975 amrex::Vector<std::unique_ptr<SHOCInterface>> eamxx_shoc_interface;
978 #ifdef ERF_USE_NATIVE_SHOC
979 amrex::Vector<std::unique_ptr<ShocDriver>> native_shoc_driver;
983 amrex::Vector<std::unique_ptr<P3Interface>> p3_interface;
992 amrex::Vector<ERFFillPatcher>
FPr_c;
993 amrex::Vector<ERFFillPatcher>
FPr_u;
994 amrex::Vector<ERFFillPatcher>
FPr_v;
995 amrex::Vector<ERFFillPatcher>
FPr_w;
998 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
Tau;
999 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
Tau_corr;
1004 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
sst_lev;
1005 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
tsk_lev;
1006 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::iMultiFab>>>
lmask_lev;
1011 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
urb_frac_lev;
1021 amrex::Vector<amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>>
Tau_EB;
1022 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
hfx3_EB;
1023 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
qfx3_EB;
1032 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
detJ_cc;
1033 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
ax;
1034 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
ay;
1035 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
az;
1040 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
ax_src;
1041 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
ay_src;
1042 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
az_src;
1047 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
z_t_rk;
1053 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
walldist;
1056 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
mapfac;
1068 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
Hwave;
1069 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
Lwave;
1207 const amrex::Vector<std::string>
cons_names {
"density",
"rhotheta",
"rhoKE",
"rhoadv_0",
1208 "rhoQ1",
"rhoQ2",
"rhoQ3",
1209 "rhoQ4",
"rhoQ5",
"rhoQ6",
1210 "rhoQ7",
"rhoQ8",
"rhoQ9",
1211 "rhoQ10",
"rhoQ11"};
1216 const amrex::Vector<std::string>
derived_names {
"temp",
"theta",
"KE",
"scalar",
"soundspeed",
1217 "reflectivity",
"max_reflectivity",
"precipitable",
"mucape",
1218 "vorticity_x",
"vorticity_y",
"vorticity_z",
1219 "helicity",
"local_helicity",
1221 "pres_hse",
"dens_hse",
"theta_hse",
"qv_hse",
1222 "pressure",
"pert_pres",
"pert_dens",
1223 "buoyancy",
"eq_pot_temp",
"VPD",
1224 #ifdef ERF_USE_WINDFARM
1225 "num_turb",
"SMark0",
"SMark1",
1227 "dpdx",
"dpdy",
"dpdz",
"pres_hse_x",
"pres_hse_y",
1228 "z_phys",
"detJ",
"mapfac",
"lat_m",
"lon_m",
1230 "u_t_avg",
"v_t_avg",
"w_t_avg",
"umag_t_avg",
1240 "pblh",
"shoc_cldfrac",
"shoc_ql",
"shoc_ql2",
"shoc_cond",
1241 "wqls_sec",
"wthv_sec",
"w_sec",
1242 "thl_sec",
"qw_sec",
"qwthl_sec",
"wthl_sec",
"wqw_sec",
"w3",
1243 "brunt",
"isotropy",
"shear_prod",
"buoy_prod",
"diss_tke",
1249 "moist_density",
"qv",
"qc",
"qi",
"qrain",
"qsnow",
"qgraup",
1250 "qt",
"qn",
"qp",
"qsat",
"nc",
"ni",
"nr",
"ns",
"ng",
1251 "rain_accum",
"snow_accum",
"graup_accum",
1252 "rel_humidity",
"condensation_rate",
1257 #ifdef ERF_COMPUTE_ERROR
1259 ,
"xvel_err",
"yvel_err",
"zvel_err",
"pp_err"
1261 ,
"qsrc_sw",
"qsrc_lw"
1275 #ifdef ERF_USE_PARTICLES
1277 ParticleData particleData;
1280 bool m_use_tracer_particles;
1283 void readTracersParams();
1286 void initializeTracers ( amrex::ParGDBBase*,
1287 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>&,
1291 void restartTracers ( amrex::ParGDBBase*,
const std::string& );
1294 void evolveTracers(
int,
1296 amrex::Vector<amrex::Vector<amrex::MultiFab>>&,
1297 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& );
1301 #ifdef ERF_USE_MULTIBLOCK
1302 MultiBlockContainer *m_mbc =
nullptr;
1360 amrex::Vector<amrex::BoxArray>
ba1d;
1361 amrex::Vector<amrex::BoxArray>
ba2d;
1370 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
mf_PSFC;
1397 amrex::Vector<amrex::Gpu::DeviceVector<amrex::Real> >
d_w_subsid;
1400 amrex::Vector<amrex::Gpu::DeviceVector<amrex::Real> >
d_u_geos;
1403 amrex::Vector<amrex::Gpu::DeviceVector<amrex::Real> >
d_v_geos;
1407 amrex::Vector<amrex::Real>& u_geos,
1408 amrex::Gpu::DeviceVector<amrex::Real>& u_geos_d,
1409 amrex::Vector<amrex::Real>& v_geos,
1410 amrex::Gpu::DeviceVector<amrex::Real>& v_geos_d,
1411 const amrex::Geometry& lgeom,
1412 const amrex::Vector<amrex::Real>& zlev_stag);
1424 amrex::Vector<amrex::Vector<amrex::Gpu::DeviceVector<amrex::Real> > >
d_sponge_ptrs;
1444 std::unique_ptr<WriteBndryPlanes>
m_w2d =
nullptr;
1445 std::unique_ptr<ReadBndryPlanes>
m_r2d =
nullptr;
1458 static AMREX_FORCE_INLINE
1541 return static_cast<int>(
datalog.size());
1612 int numCores = amrex::ParallelDescriptor::NProcs();
1614 numCores = numCores * omp_get_max_threads();
1626 if (amrex::ParallelDescriptor::IOProcessor())
1628 datalog[i] = std::make_unique<std::fstream>();
1631 amrex::FileOpenFailed(filename);
1634 amrex::ParallelDescriptor::Barrier(
"ERF::setRecordDataInfo");
1639 if (amrex::ParallelDescriptor::IOProcessor())
1641 der_datalog[i] = std::make_unique<std::fstream>();
1644 amrex::FileOpenFailed(filename);
1647 amrex::ParallelDescriptor::Barrier(
"ERF::setRecordDerDataInfo");
1652 if (amrex::ParallelDescriptor::IOProcessor())
1657 amrex::FileOpenFailed(filename);
1660 amrex::ParallelDescriptor::Barrier(
"ERF::setRecordEnergyDataInfo");
1665 amrex::MultiFab dummy(grids[lev],dmap[lev],1,0);
1666 for (amrex::MFIter mfi(dummy); mfi.isValid(); ++mfi)
1668 const amrex::Box& bx = mfi.validbox();
1669 if (bx.contains(cell)) {
1670 sampleptlog[i] = std::make_unique<std::fstream>();
1673 amrex::FileOpenFailed(filename);
1677 amrex::ParallelDescriptor::Barrier(
"ERF::setRecordSamplePointInfo");
1682 amrex::MultiFab dummy(grids[lev],dmap[lev],1,0);
1683 for (amrex::MFIter mfi(dummy); mfi.isValid(); ++mfi)
1685 const amrex::Box& bx = mfi.validbox();
1686 if (bx.contains(cell)) {
1690 amrex::FileOpenFailed(filename);
1694 amrex::ParallelDescriptor::Barrier(
"ERF::setRecordSampleLineInfo");
1705 amrex::Vector<std::unique_ptr<std::fstream> >
datalog;
1731 amrex::Vector<std::unique_ptr<eb_>>
eb;
1734 AMREX_ASSERT(lev >= 0 && lev <
eb.size() &&
eb[lev] !=
nullptr);
1738 [[nodiscard]] amrex::EBFArrayBoxFactory
const&
1740 return *(
eb[lev]->get_const_factory());
1755 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::FFT::Poisson<amrex::MultiFab>>>> m_3D_poisson;
1756 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::FFT::PoissonHybrid<amrex::MultiFab>>>> m_2D_poisson;
1764 static void print_usage(MPI_Comm , std::ostream& );
1765 static void print_error(MPI_Comm ,
const std::string& msg);
AMREX_ENUM(StateInterpType, FullState, Perturbational)
constexpr amrex::Real one
Definition: ERF_Constants.H:9
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
@ tau23
Definition: ERF_DataStruct.H:32
@ tau13
Definition: ERF_DataStruct.H:32
Contains the Eulerian microphysics class.
#define NBCVAR_max
Definition: ERF_IndexDefines.H:29
Real T
Definition: ERF_InitCustomPert_Bubble.H:105
Contains the Lagrangian microphysics class.
amrex::Real Real
Definition: ERF_ShocInterface.H:19
void SurfaceDataInterpolation(const int nlevs, const amrex::Real time, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &z_phys_nd, bool regrid_forces_file_read)
Definition: ERF_SurfaceDataInterpolation.cpp:142
void MakeHorizontalAverages()
Definition: ERF.cpp:2565
amrex::Vector< amrex::MultiFab > rU_new
Definition: ERF.H:939
static int last_check_file_step
Definition: ERF.H:1113
amrex::Vector< std::unique_ptr< amrex::MultiFab > > walldist
Definition: ERF.H:1053
amrex::Vector< amrex::Vector< amrex::Vector< amrex::Real > > > h_sponge_ptrs
Definition: ERF.H:1416
static amrex::Real start_time
Definition: ERF.H:1139
bool metgrid_basic_linear
Definition: ERF.H:1346
amrex::Vector< amrex::Vector< amrex::Box > > boxes_at_level
Definition: ERF.H:890
amrex::Vector< std::string > samplelinelogname
Definition: ERF.H:1717
int max_step
Definition: ERF.H:1136
bool metgrid_debug_msf
Definition: ERF.H:1344
AMREX_FORCE_INLINE std::ostream & DerDataLog(int i)
Definition: ERF.H:1532
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > mapfac
Definition: ERF.H:1056
void setRayleighRefFromSounding(bool restarting)
Set Rayleigh mean profiles from input sounding.
Definition: ERF_InitRayleigh.cpp:83
amrex::Vector< std::unique_ptr< MRISplitIntegrator< amrex::Vector< amrex::MultiFab > > > > mri_integrator_mem
Definition: ERF.H:914
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > d_sinesq_stag_ptrs
Definition: ERF.H:1428
void check_vels_for_nans(amrex::MultiFab const &xvel, amrex::MultiFab const &yvel, amrex::MultiFab const &zvel)
Definition: ERF.cpp:2857
void Evolve()
Definition: ERF.cpp:137
amrex::Vector< amrex::MultiFab > avg_xmom
Definition: ERF.H:921
amrex::Vector< amrex::MultiFab > pp_inc
Definition: ERF.H:917
static amrex::Real last_plot2d_file_time_2
Definition: ERF.H:1118
amrex::Vector< ERFFillPatcher > FPr_u
Definition: ERF.H:993
amrex::Vector< amrex::IntVect > sampleline
Definition: ERF.H:1718
amrex::Vector< std::string > subvol3d_var_names
Definition: ERF.H:1201
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_q1fx3_lev
Definition: ERF.H:1016
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Hwave_onegrid
Definition: ERF.H:1070
amrex::Vector< amrex::Vector< amrex::MultiFab > > vars_new
Definition: ERF.H:904
void WriteAtIntermediateTime(int nstep, double time)
Definition: ERF.cpp:235
ERF(ERF &&) noexcept=delete
void project_initial_velocity(int lev, amrex::Real time, amrex::Real dt)
Definition: ERF_PoissonSolve.cpp:31
void FillBdyCCVels(amrex::MultiFab &mf_cc_vel, amrex::Geometry &lev_geom)
Definition: ERF_FillBdyCCVels.cpp:11
AMREX_FORCE_INLINE int NumSampleLineLogs() noexcept
Definition: ERF.H:1575
static void print_tpls(std::ostream &)
Definition: ERF_ConsoleIO.cpp:137
amrex::Vector< amrex::Real > dz_min
Definition: ERF.H:1456
amrex::Real m_plot2d_per_1
Definition: ERF.H:1186
amrex::Vector< amrex::MultiFab > lagged_delta_rt
Definition: ERF.H:920
amrex::Real plane_sampling_per
Definition: ERF.H:1701
std::string DataLogName(int i) const noexcept
The filename of the ith datalog file.
Definition: ERF.H:1721
std::string plot2d_file_2
Definition: ERF.H:1173
void remake_zphys(int lev, std::unique_ptr< amrex::MultiFab > &temp_zphys_nd)
Definition: ERF_MakeNewArrays.cpp:796
amrex::Vector< std::unique_ptr< amrex::MultiFab > > thin_yforce
Definition: ERF.H:1106
void ErrorEst(int lev, amrex::TagBoxArray &tags, amrex::Real time, int ngrow) override
Definition: ERF_Tagging.cpp:25
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_hfx3_lev
Definition: ERF.H:1014
amrex::Vector< amrex::Vector< amrex::Real > > h_w_subsid
Definition: ERF.H:1396
static void print_banner(MPI_Comm, std::ostream &)
Definition: ERF_ConsoleIO.cpp:60
void volWgtColumnSum(int lev, const amrex::MultiFab &mf, int comp, amrex::MultiFab &mf_2d, const amrex::MultiFab &dJ)
Definition: ERF_VolWgtSum.cpp:82
static amrex::Real last_plot2d_file_time_1
Definition: ERF.H:1117
amrex::Vector< std::unique_ptr< std::fstream > > datalog
Definition: ERF.H:1705
static amrex::Real sum_per
Definition: ERF.H:1314
std::string MakeFilename_EyeTracker_maxvel(int nstep)
Definition: ERF_TrackerOutput.cpp:66
amrex::Vector< ERFFillPatcher > FPr_v
Definition: ERF.H:994
int cf_set_width
Definition: ERF.H:991
std::unique_ptr< amrex::MultiFab > wrf_MUB
Definition: ERF.H:1365
static amrex::Real previousCPUTimeUsed
Definition: ERF.H:1607
void setPlotVariables(const std::string &pp_plot_var_names, amrex::Vector< std::string > &plot_var_names)
Definition: ERF_Plotfile.cpp:14
amrex::Gpu::DeviceVector< amrex::Real > d_havg_temperature
Definition: ERF.H:1437
std::unique_ptr< amrex::MultiFab > wrf_C1H
Definition: ERF.H:1363
std::string erfbdy_file
Definition: ERF.H:1357
static int last_plot2d_file_step_2
Definition: ERF.H:1112
void fill_from_bndryregs(const amrex::Vector< amrex::MultiFab * > &mfs, amrex::Real time)
Definition: ERF_BoundaryConditionsBndryReg.cpp:13
const int timeprecision
Definition: ERF.H:1129
void setRecordDataInfo(int i, const std::string &filename)
Definition: ERF.H:1624
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_hfx1_lev
Definition: ERF.H:1014
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_eye_track_xy
Definition: ERF.H:169
amrex::Vector< amrex::BoxArray > ba2d
Definition: ERF.H:1361
amrex::Array< amrex::Array< amrex::Real, AMREX_SPACEDIM *2 >, AMREX_SPACEDIM+NBCVAR_max > m_bc_extdir_vals
Definition: ERF.H:1087
void ComputeGlobalMinLocation_WRF(const amrex::Geometry &geom, const amrex::Vector< amrex::MultiFab > &S_data, amrex::Real *d_val_min_ptr, int *d_i_min_ptr, int *d_j_min_ptr, amrex::Real &global_val_min, int &global_i_min, int &global_j_min)
Definition: ERF_HurricaneDiagnostics_WRF.cpp:36
void HurricaneEyeTrackerInitial_WRF(const amrex::Geometry &geom, const amrex::Vector< amrex::MultiFab > &S_data, const amrex::Real &hurricane_eye_latitude, const amrex::Real &hurricane_eye_longitude)
Definition: ERF_HurricaneDiagnostics_WRF.cpp:157
void init_from_input_sounding(int lev)
Definition: ERF_InitFromInputSounding.cpp:53
void erf_enforce_hse(int lev, amrex::MultiFab &dens, amrex::MultiFab &pres, amrex::MultiFab &pi, amrex::MultiFab &th, amrex::MultiFab &qv, std::unique_ptr< amrex::MultiFab > &z_cc)
Definition: ERF_Init1D.cpp:210
amrex::Vector< amrex::Vector< amrex::MultiFab > > gradp
Definition: ERF.H:908
std::string plot3d_file_1
Definition: ERF.H:1170
eb_ const & get_eb(int lev) const noexcept
Definition: ERF.H:1733
amrex::Gpu::DeviceVector< amrex::Real > d_havg_qv
Definition: ERF.H:1439
amrex::Vector< std::unique_ptr< amrex::MultiFab > > qfx3_EB
Definition: ERF.H:1023
static amrex::Real column_loc_y
Definition: ERF.H:1377
static bool plot_file_on_restart
Definition: ERF.H:1124
amrex::Vector< amrex::Vector< amrex::MultiFab > > bckgnd_state
Definition: ERF.H:182
static int mg_verbose
Definition: ERF.H:1306
void ReadParameters()
Definition: ERF.cpp:1950
static amrex::Vector< std::string > PlotFileVarNames(amrex::Vector< std::string > plot_var_names)
Definition: ERF_Plotfile.cpp:253
amrex::Vector< amrex::Vector< amrex::MultiFab > > forecast_state_interp
Definition: ERF.H:177
bool FindInitialEye(int lev, const amrex::MultiFab &cc_vel, const amrex::Real velmag_threshold, amrex::Real &eye_x, amrex::Real &eye_y)
Definition: ERF_RefineHurricane.cpp:11
void InitializeFromFile()
amrex::Vector< std::unique_ptr< ERFPhysBCFunct_cons > > physbcs_cons
Definition: ERF.H:926
void project_velocity_tb(int lev, amrex::Real dt, amrex::Vector< amrex::MultiFab > &vars)
Definition: ERF_PoissonSolve_tb.cpp:22
amrex::Vector< std::unique_ptr< amrex::MultiFab > > mf_PSFC
Definition: ERF.H:1370
ERF()
Definition: ERF_Constructors.cpp:21
void init_Dirichlet_bc_data(const std::string input_file)
Definition: ERF_InitBCs.cpp:735
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_phys_nd_src
Definition: ERF.H:1037
amrex::Vector< std::unique_ptr< amrex::MultiFab > > detJ_cc
Definition: ERF.H:1032
amrex::Vector< std::string > lsm_flux_name
Definition: ERF.H:968
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_phys_cc
Definition: ERF.H:1030
amrex::Vector< std::unique_ptr< eb_ > > eb
Definition: ERF.H:1731
amrex::Vector< std::unique_ptr< amrex::MultiFab > > eddyDiffs_lev
Definition: ERF.H:1000
static SolverChoice solverChoice
Definition: ERF.H:1270
amrex::Vector< std::unique_ptr< amrex::MultiFab > > hfx3_EB
Definition: ERF.H:1022
amrex::Vector< ERFFillPatcher > FPr_c
Definition: ERF.H:992
bool plot_rad
Definition: ERF.H:986
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_tracker_circle
Definition: ERF.H:173
static bool use_fft
Definition: ERF.H:1307
bool m_plot_face_vels
Definition: ERF.H:1188
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_maxvel_vs_time
Definition: ERF.H:171
void sum_derived_quantities(double time)
Definition: ERF_WriteScalarProfiles.cpp:177
amrex::Vector< amrex::MultiFab > base_state_new
Definition: ERF.H:1065
std::string plot3d_file_2
Definition: ERF.H:1171
amrex::Vector< std::unique_ptr< amrex::MultiFab > > az
Definition: ERF.H:1035
int regrid_int
Definition: ERF.H:1163
amrex::Vector< amrex::Real > fixed_dt
Definition: ERF.H:1157
void derive_diag_profiles(double time, amrex::Gpu::HostVector< amrex::Real > &h_avg_u, amrex::Gpu::HostVector< amrex::Real > &h_avg_v, amrex::Gpu::HostVector< amrex::Real > &h_avg_w, amrex::Gpu::HostVector< amrex::Real > &h_avg_rho, amrex::Gpu::HostVector< amrex::Real > &h_avg_th, amrex::Gpu::HostVector< amrex::Real > &h_avg_ksgs, amrex::Gpu::HostVector< amrex::Real > &h_avg_Kmv, amrex::Gpu::HostVector< amrex::Real > &h_avg_Khv, amrex::Gpu::HostVector< amrex::Real > &h_avg_qv, amrex::Gpu::HostVector< amrex::Real > &h_avg_qc, amrex::Gpu::HostVector< amrex::Real > &h_avg_qr, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqv, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqc, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqr, amrex::Gpu::HostVector< amrex::Real > &h_avg_qi, amrex::Gpu::HostVector< amrex::Real > &h_avg_qs, amrex::Gpu::HostVector< amrex::Real > &h_avg_qg, amrex::Gpu::HostVector< amrex::Real > &h_avg_uu, amrex::Gpu::HostVector< amrex::Real > &h_avg_uv, amrex::Gpu::HostVector< amrex::Real > &h_avg_uw, amrex::Gpu::HostVector< amrex::Real > &h_avg_vv, amrex::Gpu::HostVector< amrex::Real > &h_avg_vw, amrex::Gpu::HostVector< amrex::Real > &h_avg_ww, amrex::Gpu::HostVector< amrex::Real > &h_avg_uth, amrex::Gpu::HostVector< amrex::Real > &h_avg_vth, amrex::Gpu::HostVector< amrex::Real > &h_avg_wth, amrex::Gpu::HostVector< amrex::Real > &h_avg_thth, amrex::Gpu::HostVector< amrex::Real > &h_avg_ku, amrex::Gpu::HostVector< amrex::Real > &h_avg_kv, amrex::Gpu::HostVector< amrex::Real > &h_avg_kw, amrex::Gpu::HostVector< amrex::Real > &h_avg_p, amrex::Gpu::HostVector< amrex::Real > &h_avg_pu, amrex::Gpu::HostVector< amrex::Real > &h_avg_pv, amrex::Gpu::HostVector< amrex::Real > &h_avg_pw, amrex::Gpu::HostVector< amrex::Real > &h_avg_wthv)
Definition: ERF_Write1DProfiles.cpp:190
void WriteGenericPlotfileHeaderWithTerrain(std::ostream &HeaderFile, int nlevels, const amrex::Vector< amrex::BoxArray > &bArray, const amrex::Vector< std::string > &varnames, const amrex::Vector< amrex::Geometry > &my_geom, amrex::Real time, const amrex::Vector< int > &level_steps, const amrex::Vector< amrex::IntVect > &my_ref_ratio, const std::string &versionName, const std::string &levelPrefix, const std::string &mfPrefix) const
Definition: ERF_Plotfile.cpp:2031
bool write_erfbdy
Definition: ERF.H:1355
void solve_with_gmres(int lev, const amrex::Box &subdomain, amrex::MultiFab &rhs, amrex::MultiFab &p, amrex::Array< amrex::MultiFab, AMREX_SPACEDIM > &fluxes, amrex::MultiFab &ax_sub, amrex::MultiFab &ay_sub, amrex::MultiFab &az_sub, amrex::MultiFab &, amrex::MultiFab &znd_sub)
Definition: ERF_SolveWithGMRES.cpp:12
amrex::Vector< amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > > d_sponge_ptrs
Definition: ERF.H:1424
amrex::Vector< long > dt_mri_ratio
Definition: ERF.H:899
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > Tau
Definition: ERF.H:998
amrex::Vector< std::unique_ptr< amrex::MultiFab > > vel_t_avg
Definition: ERF.H:911
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_q2fx3_lev
Definition: ERF.H:1017
static amrex::Real dt_max
Definition: ERF.H:1154
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::iMultiFab > > > lmask_lev
Definition: ERF.H:1006
AMREX_FORCE_INLINE int NumSamplePointLogs() noexcept
Definition: ERF.H:1561
amrex::Vector< amrex::Real > h_havg_pressure
Definition: ERF.H:1432
void update_diffusive_arrays(int lev, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm)
Definition: ERF_MakeNewArrays.cpp:527
std::unique_ptr< amrex::MultiFab > wrf_PHB
Definition: ERF.H:1368
static int verbose
Definition: ERF.H:1305
amrex::Vector< amrex::Real > h_havg_qc
Definition: ERF.H:1434
amrex::Vector< std::unique_ptr< ERFPhysBCFunct_w > > physbcs_w
Definition: ERF.H:929
static int nghost_eb_basic()
Definition: ERF.H:1743
void AverageDownMoistStateTo(int crse_lev)
Conservation-preserving fine→coarse average of moist state components (RhoTheta and the contiguous mo...
Definition: ERF_AverageDown.cpp:243
void Advance(int lev, amrex::Real time, amrex::Real dt_lev, int iteration, int ncycle)
Definition: ERF_Advance.cpp:20
void FillForecastStateMultiFabs(const int lev, const std::string &filename, const std::unique_ptr< amrex::MultiFab > &z_phys_nd, amrex::Vector< amrex::Vector< amrex::MultiFab >> &forecast_state)
Definition: ERF_WeatherDataInterpolation.cpp:64
static std::string column_file_name
Definition: ERF.H:1378
amrex::Vector< std::unique_ptr< std::fstream > > samplelinelog
Definition: ERF.H:1716
static amrex::Real last_plot3d_file_time_2
Definition: ERF.H:1116
amrex::Vector< std::unique_ptr< amrex::MultiFab > > terrain_blanking
Definition: ERF.H:1050
std::unique_ptr< Microphysics > micro
Definition: ERF.H:949
int m_plot2d_int_2
Definition: ERF.H:1179
amrex::Vector< amrex::MultiFab > base_state
Definition: ERF.H:1064
AMREX_FORCE_INLINE amrex::YAFluxRegister * getAdvFluxReg(int lev)
Definition: ERF.H:1518
int m_plot3d_int_1
Definition: ERF.H:1176
amrex::Vector< amrex::Real > h_havg_density
Definition: ERF.H:1430
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_phys_nd_new
Definition: ERF.H:1044
amrex::Vector< amrex::Real > fixed_fast_dt
Definition: ERF.H:1158
void derive_diag_profiles_stag(double time, amrex::Gpu::HostVector< amrex::Real > &h_avg_u, amrex::Gpu::HostVector< amrex::Real > &h_avg_v, amrex::Gpu::HostVector< amrex::Real > &h_avg_w, amrex::Gpu::HostVector< amrex::Real > &h_avg_rho, amrex::Gpu::HostVector< amrex::Real > &h_avg_th, amrex::Gpu::HostVector< amrex::Real > &h_avg_ksgs, amrex::Gpu::HostVector< amrex::Real > &h_avg_Kmv, amrex::Gpu::HostVector< amrex::Real > &h_avg_Khv, amrex::Gpu::HostVector< amrex::Real > &h_avg_qv, amrex::Gpu::HostVector< amrex::Real > &h_avg_qc, amrex::Gpu::HostVector< amrex::Real > &h_avg_qr, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqv, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqc, amrex::Gpu::HostVector< amrex::Real > &h_avg_wqr, amrex::Gpu::HostVector< amrex::Real > &h_avg_qi, amrex::Gpu::HostVector< amrex::Real > &h_avg_qs, amrex::Gpu::HostVector< amrex::Real > &h_avg_qg, amrex::Gpu::HostVector< amrex::Real > &h_avg_uu, amrex::Gpu::HostVector< amrex::Real > &h_avg_uv, amrex::Gpu::HostVector< amrex::Real > &h_avg_uw, amrex::Gpu::HostVector< amrex::Real > &h_avg_vv, amrex::Gpu::HostVector< amrex::Real > &h_avg_vw, amrex::Gpu::HostVector< amrex::Real > &h_avg_ww, amrex::Gpu::HostVector< amrex::Real > &h_avg_uth, amrex::Gpu::HostVector< amrex::Real > &h_avg_vth, amrex::Gpu::HostVector< amrex::Real > &h_avg_wth, amrex::Gpu::HostVector< amrex::Real > &h_avg_thth, amrex::Gpu::HostVector< amrex::Real > &h_avg_ku, amrex::Gpu::HostVector< amrex::Real > &h_avg_kv, amrex::Gpu::HostVector< amrex::Real > &h_avg_kw, amrex::Gpu::HostVector< amrex::Real > &h_avg_p, amrex::Gpu::HostVector< amrex::Real > &h_avg_pu, amrex::Gpu::HostVector< amrex::Real > &h_avg_pv, amrex::Gpu::HostVector< amrex::Real > &h_avg_pw, amrex::Gpu::HostVector< amrex::Real > &h_avg_wthv)
Definition: ERF_Write1DProfiles_stag.cpp:296
void create_background_state_for_ensemble(int lev, amrex::MultiFab &mf_cc_pert, amrex::MultiFab &cons_pert, amrex::MultiFab &xvel_pert, amrex::MultiFab &yvel_pert, amrex::MultiFab &zvel_pert)
Definition: ERF_InitForEnsemble.cpp:515
void project_momenta(int lev, amrex::Real l_time, amrex::Real l_dt, amrex::Vector< amrex::MultiFab > &vars)
Definition: ERF_PoissonSolve.cpp:102
const amrex::Vector< std::string > derived_subvol_names
Definition: ERF.H:1267
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_minpressure_vs_time
Definition: ERF.H:172
bool metgrid_retain_sfc
Definition: ERF.H:1349
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Qv_prim
Definition: ERF.H:934
static int sum_interval
Definition: ERF.H:1312
static int pert_interval
Definition: ERF.H:1313
amrex::Real line_sampling_per
Definition: ERF.H:1700
void restart()
Definition: ERF.cpp:1756
static int last_plot3d_file_step_2
Definition: ERF.H:1110
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_q1fx2_lev
Definition: ERF.H:1016
amrex::IntVect & SampleLine(int i)
Definition: ERF.H:1594
void build_fine_mask(int lev, amrex::MultiFab &fine_mask)
Definition: ERF_VolWgtSum.cpp:125
int file_name_digits
Definition: ERF.H:1322
amrex::Vector< amrex::MultiFab > rV_new
Definition: ERF.H:941
std::string PlotFileName(int lev) const
void initialize_integrator(int lev, amrex::MultiFab &cons_mf, amrex::MultiFab &vel_mf)
Definition: ERF_MakeNewArrays.cpp:878
amrex::Vector< std::unique_ptr< amrex::MultiFab > > thin_zforce
Definition: ERF.H:1107
amrex::Vector< std::string > plot3d_var_names_2
Definition: ERF.H:1204
amrex::Vector< amrex::BCRec > domain_bcs_type
Definition: ERF.H:1080
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Qr_prim
Definition: ERF.H:935
void HurricaneEyeTrackerNotInitial_WRF(const amrex::Geometry &geom, const amrex::Vector< amrex::MultiFab > &S_data, MoistureType moisture_type)
Definition: ERF_HurricaneDiagnostics_WRF.cpp:204
void apply_gaussian_smoothing_to_perturbations(const int lev, amrex::MultiFab &mf_cc_pert)
Definition: ERF_InitForEnsemble.cpp:86
std::string pp_prefix
Definition: ERF.H:619
std::string SampleLineLogName(int i) const noexcept
The filename of the ith samplelinelog file.
Definition: ERF.H:1728
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > sst_lev
Definition: ERF.H:1004
amrex::Vector< std::string > plot2d_var_names_1
Definition: ERF.H:1205
amrex::Vector< std::unique_ptr< amrex::MultiFab > > thin_xforce
Definition: ERF.H:1105
AMREX_FORCE_INLINE int NumSamplePoints() noexcept
Definition: ERF.H:1588
bool metgrid_use_sfc
Definition: ERF.H:1348
amrex::Real m_plot2d_per_2
Definition: ERF.H:1187
bool writeNow(double cur_time, const int nstep, const int plot_int, const amrex::Real plot_per, const amrex::Real dt_0, amrex::Real &last_file_time)
Definition: ERF.cpp:2769
static amrex::Real bndry_output_planes_per
Definition: ERF.H:1383
void setPlotVariables2D(const std::string &pp_plot_var_names, amrex::Vector< std::string > &plot_var_names)
Definition: ERF_Plotfile2D.cpp:93
amrex::Real m_check_per
Definition: ERF.H:1199
void init_custom(int lev)
Definition: ERF_InitCustomPertState.cpp:26
amrex::Vector< std::unique_ptr< IRadiation > > rad
Definition: ERF.H:971
void ComputeAndWriteEnsemblePerturbations()
std::unique_ptr< ProblemBase > prob
Definition: ERF.H:886
amrex::Vector< int > num_files_at_level
Definition: ERF.H:889
void WriteMultiLevelPlotfileWithTerrain(const std::string &plotfilename, int nlevels, const amrex::Vector< const amrex::MultiFab * > &mf, const amrex::Vector< const amrex::MultiFab * > &mf_nd, const amrex::Vector< std::string > &varnames, const amrex::Vector< amrex::Geometry > &my_geom, amrex::Real time, const amrex::Vector< int > &level_steps, const amrex::Vector< amrex::IntVect > &my_ref_ratio, const std::string &versionName="HyperCLaw-V1.1", const std::string &levelPrefix="Level_", const std::string &mfPrefix="Cell", const amrex::Vector< std::string > &extra_dirs=amrex::Vector< std::string >()) const
Definition: ERF_Plotfile.cpp:1944
void init_bcs()
Definition: ERF_InitBCs.cpp:299
amrex::Real EvolveOneStep(amrex::Real time, amrex::Real dt_request)
Definition: ERF_Coupling.cpp:15
int profile_int
Definition: ERF.H:1193
bool metgrid_debug_quiescent
Definition: ERF.H:1340
amrex::Vector< std::unique_ptr< ERFPhysBCFunct_u > > physbcs_u
Definition: ERF.H:927
amrex::Vector< amrex::Real > t_new
Definition: ERF.H:896
bool destag_profiles
Definition: ERF.H:1194
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > stretched_dz_d
Definition: ERF.H:1062
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > th_bc_data
Definition: ERF.H:863
amrex::Vector< amrex::Real > t_avg_cnt
Definition: ERF.H:912
std::string DerDataLogName(int i) const noexcept
Definition: ERF.H:1722
void compute_max_pressure_gradient_diagnostic(int lev)
Definition: ERF_Diagnostics.cpp:12
int m_check_int
Definition: ERF.H:1198
void ReadVelsOnlyFromCheckpointFile(int lev_to_fill, std::string &chkfile)
Definition: ERF_Checkpoint.cpp:1182
amrex::Real estTimeStep(int lev, long &dt_fast_ratio) const
Definition: ERF_ComputeTimestep.cpp:60
static amrex::Real startCPUTime
Definition: ERF.H:1606
amrex::Vector< amrex::MultiFab > surface_state_1
Definition: ERF.H:178
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_diss_lev
Definition: ERF.H:1015
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > d_sinesq_ptrs
Definition: ERF.H:1427
amrex::Vector< amrex::MultiFab > rU_old
Definition: ERF.H:938
void FillIntermediatePatch(int lev, amrex::Real time, const amrex::Vector< amrex::MultiFab * > &mfs_vel, const amrex::Vector< amrex::MultiFab * > &mfs_mom, int ng_cons, int ng_vel, bool cons_only, int icomp_cons, int ncomp_cons)
Definition: ERF_FillIntermediatePatch.cpp:28
amrex::Vector< amrex::Real > t_old
Definition: ERF.H:897
AMREX_FORCE_INLINE int NumSampleLines() noexcept
Definition: ERF.H:1601
amrex::Array< bool, AMREX_SPACEDIM *2 > m_bc_nonreflecting
Definition: ERF.H:1093
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Theta_prim
Definition: ERF.H:933
void write_1D_profiles(double time)
Definition: ERF_Write1DProfiles.cpp:17
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_t_rk
Definition: ERF.H:1047
void HurricaneTracker(int lev, amrex::Real time, const amrex::MultiFab &cc_vel, const amrex::Real velmag_threshold, amrex::TagBoxArray *tags=nullptr)
Definition: ERF_RefineHurricane.cpp:109
static int check_for_nans
Definition: ERF.H:1309
void make_subdomains(const amrex::BoxList &ba, amrex::Vector< amrex::BoxArray > &bins)
Definition: ERF_MakeSubdomains.cpp:6
void compute_divergence(int lev, amrex::MultiFab &rhs, amrex::Array< amrex::MultiFab const *, AMREX_SPACEDIM > rho0_u_const, amrex::Geometry const &geom_at_lev)
Definition: ERF_ComputeDivergence.cpp:10
std::string MakeVTKFilename(int nstep)
Definition: ERF_TrackerOutput.cpp:11
void initRayleigh_at_level(const int &lev)
Initialize Rayleigh damping profiles at a level.
Definition: ERF_InitRayleigh.cpp:14
void fill_rhs(amrex::MultiFab &rhs_mf, const amrex::MultiFab &state_mf, amrex::Real time, const amrex::Geometry &geom)
void appendPlotVariables(const std::string &pp_plot_var_names, amrex::Vector< std::string > &plot_var_names)
Definition: ERF_Plotfile.cpp:176
void read_box_for_refinement(std::string &ref_prefix, int &lev_for_box, amrex::RealBox &real_box)
Definition: ERF_RefineBox.cpp:6
int nvars_erfbdy
Definition: ERF.H:1358
amrex::Vector< std::unique_ptr< ERFPhysBCFunct_v > > physbcs_v
Definition: ERF.H:928
static amrex::Real column_per
Definition: ERF.H:1375
amrex::Vector< std::string > tot_e_datalogname
Definition: ERF.H:1710
static amrex::Real stop_time
Definition: ERF.H:1140
static int output_bndry_planes
Definition: ERF.H:1381
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > d_v_geos
Definition: ERF.H:1403
void update_terrain_arrays(int lev)
Definition: ERF_MakeNewArrays.cpp:861
void update_box_for_refinement(std::string &ref_prefix, int &lev_for_box, amrex::RealBox &real_box, const amrex::Real time)
Definition: ERF_RefineBox.cpp:336
static std::string nc_bdy_file
Definition: ERF.H:1332
bool metgrid_interp_theta
Definition: ERF.H:1345
static amrex::Vector< amrex::Vector< std::string > > nc_init_file
Definition: ERF.H:1328
void init_only(int lev, amrex::Real time)
Definition: ERF.cpp:1822
static int input_bndry_planes
Definition: ERF.H:1387
static StateInterpType interpolation_type
Definition: ERF.H:1325
amrex::Gpu::DeviceVector< amrex::Real > d_havg_qc
Definition: ERF.H:1440
amrex::Real cloud_fraction(double time)
Definition: ERF_WriteScalarProfiles.cpp:452
void AverageDown()
Definition: ERF_AverageDown.cpp:16
amrex::Vector< amrex::Vector< amrex::Real > > h_v_geos
Definition: ERF.H:1402
bool regrid_level_0_on_restart
Definition: ERF.H:1167
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Lwave_onegrid
Definition: ERF.H:1071
InputSoundingData input_sounding_data
Definition: ERF.H:854
void write_1D_profiles_stag(double time)
Definition: ERF_Write1DProfiles_stag.cpp:25
amrex::Vector< amrex::Vector< amrex::Real > > h_sinesq_ptrs
Definition: ERF.H:1419
void create_random_perturbations(const int lev, amrex::MultiFab &mf_cc_pert)
Definition: ERF_InitForEnsemble.cpp:14
void Write2DPlotFile(int which, PlotFileType plotfile_type, amrex::Vector< std::string > plot_var_names)
Definition: ERF_Plotfile2D.cpp:130
amrex::Gpu::DeviceVector< amrex::Real > d_havg_density
Definition: ERF.H:1436
amrex::Vector< std::unique_ptr< amrex::MultiFab > > rhotheta_src
Definition: ERF.H:1393
void init_from_hse(int lev)
Definition: ERF_InitFromHSE.cpp:32
const std::string datetime_format
Definition: ERF.H:1143
amrex::Vector< amrex::YAFluxRegister * > advflux_reg
Definition: ERF.H:1075
void check_mesh_type(int lev)
Definition: ERF.cpp:2957
int metgrid_force_sfc_k
Definition: ERF.H:1352
void setSubVolVariables(const std::string &pp_subvol_var_names, amrex::Vector< std::string > &subvol_var_names)
Definition: ERF_WriteSubvolume.cpp:9
static int ng_pres_hse
Definition: ERF.H:1390
static amrex::Real bndry_output_planes_start_time
Definition: ERF.H:1384
bool real_extrap_w
Definition: ERF.H:1334
static amrex::Real cfl
Definition: ERF.H:1149
amrex::Vector< std::unique_ptr< amrex::MultiFab > > fine_mask
Definition: ERF.H:1059
amrex::Gpu::DeviceVector< amrex::BCRec > domain_bcs_type_d
Definition: ERF.H:1081
amrex::Vector< std::unique_ptr< ForestDrag > > m_forest_drag
Definition: ERF.H:1447
const int datwidth
Definition: ERF.H:1127
amrex::Vector< amrex::BoxArray > ba1d
Definition: ERF.H:1360
InputSpongeData input_sponge_data
Definition: ERF.H:857
amrex::Vector< amrex::Vector< amrex::BoxArray > > subdomains
Definition: ERF.H:1454
void check_state_for_nans(amrex::MultiFab const &S)
Definition: ERF.cpp:2790
std::string restart_chkfile
Definition: ERF.H:1146
bool metgrid_use_below_sfc
Definition: ERF.H:1347
amrex::Vector< std::string > sampleptlogname
Definition: ERF.H:1713
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > xvel_bc_data
Definition: ERF.H:860
void init_zphys(int lev, amrex::Real elapsed_time)
Definition: ERF_MakeNewArrays.cpp:686
void InitData_pre()
Definition: ERF.cpp:552
amrex::IntVect & SamplePoint(int i)
Definition: ERF.H:1581
bool use_datetime
Definition: ERF.H:1142
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_track_xy
Definition: ERF.H:168
amrex::Vector< amrex::Vector< amrex::Real > > h_u_geos
Definition: ERF.H:1399
void InitializeLevelFromData(int lev, const amrex::MultiFab &initial_data)
std::string subvol_file
Definition: ERF.H:1174
amrex::Vector< amrex::Real > m_subvol_per
Definition: ERF.H:1182
int rad_datalog_int
Definition: ERF.H:987
amrex::Vector< std::string > datalogname
Definition: ERF.H:1708
void post_timestep(int nstep, double time, amrex::Real dt_lev)
Definition: ERF.cpp:313
void initHSE()
Initialize HSE.
Definition: ERF_Init1D.cpp:192
void AverageDownTo(int crse_lev, int scomp, int ncomp, bool do_perturbational_and_momenta=true)
Definition: ERF_AverageDown.cpp:36
static amrex::Real column_loc_x
Definition: ERF.H:1376
amrex::Vector< amrex::MultiFab > surface_state_2
Definition: ERF.H:179
amrex::Vector< std::unique_ptr< amrex::MultiFab > > ax
Definition: ERF.H:1033
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_phys_nd
Definition: ERF.H:1029
void MakeDiagnosticAverage(amrex::Vector< amrex::Real > &h_havg, amrex::MultiFab &S, int n)
Definition: ERF.cpp:2671
amrex::Real metgrid_proximity
Definition: ERF.H:1350
amrex::Real volWgtSumMF(int lev, const amrex::MultiFab &mf, int comp, const amrex::MultiFab &dJ, const amrex::MultiFab &mfx, const amrex::MultiFab &mfy, bool finemask, bool local=true)
Definition: ERF_VolWgtSum.cpp:20
void setRecordDerDataInfo(int i, const std::string &filename)
Definition: ERF.H:1637
amrex::Vector< amrex::Real > h_havg_temperature
Definition: ERF.H:1431
void advance_dycore(int level, amrex::Vector< amrex::MultiFab > &state_old, amrex::Vector< amrex::MultiFab > &state_new, amrex::MultiFab &xvel_old, amrex::MultiFab &yvel_old, amrex::MultiFab &zvel_old, amrex::MultiFab &xvel_new, amrex::MultiFab &yvel_new, amrex::MultiFab &zvel_new, amrex::MultiFab &source, amrex::MultiFab &xmom_src, amrex::MultiFab &ymom_src, amrex::MultiFab &zmom_src, amrex::MultiFab &buoyancy, amrex::Geometry fine_geom, amrex::Real dt, amrex::Real time)
Definition: ERF_AdvanceDycore.cpp:38
amrex::Vector< std::unique_ptr< std::fstream > > sampleptlog
Definition: ERF.H:1712
void poisson_wall_dist(int lev)
Definition: ERF_PoissonWallDist.cpp:22
amrex::Vector< std::array< amrex::Real, 2 > > hurricane_eye_track_latlon
Definition: ERF.H:170
amrex::Vector< std::unique_ptr< amrex::MultiFab > > detJ_cc_src
Definition: ERF.H:1039
amrex::Gpu::DeviceVector< amrex::Real > d_havg_pressure
Definition: ERF.H:1438
void PackAtmosphericStates(amrex::Vector< amrex::MultiFab * > &states, amrex::Real time)
Definition: ERF_Coupling.cpp:61
std::string plot2d_file_1
Definition: ERF.H:1172
amrex::Vector< std::string > der_datalogname
Definition: ERF.H:1709
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SmnSmn_lev
Definition: ERF.H:1001
const amrex::Vector< std::string > derived_names
Definition: ERF.H:1216
void sum_integrated_quantities(double time)
Definition: ERF_WriteScalarProfiles.cpp:15
std::string MakeVTKFilename_TrackerCircle(int nstep)
Definition: ERF_TrackerOutput.cpp:24
amrex::Vector< std::unique_ptr< amrex::MultiFab > > ay_src
Definition: ERF.H:1041
void sample_points(int lev, amrex::Real time, amrex::IntVect cell, amrex::MultiFab &mf)
Definition: ERF_WriteScalarProfiles.cpp:528
void ComputeDt(int step=-1, double cur_time_d=0.0)
Definition: ERF_ComputeTimestep.cpp:11
AMREX_FORCE_INLINE std::ostream & DataLog(int i)
Definition: ERF.H:1525
void writeJobInfo(const std::string &dir) const
Definition: ERF_WriteJobInfo.cpp:9
std::string MakeVTKFilename_EyeTracker_xy(int nstep)
Definition: ERF_TrackerOutput.cpp:38
amrex::Vector< int > nsubsteps
Definition: ERF.H:893
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > yflux_imask
Definition: ERF.H:1100
amrex::Vector< amrex::MultiFab > rW_new
Definition: ERF.H:943
amrex::Vector< amrex::MultiFab > weather_forecast_data_2
Definition: ERF.H:174
amrex::Vector< std::unique_ptr< amrex::MultiFab > > lon_m
Definition: ERF.H:849
std::unique_ptr< WriteBndryPlanes > m_w2d
Definition: ERF.H:1444
AMREX_FORCE_INLINE std::ostream & SampleLineLog(int i)
Definition: ERF.H:1568
amrex::Vector< amrex::Vector< amrex::MultiFab * > > lsm_flux
Definition: ERF.H:969
bool use_erfbdy
Definition: ERF.H:1356
amrex::Vector< std::string > plot3d_var_names_1
Definition: ERF.H:1203
void ApplyOceanSurfaceState(const amrex::Vector< amrex::MultiFab * > &state, amrex::Real time)
Definition: ERF_Coupling.cpp:258
std::string SamplePointLogName(int i) const noexcept
The filename of the ith sampleptlog file.
Definition: ERF.H:1725
void turbPert_update(const int lev, const amrex::Real dt)
Definition: ERF_InitTurbPert.cpp:12
void InitData_post()
Definition: ERF.cpp:576
void refinement_criteria_setup()
Definition: ERF_Tagging.cpp:472
static int nghost_eb_volume()
Definition: ERF.H:1747
bool metgrid_debug_dry
Definition: ERF.H:1342
static AMREX_FORCE_INLINE int ComputeGhostCells(const SolverChoice &sc)
Definition: ERF.H:1460
static int bndry_output_planes_interval
Definition: ERF.H:1382
void init_geo_wind_profile(const std::string input_file, amrex::Vector< amrex::Real > &u_geos, amrex::Gpu::DeviceVector< amrex::Real > &u_geos_d, amrex::Vector< amrex::Real > &v_geos, amrex::Gpu::DeviceVector< amrex::Real > &v_geos_d, const amrex::Geometry &lgeom, const amrex::Vector< amrex::Real > &zlev_stag)
Definition: ERF_InitGeowind.cpp:10
void ERF_shared()
Definition: ERF_Constructors.cpp:61
amrex::Vector< std::string > plot2d_var_names_2
Definition: ERF.H:1206
void WeatherDataInterpolation(const int nlevs, const amrex::Real time, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &z_phys_nd, bool regrid_forces_file_read)
Definition: ERF_WeatherDataInterpolation.cpp:347
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > Tau_corr
Definition: ERF.H:999
void FillPatchCrseLevel(int lev, double time, const amrex::Vector< amrex::MultiFab * > &mfs_vel, bool cons_only=false)
Definition: ERF_FillPatch.cpp:290
void WriteSubvolume(int isub, amrex::Vector< std::string > subvol_var_names)
Definition: ERF_WriteSubvolume.cpp:145
void sum_energy_quantities(double time)
Definition: ERF_WriteScalarProfiles.cpp:313
static int nghost_eb_full()
Definition: ERF.H:1750
void RemakeLevel(int lev, amrex::Real time, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm) override
Definition: ERF_MakeNewLevel.cpp:535
static void GotoNextLine(std::istream &is)
Definition: ERF_Checkpoint.cpp:17
void MakeNewLevelFromScratch(int lev, amrex::Real time, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm) override
Definition: ERF_MakeNewLevel.cpp:25
void init_stuff(int lev, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm, amrex::Vector< amrex::MultiFab > &lev_new, amrex::Vector< amrex::MultiFab > &lev_old, amrex::MultiFab &tmp_base_state, std::unique_ptr< amrex::MultiFab > &tmp_zphys_nd)
Definition: ERF_MakeNewArrays.cpp:24
amrex::Vector< amrex::MultiFab > zmom_crse_rhs
Definition: ERF.H:947
bool metgrid_debug_isothermal
Definition: ERF.H:1341
void PerformDataAssimilation(int da_iter)
amrex::Vector< std::string > lsm_data_name
Definition: ERF.H:966
amrex::Vector< std::unique_ptr< amrex::MultiFab > > rhoqt_src
Definition: ERF.H:1394
void initSponge()
Initialize sponge profiles.
Definition: ERF_InitSponge.cpp:35
std::unique_ptr< PlaneSampler > plane_sampler
Definition: ERF.H:1703
void HurricaneEyeTracker_WRF(const SolverChoice &solverChoice)
Definition: ERF_HurricaneDiagnostics_WRF.cpp:368
void check_for_low_temp(amrex::MultiFab &S)
Definition: ERF.cpp:2884
amrex::Vector< std::unique_ptr< std::fstream > > der_datalog
Definition: ERF.H:1706
static amrex::Vector< amrex::Vector< int > > have_read_nc_init_file
Definition: ERF.H:1329
amrex::Real m_plot3d_per_2
Definition: ERF.H:1185
amrex::Vector< std::unique_ptr< std::fstream > > tot_e_datalog
Definition: ERF.H:1707
amrex::Vector< std::unique_ptr< amrex::MultiFab > > sinPhi_m
Definition: ERF.H:851
int real_width
Definition: ERF.H:1333
void MakeNewLevelFromCoarse(int lev, amrex::Real time, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm) override
Definition: ERF_MakeNewLevel.cpp:275
amrex::Vector< int > last_subvol_step
Definition: ERF.H:1121
amrex::Vector< std::unique_ptr< amrex::MultiFab > > ax_src
Definition: ERF.H:1040
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > urb_frac_lev
Definition: ERF.H:1011
amrex::Vector< std::unique_ptr< amrex::MultiFab > > z_phys_cc_src
Definition: ERF.H:1038
void input_sponge(int lev)
Definition: ERF_InitSponge.cpp:17
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > d_u_geos
Definition: ERF.H:1400
void Define_ERFFillPatchers(int lev)
Definition: ERF.cpp:2743
AMREX_FORCE_INLINE int NumDataLogs() noexcept
Definition: ERF.H:1539
static PlotFileType plotfile3d_type_2
Definition: ERF.H:1318
void setRecordEnergyDataInfo(int i, const std::string &filename)
Definition: ERF.H:1650
TurbulentPerturbation turbPert
Definition: ERF.H:1273
amrex::Vector< amrex::MultiFab > rW_old
Definition: ERF.H:942
amrex::Vector< amrex::Vector< amrex::MultiFab > > forecast_state_2
Definition: ERF.H:176
void check_for_negative_theta(amrex::MultiFab &S)
Definition: ERF.cpp:2919
void ImposeBCsOnPhi(int lev, amrex::MultiFab &phi, const amrex::Box &subdomain)
Definition: ERF_ImposeBCsOnPhi.cpp:12
void Interp2DArrays(int lev, const amrex::BoxArray &my_ba2d, const amrex::DistributionMapping &my_dm)
Definition: ERF.cpp:1524
void FillCoarsePatch(int lev, amrex::Real time)
Definition: ERF_FillCoarsePatch.cpp:21
void ClearLevel(int lev) override
Definition: ERF_MakeNewLevel.cpp:813
std::string MakeFilename_EyeTracker_minpressure(int nstep)
Definition: ERF_TrackerOutput.cpp:80
std::unique_ptr< SurfaceLayer > m_SurfaceLayer
Definition: ERF.H:1446
static PlotFileType plotfile2d_type_2
Definition: ERF.H:1320
int plane_sampling_interval
Definition: ERF.H:1699
static amrex::Vector< amrex::AMRErrorTag > ref_tags
Definition: ERF.H:1452
void make_physbcs(int lev)
Definition: ERF_MakeNewArrays.cpp:900
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > d_w_subsid
Definition: ERF.H:1397
amrex::Vector< ERFFillPatcher > FPr_w
Definition: ERF.H:995
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_hfx2_lev
Definition: ERF.H:1014
void WriteLinePlot(const std::string &filename, amrex::Vector< std::array< amrex::Real, 2 >> &points_xy)
Definition: ERF_Write1DProfiles.cpp:593
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::iMultiFab > > > soil_type_lev
Definition: ERF.H:1010
amrex::Vector< amrex::Vector< amrex::Real > > zlevels_stag
Definition: ERF.H:1026
AMREX_FORCE_INLINE int NumDerDataLogs() noexcept
Definition: ERF.H:1546
amrex::EBFArrayBoxFactory const & EBFactory(int lev) const noexcept
Definition: ERF.H:1739
amrex::Vector< amrex::Vector< amrex::MultiFab * > > lsm_data
Definition: ERF.H:967
void init_immersed_forcing(int lev)
Definition: ERF_InitImmersedForcing.cpp:15
amrex::Vector< amrex::Vector< amrex::Real > > stretched_dz_h
Definition: ERF.H:1061
bool use_real_time_in_pltname
Definition: ERF.H:1323
int m_plot2d_int_1
Definition: ERF.H:1178
void WriteCheckpointFile() const
Definition: ERF_Checkpoint.cpp:27
static int output_1d_column
Definition: ERF.H:1373
bool metgrid_debug_psfc
Definition: ERF.H:1343
void ReadStormTrackerRestart()
Definition: ERF_HurricaneDiagnostics_WRF.cpp:268
amrex::Vector< std::unique_ptr< amrex::MultiFab > > az_src
Definition: ERF.H:1042
static int fixed_mri_dt_ratio
Definition: ERF.H:1159
amrex::Vector< amrex::Real > dt
Definition: ERF.H:898
static amrex::Real init_shrink
Definition: ERF.H:1151
void WriteVTKPolyline(const std::string &filename, amrex::Vector< std::array< amrex::Real, 2 >> &points_xy)
Definition: ERF_TrackerOutput.cpp:94
void Write3DPlotFile(int which, PlotFileType plotfile_type, amrex::Vector< std::string > plot_var_names)
Definition: ERF_Plotfile.cpp:265
void advance_radiation(int lev, amrex::MultiFab &cons_in, const amrex::Real &dt_advance)
Definition: ERF_AdvanceRadiation.cpp:5
static amrex::Real dt_max_initial
Definition: ERF.H:1153
static std::string nc_low_file
Definition: ERF.H:1337
amrex::Vector< amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > > d_rayleigh_ptrs
Definition: ERF.H:1423
void InitData()
Definition: ERF.cpp:543
void advance_microphysics(int lev, amrex::MultiFab &cons_in, const amrex::Real &dt_advance, const int &iteration, const amrex::Real &time)
Definition: ERF_AdvanceMicrophysics.cpp:5
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Lwave
Definition: ERF.H:1069
amrex::Vector< std::unique_ptr< amrex::MultiFab > > cosPhi_m
Definition: ERF.H:851
void ParameterSanityChecks()
Definition: ERF.cpp:2497
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::iMultiFab > > > land_type_lev
Definition: ERF.H:1009
void derive_stress_profiles(amrex::Gpu::HostVector< amrex::Real > &h_avg_tau11, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau12, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau13, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau22, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau23, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau33, amrex::Gpu::HostVector< amrex::Real > &h_avg_hfx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_q1fx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_q2fx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_diss)
Definition: ERF_Write1DProfiles.cpp:494
amrex::Vector< amrex::Vector< amrex::MultiFab > > forecast_state_1
Definition: ERF.H:175
int cf_width
Definition: ERF.H:990
static int last_plot2d_file_step_1
Definition: ERF.H:1111
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > zflux_imask
Definition: ERF.H:1101
bool m_expand_plotvars_to_unif_rr
Definition: ERF.H:1175
amrex::Real m_plot3d_per_1
Definition: ERF.H:1184
void Construct_ERFFillPatchers(int lev)
Definition: ERF.cpp:2717
void post_update(amrex::MultiFab &state_mf, amrex::Real time, const amrex::Geometry &geom)
amrex::Vector< int > num_boxes_at_level
Definition: ERF.H:888
void init_phys_bcs(bool &rho_read, bool &read_prim_theta)
Definition: ERF_InitBCs.cpp:20
void FillSurfaceStateMultiFabs(const int lev, const std::string &filename, amrex::Vector< amrex::MultiFab > &surface_state)
Definition: ERF_SurfaceDataInterpolation.cpp:19
static amrex::Real sub_cfl
Definition: ERF.H:1150
static void print_error(MPI_Comm, const std::string &msg)
Definition: ERF_ConsoleIO.cpp:43
static int ng_dens_hse
Definition: ERF.H:1389
std::unique_ptr< ReadBndryPlanes > m_r2d
Definition: ERF.H:1445
amrex::Vector< std::unique_ptr< amrex::MultiFab > > ay
Definition: ERF.H:1034
amrex::Vector< amrex::Vector< amrex::MultiFab * > > qmoist
Definition: ERF.H:950
amrex::Vector< std::unique_ptr< amrex::MultiFab > > SFS_q1fx1_lev
Definition: ERF.H:1016
static amrex::Real getCPUTime()
Definition: ERF.H:1610
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > zvel_bc_data
Definition: ERF.H:862
void derive_stress_profiles_stag(amrex::Gpu::HostVector< amrex::Real > &h_avg_tau11, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau12, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau13, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau22, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau23, amrex::Gpu::HostVector< amrex::Real > &h_avg_tau33, amrex::Gpu::HostVector< amrex::Real > &h_avg_hfx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_q1fx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_q2fx3, amrex::Gpu::HostVector< amrex::Real > &h_avg_diss)
Definition: ERF_Write1DProfiles_stag.cpp:624
LandSurface lsm
Definition: ERF.H:965
static amrex::Real change_max
Definition: ERF.H:1152
void setRecordSampleLineInfo(int i, int lev, amrex::IntVect &cell, const std::string &filename)
Definition: ERF.H:1680
void setSpongeRefFromSounding(bool restarting)
Set sponge mean profiles from input sounding.
Definition: ERF_InitSponge.cpp:65
amrex::Vector< amrex::MultiFab > avg_ymom
Definition: ERF.H:922
int line_sampling_interval
Definition: ERF.H:1698
amrex::Vector< amrex::Vector< amrex::Real > > h_sinesq_stag_ptrs
Definition: ERF.H:1420
amrex::Vector< std::unique_ptr< amrex::MultiFab > > detJ_cc_new
Definition: ERF.H:1045
amrex::Array< std::string, 2 *AMREX_SPACEDIM > domain_bc_type
Definition: ERF.H:1084
amrex::Vector< amrex::Gpu::DeviceVector< amrex::Real > > yvel_bc_data
Definition: ERF.H:861
static void writeBuildInfo(std::ostream &os)
Definition: ERF_WriteJobInfo.cpp:143
amrex::GpuArray< ERF_BC, AMREX_SPACEDIM *2 > phys_bc_type
Definition: ERF.H:1096
std::string check_file
Definition: ERF.H:1197
void HurricaneTrackerCircle_WRF()
Definition: ERF_HurricaneDiagnostics_WRF.cpp:131
amrex::Vector< amrex::IntVect > samplepoint
Definition: ERF.H:1714
amrex::Vector< amrex::MultiFab > surface_state_interp
Definition: ERF.H:180
amrex::Vector< amrex::Real > h_havg_qv
Definition: ERF.H:1433
amrex::Vector< amrex::Real > last_subvol_time
Definition: ERF.H:1122
amrex::Vector< amrex::MultiFab > weather_forecast_data_1
Definition: ERF.H:174
static void print_usage(MPI_Comm, std::ostream &)
Definition: ERF_ConsoleIO.cpp:26
amrex::Vector< amrex::MultiFab > rV_old
Definition: ERF.H:940
amrex::Vector< std::unique_ptr< amrex::MultiFab > > lat_m
Definition: ERF.H:849
void timeStep(int lev, double time, int iteration)
Definition: ERF_TimeStep.cpp:18
amrex::Vector< amrex::Vector< amrex::Vector< amrex::Real > > > h_rayleigh_ptrs
Definition: ERF.H:1415
static amrex::Real last_check_file_time
Definition: ERF.H:1119
static int last_plot3d_file_step_1
Definition: ERF.H:1109
static amrex::Real last_plot3d_file_time_1
Definition: ERF.H:1115
void FillPatchFineLevel(int lev, double time, const amrex::Vector< amrex::MultiFab * > &mfs_vel, const amrex::Vector< amrex::MultiFab * > &mfs_mom, const amrex::MultiFab &old_base_state, const amrex::MultiFab &new_base_state, bool fillset=true, bool cons_only=false)
Definition: ERF_FillPatch.cpp:20
std::unique_ptr< LineSampler > line_sampler
Definition: ERF.H:1702
amrex::Vector< std::unique_ptr< amrex::MultiFab > > Hwave
Definition: ERF.H:1068
amrex::Vector< amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > > Tau_EB
Definition: ERF.H:1021
amrex::Vector< int > istep
Definition: ERF.H:892
const int datprecision
Definition: ERF.H:1128
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > xflux_imask
Definition: ERF.H:1099
void advance_lsm(int lev, amrex::MultiFab &cons_in, amrex::MultiFab &xvel_in, amrex::MultiFab &yvel_in, const amrex::Real &time, const amrex::Real &dt_advance)
Definition: ERF_AdvanceLSM.cpp:5
void derive_upwp(amrex::Vector< amrex::Real > &h_havg)
static PlotFileType plotfile2d_type_1
Definition: ERF.H:1319
int metgrid_order
Definition: ERF.H:1351
bool finished_wave
Definition: ERF.H:1072
void ReadCheckpointFile()
Definition: ERF_Checkpoint.cpp:504
amrex::Vector< amrex::Vector< amrex::MultiFab > > vars_old
Definition: ERF.H:905
void WriteAtFinalTime()
Definition: ERF.cpp:278
amrex::Vector< std::unique_ptr< ERFPhysBCFunct_base > > physbcs_base
Definition: ERF.H:930
void init_thin_body(int lev, const amrex::BoxArray &ba, const amrex::DistributionMapping &dm)
Definition: ERF_MakeNewLevel.cpp:898
static PlotFileType plotfile3d_type_1
Definition: ERF.H:1317
amrex::Vector< int > m_subvol_int
Definition: ERF.H:1181
static bool is_it_time_for_action(int nstep, double time, amrex::Real dt, int action_interval, amrex::Real action_per)
Definition: ERF_WriteScalarProfiles.cpp:654
AMREX_FORCE_INLINE std::ostream & SamplePointLog(int i)
Definition: ERF.H:1554
std::string MakeFilename_EyeTracker_latlon(int nstep)
Definition: ERF_TrackerOutput.cpp:52
amrex::Array< amrex::Array< amrex::Real, AMREX_SPACEDIM *2 >, AMREX_SPACEDIM+NBCVAR_max > m_bc_neumann_vals
Definition: ERF.H:1090
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > tsk_lev
Definition: ERF.H:1005
void setRecordSamplePointInfo(int i, int lev, amrex::IntVect &cell, const std::string &filename)
Definition: ERF.H:1663
static int column_interval
Definition: ERF.H:1374
static void print_summary(std::ostream &)
int m_plot3d_int_2
Definition: ERF.H:1177
amrex::Vector< std::unique_ptr< amrex::MultiFab > > qheating_rates
Definition: ERF.H:972
void turbPert_amplitude(const int lev)
Definition: ERF_InitTurbPert.cpp:33
void sample_lines(int lev, amrex::Real time, amrex::IntVect cell, amrex::MultiFab &mf)
Definition: ERF_WriteScalarProfiles.cpp:564
amrex::Vector< std::unique_ptr< amrex::MultiFab > > rad_fluxes
Definition: ERF.H:973
void initializeMicrophysics(const int &)
Definition: ERF.cpp:1722
std::unique_ptr< amrex::MultiFab > wrf_C2H
Definition: ERF.H:1364
bool plot_lsm
Definition: ERF.H:1190
amrex::Vector< amrex::MultiFab > avg_zmom
Definition: ERF.H:923
const amrex::Vector< std::string > cons_names
Definition: ERF.H:1207
void ReadCheckpointFileSurfaceLayer()
Definition: ERF_Checkpoint.cpp:1222
Definition: ERF_LandSurface.H:16
Definition: ERF_InterpolationUtils.H:16
@ pres
Definition: ERF_Kessler.H:26
@ qv
Definition: ERF_Kessler.H:29
@ xvel
Definition: ERF_IndexDefines.H:175
@ cons
Definition: ERF_IndexDefines.H:174
@ zvel
Definition: ERF_IndexDefines.H:177
@ yvel
Definition: ERF_IndexDefines.H:176
@ p
Definition: ERF_WSM6.H:176
Definition: ERF_ConsoleIO.cpp:12
real(c_double), parameter, private pi
Definition: ERF_module_mp_morr_two_moment.F90:100
integer, private isub
Definition: ERF_module_mp_morr_two_moment.F90:164
real(kind=kind_phys), parameter, private dens
Definition: ERF_module_mp_wsm6.F90:39
AdvType moistscal_horiz_adv_type
Definition: ERF_AdvStruct.H:423
AdvType dycore_vert_adv_type
Definition: ERF_AdvStruct.H:420
AdvType moistscal_vert_adv_type
Definition: ERF_AdvStruct.H:424
AdvType dryscal_horiz_adv_type
Definition: ERF_AdvStruct.H:421
AdvType dycore_horiz_adv_type
Definition: ERF_AdvStruct.H:419
AdvType dryscal_vert_adv_type
Definition: ERF_AdvStruct.H:422
Definition: ERF_DataStruct.H:141
bool use_num_diff
Definition: ERF_DataStruct.H:1385
AdvChoice advChoice
Definition: ERF_DataStruct.H:1219
static TerrainType terrain_type
Definition: ERF_DataStruct.H:1202
Definition: ERF_TurbPertStruct.H:22