17 const int clearval = TagBox::CLEAR;
18 const int tagval = TagBox::SET;
23 std::unique_ptr<MultiFab> mf = std::make_unique<MultiFab>(grids[levc], dmap[levc], 1, 1);
25 for (
int j=0; j <
ref_tags.size(); ++j)
36 }
else if (
ref_tags[j].Field() ==
"temp") {
38 }
else if (
ref_tags[j].Field() ==
"salt") {
40 }
else if (
ref_tags[j].Field() ==
"x_velocity") {
42 MultiFab::Copy(*mf,*
xvel_new[levc],0,0,1,1);
43 }
else if (
ref_tags[j].Field() ==
"y_velocity") {
45 MultiFab::Copy(*mf,*
yvel_new[levc],0,0,1,1);
46 }
else if (
ref_tags[j].Field() ==
"z_velocity") {
48 MultiFab::Copy(*mf,*
zvel_new[levc],0,0,1,1);
49 }
else if (
ref_tags[j].Field() ==
"vorticity") {
50 MultiFab mf_cc_vel(grids[levc],dmap[levc],3,1);
51 average_face_to_cellcenter(mf_cc_vel,0,
52 Array<const MultiFab*,3>{
xvel_new[levc],
59#pragma omp parallel if (Gpu::notInLaunchRegion())
61 for (MFIter mfi(*mf, TilingIfNotGPU()); mfi.isValid(); ++mfi)
63 const Box& bx = mfi.tilebox();
64 auto& dfab = (*mf)[mfi];
65 auto& sfab = mf_cc_vel[mfi];
66 auto pm =
vec_pm[levc]->const_array(mfi);
67 auto pn =
vec_pn[levc]->const_array(mfi);
68 auto maskr =
vec_mskr[levc]->const_array(mfi);
69 derived::remora_dervort(bx, dfab, 0, 1, sfab, pm, pn, maskr, Geom(levc), time,
nullptr, levc);
72 mf->FillBoundary(geom[levc].periodicity());
77 }
else if (
ref_tags[j].Field() ==
"mask") {
78 MultiFab::Copy(*mf,*
vec_mskr3d[levc],0,0,1,IntVect(1,1,0));
79#ifdef REMORA_USE_PARTICLES
89 const auto& particles_namelist( particleData.getNames() );
91 for (ParticlesNamesVector::size_type i = 0; i < particles_namelist.size(); i++)
93 std::string tmp_string(particles_namelist[i]+
"_count");
94 IntVect rr = IntVect::TheUnitVector();
95 if (
ref_tags[j].Field() == tmp_string) {
96 for (
int lev = levc; lev <= finest_level; lev++)
98 MultiFab temp_dat(grids[lev], dmap[lev], 1, 0); temp_dat.setVal(0);
99 particleData[particles_namelist[i]]->IncrementWithTotal(temp_dat, lev);
101 MultiFab temp_dat_crse(grids[levc], dmap[levc], 1, 0); temp_dat_crse.setVal(0);
104 MultiFab::Copy(*mf, temp_dat, 0, 0, 1, 0);
106 for (
int d = 0; d < AMREX_SPACEDIM; d++) {
107 rr[d] *= ref_ratio[levc][d];
109 average_down(temp_dat, temp_dat_crse, 0, 1, rr);
110 MultiFab::Add(*mf, temp_dat_crse, 0, 0, 1, 0);
120 ref_tags[j](tags,mf.get(),clearval,tagval,time,levc,geom[levc]);
133 Vector<std::string> refinement_indicators;
134 pp.queryarr(
"refinement_indicators",refinement_indicators,0,pp.countval(
"refinement_indicators"));
136 for (
int i=0; i<refinement_indicators.size(); ++i)
138 std::string ref_prefix =
pp_prefix +
"." + refinement_indicators[i];
140 ParmParse ppr(ref_prefix);
143 if (ppr.countval(
"in_box_lo")) {
144 std::vector<Real> box_lo(3), box_hi(3);
145 ppr.get(
"max_level",lev_for_box);
146 if (lev_for_box <= max_level)
148 ppr.getarr(
"in_box_lo",box_lo,0,2);
149 ppr.getarr(
"in_box_hi",box_hi,0,2);
150 box_lo[2] = geom[0].ProbLo(2);
151 box_hi[2] = geom[0].ProbHi(2);
152 realbox = RealBox(&(box_lo[0]),&(box_hi[0]));
154 amrex::Print() <<
"Reading " << realbox <<
" at level " << lev_for_box << std::endl;
157 const auto* dx = geom[lev_for_box].CellSize();
158 const Real* plo = geom[lev_for_box].ProbLo();
159 int ilo =
static_cast<int>((box_lo[0] - plo[0])/dx[0]);
160 int jlo =
static_cast<int>((box_lo[1] - plo[1])/dx[1]);
161 int klo =
static_cast<int>((box_lo[2] - plo[2])/dx[2]);
162 int ihi =
static_cast<int>((box_hi[0] - plo[0])/dx[0]-1);
163 int jhi =
static_cast<int>((box_hi[1] - plo[1])/dx[1]-1);
164 int khi =
static_cast<int>((box_hi[2] - plo[2])/dx[2]-1);
165 Box bx_old(IntVect(ilo,jlo,klo),IntVect(ihi,jhi,khi));
166 int mod_ilo = ilo%ref_ratio[lev_for_box-1][0];
167 int mod_ihi = (ihi+1)%ref_ratio[lev_for_box-1][0];
168 int mod_jlo = jlo%ref_ratio[lev_for_box-1][0];
169 int mod_jhi = (jhi+1)%ref_ratio[lev_for_box-1][0];
177 ihi += ref_ratio[lev_for_box-1][0] - mod_ihi;
180 jhi += ref_ratio[lev_for_box-1][1] - mod_jhi;
182 Box bx(IntVect(ilo,jlo,klo),IntVect(ihi,jhi,khi));
183 if (mod_ilo !=0 || mod_jlo !=0 || mod_ihi != 0 || mod_jhi != 0) {
184 amrex::Print() <<
"Fine box on level " << lev_for_box <<
" adjusted from " << bx_old <<
" to " << bx <<
" to make it valid for refinement." << std::endl;
187 amrex::Print() <<
"Saving in 'boxes at level' as " << bx << std::endl;
191 AMRErrorTagInfo info;
194 info.SetRealBox(realbox);
196 if (ppr.countval(
"start_time") > 0) {
197 Real ref_min_time; ppr.get(
"start_time",ref_min_time);
198 info.SetMinTime(ref_min_time);
200 if (ppr.countval(
"end_time") > 0) {
201 Real ref_max_time; ppr.get(
"end_time",ref_max_time);
202 info.SetMaxTime(ref_max_time);
204 if (ppr.countval(
"max_level") > 0) {
205 int ref_max_level; ppr.get(
"max_level",ref_max_level);
206 info.SetMaxLevel(ref_max_level);
209 if (ppr.countval(
"value_greater")) {
210 int num_val = ppr.countval(
"value_greater");
211 Vector<Real> value(num_val);
212 ppr.getarr(
"value_greater",value,0,num_val);
213 std::string field; ppr.get(
"field_name",field);
214 ref_tags.push_back(AMRErrorTag(value,AMRErrorTag::GREATER,field,info));
216 else if (ppr.countval(
"value_less")) {
217 int num_val = ppr.countval(
"value_less");
218 Vector<Real> value(num_val);
219 ppr.getarr(
"value_less",value,0,num_val);
220 std::string field; ppr.get(
"field_name",field);
221 ref_tags.push_back(AMRErrorTag(value,AMRErrorTag::LESS,field,info));
223 else if (ppr.countval(
"adjacent_difference_greater")) {
224 int num_val = ppr.countval(
"adjacent_difference_greater");
225 Vector<Real> value(num_val);
226 ppr.getarr(
"adjacent_difference_greater",value,0,num_val);
227 std::string field; ppr.get(
"field_name",field);
228 ref_tags.push_back(AMRErrorTag(value,AMRErrorTag::GRAD,field,info));
230 else if (realbox.ok())
232 ref_tags.push_back(AMRErrorTag(info));
234 Abort(std::string(
"Unrecognized refinement indicator for " + refinement_indicators[i]).c_str());
238 AMRErrorTagInfo info;
241 ref_tags.push_back(AMRErrorTag(value,AMRErrorTag::LESS,
"mask",info));
void FillPatch(int lev, amrex::Real time, amrex::MultiFab &mf_to_be_filled, amrex::Vector< amrex::MultiFab * > const &mfs, const int bccomp, const int bdy_var_type=BdyVars::null, const int icomp=0, const bool fill_all=true, const bool fill_set=true, const int n_not_fill=0, const int icomp_calc=0, const amrex::Real dt=amrex::Real(0.0), const amrex::MultiFab &mf_calc=amrex::MultiFab())
Fill a new MultiFab by copying in phi from valid region and filling ghost cells.
void remora_dervort(const amrex::Box &bx, amrex::FArrayBox &derfab, int dcomp, int ncomp, const amrex::FArrayBox &datfab, const amrex::Array4< const amrex::Real > &pm, const amrex::Array4< const amrex::Real > &pn, const amrex::Array4< const amrex::Real > &, const amrex::Geometry &, amrex::Real, const int *, const int)