12 #ifndef CD_MFHelmholtzJumpBC_H
13 #define CD_MFHelmholtzJumpBC_H
16 #include <MFCellFAB.H>
18 #include <LayoutData.H>
20 #include <AggStencil.H>
21 #include <EBCellFAB.H>
22 #include <BaseIVFAB.H>
30 #include <CD_NamespaceHeader.H>
47 using BcoefPtr = RefCountedPtr<LevelData<MFBaseIVFAB>>;
74 const IntVect a_ghostPhi);
97 setBco(
const RefCountedPtr<LevelData<MFBaseIVFAB>>& a_Bcoef);
131 matchBC(LevelData<BaseIVFAB<Real>>& a_jump, const LevelData<MFCellFAB>& a_phi, const
bool a_homogeneousPhysBC) const;
141 matchBC(BaseIVFAB<Real>& a_jump,
142 const MFCellFAB& a_phi,
143 const
bool a_homogeneousPhysBC,
144 const DataIndex& a_dit) const;
152 virtual const BaseIVFAB<Real>&
153 getBndryPhi(const
int a_phase, const DataIndex& a_dit) const;
304 LayoutData<RefCountedPtr<AggStencil<EBCellFAB, BaseIVFAB<Real>>>>
m_aggStencils[2];
336 const VolIndex& a_vof,
337 const EBISBox& a_ebisbox,
338 const
VofUtils::Neighborhood a_neighborhood,
339 const
int a_order) const;
348 isStencilValidCF(const VoFStencil& a_stencil, const DataIndex& a_dit) const;
357 applyStencil(const VoFStencil& a_stencil, const EBCellFAB& a_phi) const;
360 #include <CD_NamespaceFooter.H>
362 #include <CD_MFHelmholtzJumpBCImplem.H>
Declaration of cell positions.
Declaration of a multiphase BaseIVFAB<Real>
Declaration of a class that allocates irregular data holders over the interface between two phases.
Declaration of a wrapper for wrapping multifluid EBLevelGrids.
Various functions for getting Vofs near cut-cells.
Multiphase BaseIVFAB<Real>.
Definition: CD_MFBaseIVFAB.H:29
Class for computing "jump interface" boundary conditions for multifluid code.
Definition: CD_MFHelmholtzJumpBC.H:42
virtual VoFIterator & getSinglePhaseVofs(const int a_phase, const DataIndex &a_dit) const
Return vof iterator which iterates over single-phase cells on a specific phase and box.
Definition: CD_MFHelmholtzJumpBC.cpp:88
static constexpr int m_comp
Component where stencils are stored.
Definition: CD_MFHelmholtzJumpBC.H:189
Real m_dx
Grid resolution.
Definition: CD_MFHelmholtzJumpBC.H:214
MFHelmholtzJumpBC & operator=(const MFHelmholtzJumpBC &a_other)=delete
Disallowed assignment constructor.
LayoutData< MFInterfaceFAB< VoFStencil > > m_avgStencils
Average stencil.
Definition: CD_MFHelmholtzJumpBC.H:284
LayoutData< MFInterfaceFAB< Real > > m_boundaryPhi
Value of phi on the boundary.
Definition: CD_MFHelmholtzJumpBC.H:254
LayoutData< MFInterfaceFAB< Real > > m_denom
Denominator 1/(bp*wp + bq*wq) for all interface cells.
Definition: CD_MFHelmholtzJumpBC.H:294
int m_ghostCF
Number of grid cells that were filled over the CF.
Definition: CD_MFHelmholtzJumpBC.H:234
virtual const LayoutData< MFInterfaceFAB< Real > > & getGradPhiWeights() const noexcept
Get constant weights involved when computing dphi/dn at the boundary.
Definition: CD_MFHelmholtzJumpBC.cpp:106
LayoutData< MFInterfaceFAB< Real > > m_gradPhiWeights
Raw weights for dphi/dn.
Definition: CD_MFHelmholtzJumpBC.H:279
Real applyStencil(const VoFStencil &a_stencil, const EBCellFAB &a_phi) const
Apply a stencil and return the result.
Definition: CD_MFHelmholtzJumpBCImplem.H:69
RefCountedPtr< LevelData< MFBaseIVFAB > > m_Bcoef
B-coefficient.
Definition: CD_MFHelmholtzJumpBC.H:209
virtual void matchBC(LevelData< BaseIVFAB< Real >> &a_jump, const LevelData< MFCellFAB > &a_phi, const bool a_homogeneousPhysBC) const
Match the BC.
Definition: CD_MFHelmholtzJumpBC.cpp:535
virtual bool getLeastSquaresBoundaryGradStencil(std::pair< Real, VoFStencil > &a_stencil, const VolIndex &a_vof, const EBISBox &a_ebisbox, const VofUtils::Neighborhood a_neighborhood, const int a_order) const
Get stencil with specified order.
Definition: CD_MFHelmholtzJumpBC.cpp:476
bool isMultiPhase() const noexcept
Is multiphase or not.
Definition: CD_MFHelmholtzJumpBC.cpp:123
int m_numPhases
Number of phases.
Definition: CD_MFHelmholtzJumpBC.H:239
int m_order
Stencil order.
Definition: CD_MFHelmholtzJumpBC.H:219
LayoutData< RefCountedPtr< AggStencil< EBCellFAB, BaseIVFAB< Real > > > > m_aggStencils[2]
Agg stencils for making matching go faster.
Definition: CD_MFHelmholtzJumpBC.H:304
virtual const LayoutData< MFInterfaceFAB< VoFStencil > > & getGradPhiStencils() const noexcept
Get stencils for computing dphi/dn at the boundary.
Definition: CD_MFHelmholtzJumpBC.cpp:100
int m_radius
Stencil order.
Definition: CD_MFHelmholtzJumpBC.H:229
int getWeight() const
Return stencil weight (for least squares)
Definition: CD_MFHelmholtzJumpBC.cpp:70
RefCountedPtr< LevelData< MFBaseIVFAB > > BcoefPtr
Alias to cut down on typing.
Definition: CD_MFHelmholtzJumpBC.H:47
MFHelmholtzJumpBC(const MFHelmholtzJumpBC &a_other)=delete
Disallowed copy constructor.
LayoutData< MFInterfaceFAB< Real > > m_avgWeights
Average weights.
Definition: CD_MFHelmholtzJumpBC.H:299
Location::Cell m_dataLocation
Data centering.
Definition: CD_MFHelmholtzJumpBC.H:199
MFHelmholtzJumpBC()=delete
Disallowed weak construction.
IntVect m_ghostPhi
Number of ghost cells in phi (must be exact match in order to use AggStencil)
Definition: CD_MFHelmholtzJumpBC.H:244
void defineIterators()
Define function. Builds stencils.
Definition: CD_MFHelmholtzJumpBC.cpp:421
bool isStencilValidCF(const VoFStencil &a_stencil, const DataIndex &a_dit) const
Check if stencil is valid.
Definition: CD_MFHelmholtzJumpBCImplem.H:23
void defineStencils()
Define function. Builds stencils.
Definition: CD_MFHelmholtzJumpBC.cpp:131
void buildAverageStencils()
Brief the average stencils.
Definition: CD_MFHelmholtzJumpBC.cpp:279
virtual void resetBC() const
Set everything to zero. This is a debugging function.
Definition: CD_MFHelmholtzJumpBC.cpp:516
static constexpr int m_nComp
Number of components in stencil.
Definition: CD_MFHelmholtzJumpBC.H:194
void setBco(const RefCountedPtr< LevelData< MFBaseIVFAB >> &a_Bcoef)
Set B-coefficient. This updates the stencils.
Definition: CD_MFHelmholtzJumpBC.cpp:112
int getRadius() const
Return stencil radius (for least squares)
Definition: CD_MFHelmholtzJumpBC.cpp:76
LayoutData< IntVectSet > m_ivs
IntVectSet over which we run the "averaging".
Definition: CD_MFHelmholtzJumpBC.H:269
MFLevelGrid m_mflg
Grids.
Definition: CD_MFHelmholtzJumpBC.H:204
LayoutData< MFInterfaceFAB< VoFStencil > > m_gradPhiStencils
Raw stencils for dphi/dn.
Definition: CD_MFHelmholtzJumpBC.H:274
virtual ~MFHelmholtzJumpBC()
Destructor. Does nothing.
Definition: CD_MFHelmholtzJumpBC.cpp:58
std::map< int, std::shared_ptr< LayoutData< VoFIterator > > > m_multiPhaseVofs
Iterators for multi-phase cells. The integer index is the phase.
Definition: CD_MFHelmholtzJumpBC.H:264
int getOrder() const
Return stencil order.
Definition: CD_MFHelmholtzJumpBC.cpp:64
LayoutData< MFInterfaceFAB< Vector< VolIndex > > > m_avgVoFs
Target vofs for average stencils.
Definition: CD_MFHelmholtzJumpBC.H:289
virtual VoFIterator & getMultiPhaseVofs(const int a_phase, const DataIndex &a_dit) const
Return vof iterator which iterates over multi-phase cells on a specified phase and box.
Definition: CD_MFHelmholtzJumpBC.cpp:94
virtual const BaseIVFAB< Real > & getBndryPhi(const int a_phase, const DataIndex &a_dit) const
Get phi on the boundary.
Definition: CD_MFHelmholtzJumpBC.cpp:82
bool m_multiPhase
Multiphase or not.
Definition: CD_MFHelmholtzJumpBC.H:249
int m_weight
Stencil order.
Definition: CD_MFHelmholtzJumpBC.H:224
std::map< int, std::shared_ptr< LayoutData< VoFIterator > > > m_singlePhaseVofs
Iterators for single-phase cells. The integer index is the phase.
Definition: CD_MFHelmholtzJumpBC.H:259
Class for holding BaseIVFAB<T> on the interface between two phases.
Definition: CD_MFInterfaceFAB.H:30
Wrapper class for holding multifluid EBLevelGrids.
Definition: CD_MFLevelGrid.H:29
Static class which contains some routines for fetching VoFs using various algorithms....
Definition: CD_VofUtils.H:33
Namespace for encapsulating various data centerings.
Definition: CD_Location.H:24
Cell
Enum for distinguishing between cell locations.
Definition: CD_Location.H:30