1#ifndef REMORA_FILLPATCHER_H_
2#define REMORA_FILLPATCHER_H_
4#include <AMReX_FillPatchUtil.H>
5#include <AMReX_Interp_C.H>
6#include <AMReX_MFInterp_C.H>
13 REMORAFillPatcher (amrex::BoxArray
const& fba, amrex::DistributionMapping
const& fdm,
14 amrex::Geometry
const& fgeom,
15 amrex::BoxArray
const& cba, amrex::DistributionMapping
const& cdm,
16 amrex::Geometry
const& cgeom,
17 int nghost,
int nghost_set,
int ncomp, amrex::InterpBase* interp);
20 void Define (amrex::BoxArray
const& fba, amrex::DistributionMapping
const& fdm,
21 amrex::Geometry
const& fgeom,
22 amrex::BoxArray
const& cba, amrex::DistributionMapping
const& cdm,
23 amrex::Geometry
const& cgeom,
24 int nghost,
int nghost_set,
int ncomp,
25 amrex::InterpBase* interp);
28 void BuildMask (amrex::BoxArray
const& fba,
int nghost,
int nghost_set);
32 amrex::Vector<amrex::Real>
const& crse_time);
36 amrex::MultiFab
const& crse,
41 amrex::MultiFab
const& crse,
42 amrex::Vector<amrex::BCRec>
const& bcr,
52 template <
typename BC>
53 void FillSet (amrex::MultiFab& mf, amrex::Real time,
54 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs);
57 template <
typename BC>
58 void FillRelax (amrex::MultiFab& mf, amrex::Real time,
59 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs);
61 template <
typename BC>
62 void Fill (amrex::MultiFab& mf, amrex::Real time,
63 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs,
int mask_val);
69 amrex::DistributionMapping
m_fdm;
70 amrex::DistributionMapping
m_cdm;
96 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs)
107template <
typename BC>
110 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs)
122template <
typename BC>
125 BC& cbc, amrex::Vector<amrex::BCRec>
const& bcs,
int mask_val)
127 constexpr amrex::Real eps = std::numeric_limits<float>::epsilon();
133 amrex::Real fac_old = 1.0 - fac_new;
144 amrex::MultiFab::LinComb(crse_data_time_interp,
147 0,
m_ncomp, amrex::IntVect{0});
150 amrex::IndexType m_ixt = mf.boxArray().ixType();
151 int ixt_sum = m_ixt[0]+m_ixt[1]+m_ixt[2];
153 InterpCell(mf,crse_data_time_interp,bcs,mask_val);
154 }
else if (ixt_sum == 1) {
155 InterpFace(mf,crse_data_time_interp,mask_val);
157 amrex::Abort(
"REMORA_FillPatcher only supports face linear and cell cons linear interp!");
amrex::InterpBase * m_interp
void FillRelax(amrex::MultiFab &mf, amrex::Real time, BC &cbc, amrex::Vector< amrex::BCRec > const &bcs)
Fill fine data in the relax region.
amrex::DistributionMapping m_fdm
amrex::iMultiFab * GetMask()
void Define(amrex::BoxArray const &fba, amrex::DistributionMapping const &fdm, amrex::Geometry const &fgeom, amrex::BoxArray const &cba, amrex::DistributionMapping const &cdm, amrex::Geometry const &cgeom, int nghost, int nghost_set, int ncomp, amrex::InterpBase *interp)
Redefine the coarse and fine patch MultiFabs.
void RegisterCoarseData(amrex::Vector< amrex::MultiFab const * > const &crse_data, amrex::Vector< amrex::Real > const &crse_time)
Register the coarse data to be used by the REMORAFillPatcher.
void InterpCell(amrex::MultiFab &fine, amrex::MultiFab const &crse, amrex::Vector< amrex::BCRec > const &bcr, int mask_val)
Interpolate to cell centers.
void Fill(amrex::MultiFab &mf, amrex::Real time, BC &cbc, amrex::Vector< amrex::BCRec > const &bcs, int mask_val)
Fill fine data in the relax region.
amrex::Vector< amrex::Real > m_crse_times
void InterpFace(amrex::MultiFab &fine, amrex::MultiFab const &crse, int mask_val)
Interpolate to cell faces.
std::unique_ptr< amrex::MultiFab > m_cf_crse_data_new
void BuildMask(amrex::BoxArray const &fba, int nghost, int nghost_set)
Generate masking array.
amrex::DistributionMapping m_cdm
std::unique_ptr< amrex::iMultiFab > m_cf_mask
std::unique_ptr< amrex::MultiFab > m_cf_crse_data_old
void FillSet(amrex::MultiFab &mf, amrex::Real time, BC &cbc, amrex::Vector< amrex::BCRec > const &bcs)
Fill fine data in the set region.