12 #ifndef CD_EBGhostCellInterpolator_H
13 #define CD_EBGhostCellInterpolator_H
19 #include <EBLevelGrid.H>
23 #include <CD_NamespaceHeader.H>
66 const EBLevelGrid& a_eblgCoFi,
67 const EBLevelGrid& a_eblgCoar,
68 const IntVect& a_ghostVector,
70 const
int a_ghostCF) noexcept;
88 define(const EBLevelGrid& a_eblgFine,
89 const EBLevelGrid& a_eblgCoFi,
90 const EBLevelGrid& a_eblgCoar,
91 const IntVect& a_ghostVector,
93 const
int a_ghostCF) noexcept;
104 const LevelData<EBCellFAB>& a_phiCoar,
105 const Interval a_variables,
106 const
Type a_interpType) const noexcept;
201 const FArrayBox& a_phiCoar,
202 const DataIndex& a_dit,
205 const
Type a_interpType) const noexcept;
218 const EBCellFAB& a_phiCoar,
219 const DataIndex& a_dit,
222 const
Type a_interpType) const noexcept;
230 minmod(const Real& dwl, const Real& dwr) const noexcept;
238 superbee(const Real& dwl, const Real& dwr) const noexcept;
249 #include <CD_NamespaceFooter.H>
Declaration of cell positions.
Class which can interpolate ghost cells across the coarse-fine interface. To select an interpolation ...
Definition: CD_EBGhostCellInterpolator.H:32
virtual void interpolateRegular(FArrayBox &a_phiFine, const FArrayBox &a_phiCoar, const DataIndex &a_dit, const int a_fineVar, const int a_coarVar, const Type a_interpType) const noexcept
Regular interpolation, as if the EB was not there.
Definition: CD_EBGhostCellInterpolator.cpp:216
LayoutData< std::map< std::pair< int, Side::LoHiSide >, Box > > m_regularGhostRegions
Regular ghost regions to be interpolated.
Definition: CD_EBGhostCellInterpolator.H:148
Real superbee(const Real &dwl, const Real &dwr) const noexcept
Superbee slope limiter.
Definition: CD_EBGhostCellInterpolator.cpp:479
EBGhostCellInterpolator() noexcept
Weak constructor. Need to call define afterwards.
Definition: CD_EBGhostCellInterpolator.cpp:24
LayoutData< VoFIterator > m_coarIrregCells
Coarse-grid cells on the caorse-side of the interface that are irregular cells.
Definition: CD_EBGhostCellInterpolator.H:170
virtual void defineBuffers() noexcept
Define buffers.
Definition: CD_EBGhostCellInterpolator.cpp:161
IntVect m_ghostVector
Minimum number of ghost cells in input data.
Definition: CD_EBGhostCellInterpolator.H:132
virtual void define(const EBLevelGrid &a_eblgFine, const EBLevelGrid &a_eblgCoFi, const EBLevelGrid &a_eblgCoar, const IntVect &a_ghostVector, const int a_refRat, const int a_ghostCF) noexcept
Define method. Puts object in usable state.
Definition: CD_EBGhostCellInterpolator.cpp:49
Real minmod(const Real &dwl, const Real &dwr) const noexcept
minmod slope function.
Definition: CD_EBGhostCellInterpolator.cpp:467
Copier m_copier
Copier for making copying from m_eblgCoar to m_grownCoarData go faster.
Definition: CD_EBGhostCellInterpolator.H:153
virtual void defineGhostRegions() noexcept
Define ghost regions to be interpolated.
Definition: CD_EBGhostCellInterpolator.cpp:75
bool m_isDefined
Is defined or not.
Definition: CD_EBGhostCellInterpolator.H:112
virtual void interpolateIrregular(EBCellFAB &a_phiFine, const EBCellFAB &a_phiCoar, const DataIndex &a_dit, const int a_fineVar, const int a_coarVar, const Type a_interpType) const noexcept
Ghost cell interpolation near the EB, correcting slopes that broke in interpolateRegular.
Definition: CD_EBGhostCellInterpolator.cpp:344
LayoutData< BaseIVFAB< VolIndex > > m_coarsenedFineGhosts
List of coarse-grid cells that appear through coarsening a fine-grid ghost cell.
Definition: CD_EBGhostCellInterpolator.H:160
EBLevelGrid m_eblgFine
Fine grids.
Definition: CD_EBGhostCellInterpolator.H:117
LayoutData< VoFIterator > m_fineIrregCells
Fine-grid ghost cells on the coarse-fine interface that overlap an irregular coarse cell.
Definition: CD_EBGhostCellInterpolator.H:165
EBLevelGrid m_eblgCoar
Coarse grids.
Definition: CD_EBGhostCellInterpolator.H:122
EBLevelGrid m_eblgCoFi
Coarsened fine grids.
Definition: CD_EBGhostCellInterpolator.H:127
Real monotonizedCentral(const Real &dwl, const Real &dwr) const noexcept
Monotonized central difference slope limiter.
Definition: CD_EBGhostCellInterpolator.cpp:496
virtual void interpolate(LevelData< EBCellFAB > &a_phiFine, const LevelData< EBCellFAB > &a_phiCoar, const Interval a_variables, const Type a_interpType) const noexcept
Do inhomogeneous interpolation.
Definition: CD_EBGhostCellInterpolator.cpp:169
int m_refRat
Refinement factor between fine and coarse level.
Definition: CD_EBGhostCellInterpolator.H:137
Type
Type of interpolation slopes supported.
Definition: CD_EBGhostCellInterpolator.H:38
LayoutData< BaseIVFAB< Real > > m_coarIrregSlopes
Buffer data defined on the coarsened fine grids (over m_coarIrregCells). Used for holding slopes in t...
Definition: CD_EBGhostCellInterpolator.H:176
int m_ghostCF
Number of ghost cells to fill across coarse-fine interface.
Definition: CD_EBGhostCellInterpolator.H:143