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();
183 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
184 }
else if (var_name ==
"theta") {
185 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
186 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
188 const Box& bx = mfi.tilebox();
191 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
192 }
else if (var_name ==
"scalar") {
193 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
194 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
196 const Box& bx = mfi.tilebox();
199 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
200 }
else if (var_name ==
"ke") {
201 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
202 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
204 const Box& bx = mfi.tilebox();
207 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
208 }
else if (var_name ==
"qv") {
209 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
211 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
213 const Box& bx = mfi.tilebox();
219 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
220 }
else if (var_name ==
"qc") {
221 MultiFab Temp(S.boxArray(),S.DistributionMap(),ncomp,0);
223 for (MFIter mfi(Temp, TilingIfNotGPU()); mfi.isValid(); ++mfi)
225 const Box& bx = mfi.tilebox();
231 bndry.copyFrom(Temp, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
232 }
else if (var_name ==
"velocity") {
233 MultiFab Vel(S.boxArray(), S.DistributionMap(), 3,
m_out_rad);
234 average_face_to_cellcenter(Vel,0,Array<const MultiFab*,3>{&
xvel,&
yvel,&
zvel});
235 bndry.copyFrom(Vel, nghost, 0, 0, ncomp,
m_geom[
bndry_lev].periodicity());
238 Error(
"Don't know how to output this variable");
241 for (OrientationIter oit; oit !=
nullptr; ++oit) {
243 if (ori.coordDir() < 2) {
244 std::string facename = Concatenate(filename +
'_', ori, 1);
245 br_shift(oit, bndry, bndry_shifted);
246 bndry_shifted[ori].write(facename);
253 if (ParallelDescriptor::IOProcessor()) {
255 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:157
@ cons
Definition: ERF_IndexDefines.H:156
@ zvel
Definition: ERF_IndexDefines.H:159
@ yvel
Definition: ERF_IndexDefines.H:158
void erf_derrhodivide(const Box &bx, FArrayBox &derfab, const FArrayBox &datfab, const int scalar_index)
Definition: ERF_Derive.cpp:18
void erf_dertemp(const Box &bx, FArrayBox &derfab, int, int, const FArrayBox &datfab, const Geometry &, Real, const int *, const int)
Definition: ERF_Derive.cpp:91
void erf_dermoisttemp(const Box &bx, FArrayBox &derfab, int, int, const FArrayBox &datfab, const Geometry &, Real, const int *, const int)
Definition: ERF_Derive.cpp:113