1 #ifndef ERF_MOSTAverage_H
2 #define ERF_MOSTAverage_H
5 #include "AMReX_FArrayBox.H"
6 #include "AMReX_MultiFab.H"
7 #include "AMReX_iMultiFab.H"
8 #include "AMReX_ParmParse.H"
17 const bool& has_zphys,
18 std::string a_pp_prefix,
41 const
amrex::Vector<
amrex::MultiFab*>& vars_old,
42 std::unique_ptr<
amrex::MultiFab>& Theta_prim,
43 std::unique_ptr<
amrex::MultiFab>& Qv_prim,
44 std::unique_ptr<
amrex::MultiFab>& Qr_prim,
45 std::unique_ptr<
amrex::MultiFab>& z_phys_nd);
50 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Theta_prim,
51 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Qv_prim,
52 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Qr_prim);
102 [[nodiscard]]
const amrex::MultiFab*
get_average (
const int& lev,
const int& comp)
const {
return m_averages[lev][comp].get(); }
119 AMREX_GPU_HOST_DEVICE AMREX_INLINE
124 amrex::Array4<amrex::Real const>
const& interp_array,
125 amrex::Array4<amrex::Real const>
const& z_arr,
126 const amrex::GpuArray<amrex::Real, AMREX_SPACEDIM>& plo,
127 const amrex::GpuArray<amrex::Real, AMREX_SPACEDIM>& dxi,
128 const int interp_comp)
132 int kmax = ubound(z_arr).z;
139 int i_new = (int) (ireal - 0.5);
140 int j_new = (int) (jreal - 0.5);
142 for (
int lk(0); lk<kmax; ++lk) {
143 amrex::Real z_lo = 0.25 * ( z_arr(i_new,j_new ,lk ) + z_arr(i_new+1,j_new ,lk )
144 + z_arr(i_new,j_new+1,lk ) + z_arr(i_new+1,j_new+1,lk ) );
145 amrex::Real z_hi = 0.25 * ( z_arr(i_new,j_new ,lk+1) + z_arr(i_new+1,j_new ,lk+1)
146 + z_arr(i_new,j_new+1,lk+1) + z_arr(i_new+1,j_new+1,lk+1) );
147 if (z_target > z_lo && z_target < z_hi){
149 zval = (
amrex::Real) lk + ((z_target - z_lo) / (z_hi - z_lo)) + 0.5;
154 amrex::ignore_unused(found);
155 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(found,
"MOSTAverage: Height above terrain not found, try increasing z_ref!");
158 const amrex::RealVect lx(ireal + 0.5, jreal + 0.5, zval);
160 const amrex::IntVect ijk = lx.floor();
162 int i = ijk[0];
int j = ijk[1];
int k = ijk[2];
165 amrex::RealVect ijk_r(
static_cast<amrex::Real>(ijk[0]),
170 const amrex::RealVect sx_hi = lx - ijk_r;
171 const amrex::RealVect sx_lo = 1.0 - sx_hi;
173 for (
int n = 0; n < interp_comp; n++) {
174 interp_vals[n] = sx_lo[0]*sx_lo[1]*sx_lo[2]*interp_array(i-1, j-1, k-1,n) +
175 sx_lo[0]*sx_lo[1]*sx_hi[2]*interp_array(i-1, j-1, k ,n) +
176 sx_lo[0]*sx_hi[1]*sx_lo[2]*interp_array(i-1, j , k-1,n) +
177 sx_lo[0]*sx_hi[1]*sx_hi[2]*interp_array(i-1, j , k ,n) +
178 sx_hi[0]*sx_lo[1]*sx_lo[2]*interp_array(i , j-1, k-1,n) +
179 sx_hi[0]*sx_lo[1]*sx_hi[2]*interp_array(i , j-1, k ,n) +
180 sx_hi[0]*sx_hi[1]*sx_lo[2]*interp_array(i , j , k-1,n) +
181 sx_hi[0]*sx_hi[1]*sx_hi[2]*interp_array(i , j , k ,n);
189 const amrex::Vector<amrex::Geometry>
m_geom;
190 amrex::Vector<amrex::Vector<amrex::MultiFab*>>
m_fields;
204 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_x_pos;
205 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_y_pos;
206 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_z_pos;
207 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_i_indx;
208 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_j_indx;
209 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_k_indx;
210 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
m_averages;
211 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
m_rot_fields;
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_MOSTAverage.H:14
int m_navg
Definition: ERF_MOSTAverage.H:199
bool m_t_avg
Definition: ERF_MOSTAverage.H:231
void write_xz_positions(const int &lev, const int &j)
Definition: ERF_MOSTAverage.cpp:1464
void compute_plane_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:734
int m_policy
Definition: ERF_MOSTAverage.H:201
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > m_averages
Definition: ERF_MOSTAverage.H:210
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_y_pos
Definition: ERF_MOSTAverage.H:205
int m_radius
Definition: ERF_MOSTAverage.H:220
void write_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:1495
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_i_indx
Definition: ERF_MOSTAverage.H:207
void compute_region_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:1019
amrex::Vector< amrex::MultiFab * > m_z_phys_nd
Definition: ERF_MOSTAverage.H:191
amrex::Vector< int > m_t_init
Definition: ERF_MOSTAverage.H:232
void compute_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:708
void set_rotated_fields(const int &lev)
Definition: ERF_MOSTAverage.cpp:279
void set_region_normalization(const int &)
Definition: ERF_MOSTAverage.H:61
void set_z_positions_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:586
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_x_pos
Definition: ERF_MOSTAverage.H:204
amrex::Real get_zref() const
Definition: ERF_MOSTAverage.H:105
void set_norm_positions_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:634
amrex::Vector< amrex::Real > m_Vsg
Definition: ERF_MOSTAverage.H:239
void set_k_indices_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:451
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > m_rot_fields
Definition: ERF_MOSTAverage.H:211
bool m_rotate
Definition: ERF_MOSTAverage.H:202
amrex::Vector< amrex::Vector< amrex::Real > > m_plane_average
Definition: ERF_MOSTAverage.H:216
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_z_pos
Definition: ERF_MOSTAverage.H:206
MOSTAverage(amrex::Vector< amrex::Geometry > geom, const bool &has_zphys, std::string a_pp_prefix, const MeshType &m_mesh_type, const TerrainType &m_terrain_type)
amrex::Vector< amrex::Vector< int > > m_ncell_plane
Definition: ERF_MOSTAverage.H:215
void set_plane_normalization(const int &lev)
Definition: ERF_MOSTAverage.cpp:338
void write_k_indices(const int &lev)
Definition: ERF_MOSTAverage.cpp:1376
TerrainType m_terrain_type
Definition: ERF_MOSTAverage.H:194
std::string m_pp_prefix
Definition: ERF_MOSTAverage.H:192
bool m_norm_vec
Definition: ERF_MOSTAverage.H:227
int m_nvar
Definition: ERF_MOSTAverage.H:198
amrex::Real m_fact_new
Definition: ERF_MOSTAverage.H:234
int m_ncell_region
Definition: ERF_MOSTAverage.H:221
void set_norm_indices_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:512
int m_maxlev
Definition: ERF_MOSTAverage.H:200
const amrex::MultiFab * get_average(const int &lev, const int &comp) const
Definition: ERF_MOSTAverage.H:102
bool include_subgrid_vel
Definition: ERF_MOSTAverage.H:238
void update_field_ptrs(const int &lev, amrex::Vector< amrex::Vector< amrex::MultiFab >> &vars_old, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Theta_prim, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Qv_prim, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Qr_prim)
Definition: ERF_MOSTAverage.cpp:260
~MOSTAverage()
Definition: ERF_MOSTAverage.H:23
amrex::Real m_time_window
Definition: ERF_MOSTAverage.H:233
MeshType m_mesh_type
Definition: ERF_MOSTAverage.H:193
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_j_indx
Definition: ERF_MOSTAverage.H:208
void set_k_indices_N(const int &lev)
Definition: ERF_MOSTAverage.cpp:396
void make_MOSTAverage_at_level(const int &lev, const amrex::Vector< amrex::MultiFab * > &vars_old, std::unique_ptr< amrex::MultiFab > &Theta_prim, std::unique_ptr< amrex::MultiFab > &Qv_prim, std::unique_ptr< amrex::MultiFab > &Qr_prim, std::unique_ptr< amrex::MultiFab > &z_phys_nd)
Definition: ERF_MOSTAverage.cpp:84
MOSTAverage(MOSTAverage &&) noexcept=default
void write_norm_indices(const int &lev)
Definition: ERF_MOSTAverage.cpp:1415
amrex::Vector< amrex::Vector< amrex::MultiFab * > > m_fields
Definition: ERF_MOSTAverage.H:190
amrex::Vector< int > m_k_in
Definition: ERF_MOSTAverage.H:222
amrex::Real m_fact_old
Definition: ERF_MOSTAverage.H:234
bool m_interp
Definition: ERF_MOSTAverage.H:226
const amrex::Vector< amrex::Geometry > m_geom
Definition: ERF_MOSTAverage.H:189
AMREX_GPU_HOST_DEVICE static AMREX_INLINE void trilinear_interp_T(const amrex::Real &xp, const amrex::Real &yp, const amrex::Real &zp, amrex::Real *interp_vals, amrex::Array4< amrex::Real const > const &interp_array, amrex::Array4< amrex::Real const > const &z_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &plo, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxi, const int interp_comp)
Definition: ERF_MOSTAverage.H:120
amrex::Real m_zref
Definition: ERF_MOSTAverage.H:203
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_k_indx
Definition: ERF_MOSTAverage.H:209
Definition: ERF_ConsoleIO.cpp:12