128 BL_PROFILE(
"ERF::WriteBndryPlanes::write_planes");
135 const std::string chkname =
136 m_filename + Concatenate(
"/bndry_output", t_step);
140 const std::string level_prefix =
"Level_";
141 PreBuildDirectorHierarchy(chkname, level_prefix, 1,
true);
146 DistributionMapping dm{ba};
149 Box target_box_shifted(IntVect(0,0,0),new_hi);
150 BoxArray ba_shifted(target_box_shifted);
155 std::string filename = MultiFabFileFullPrefix(
bndry_lev, chkname, level_prefix, var_name);
158 if (var_name ==
"velocity") {
159 ncomp = AMREX_SPACEDIM;
168 if (var_name ==
"density")
172 }
else if (var_name ==
"temperature") {
173 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
174 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
176 const Box& bx = mfi.tilebox();
185 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
186 }
else if (var_name ==
"theta") {
187 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
188 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
190 const Box& bx = mfi.tilebox();
193 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
194 }
else if (var_name ==
"scalar") {
195 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
196 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
198 const Box& bx = mfi.tilebox();
201 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
202 }
else if (var_name ==
"ke") {
203 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
204 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
206 const Box& bx = mfi.tilebox();
209 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
210 }
else if (var_name ==
"qv") {
211 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
213 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
215 const Box& bx = mfi.tilebox();
221 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
222 }
else if (var_name ==
"qc") {
223 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
225 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
227 const Box& bx = mfi.tilebox();
233 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
234 }
else if (var_name ==
"velocity") {
235 MultiFab Vel(S.boxArray(), S.DistributionMap(), 3,
m_out_rad);
236 average_face_to_cellcenter(Vel,0,Array<const MultiFab*,3>{&
xvel,&
yvel,&
zvel});
237 bndry.copyFrom(Vel, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
240 Error(
"Don't know how to output this variable");
243 for (OrientationIter oit; oit !=
nullptr; ++oit) {
245 if (ori.coordDir() < 2) {
246 std::string facename = Concatenate(filename +
'_', ori, 1);
247 br_shift(oit, bndry, bndry_shifted);
248 bndry_shifted[ori].write(facename);
255 if (ParallelDescriptor::IOProcessor()) {
257 oftime << std::setprecision(17) << t_step <<
' ' << time <<
'\n';
#define RhoScalar_comp
Definition: ERF_IndexDefines.H:40
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define RhoQ2_comp
Definition: ERF_IndexDefines.H:43
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
void br_shift(OrientationIter oit, const BndryRegister &b1, BndryRegister &b2)
Definition: ERF_WriteBndryPlanes.cpp:18
const int m_out_rad
Definition: ERF_WriteBndryPlanes.H:51
const int m_extent_rad
Definition: ERF_WriteBndryPlanes.H:52
@ xvel
Definition: ERF_IndexDefines.H:159
@ cons
Definition: ERF_IndexDefines.H:158
@ zvel
Definition: ERF_IndexDefines.H:161
@ yvel
Definition: ERF_IndexDefines.H:160
void erf_derrhodivide(const Box &bx, FArrayBox &derfab, const FArrayBox &datfab, const int scalar_index)
Definition: ERF_Derive.cpp:168
void erf_dermoisttemp(const Box &bx, FArrayBox &derfab, int, int, const FArrayBox &datfab, const FArrayBox &, const Geometry &, Real, const int *, const int)
Definition: ERF_Derive.cpp:266
void erf_dertemp(const Box &bx, FArrayBox &derfab, int, int, const FArrayBox &datfab, const FArrayBox &, const Geometry &, Real, const int *, const int)
Definition: ERF_Derive.cpp:243