12#ifndef CD_EBHelmholtzDomainBC_H
13#define CD_EBHelmholtzDomainBC_H
16#include <EBLevelGrid.H>
17#include <RefCountedPtr.H>
23#include <CD_NamespaceHeader.H>
170#include <CD_NamespaceFooter.H>
172#include <CD_EBHelmholtzDomainBCImplem.H>
Declaration of cell positions.
Base class for passing domain boundary conditions into EBHelmholtzOp.
Definition CD_EBHelmholtzDomainBC.H:29
EBLevelGrid m_eblg
Level grid.
Definition CD_EBHelmholtzDomainBC.H:141
RealVect getBoundaryPosition(const IntVect &a_iv, const int &a_dir, const Side::LoHiSide &a_side) const
Returns the cell-centered position at the boundary.
Definition CD_EBHelmholtzDomainBCImplem.H:20
virtual Real getFaceFlux(const VolIndex &a_vof, const EBCellFAB &a_phi, const EBFaceFAB &a_Bcoef, const int &a_dir, const Side::LoHiSide &a_side, const DataIndex &a_dit, const bool a_useHomogeneous) const =0
Get face flux. This is for irregular cells.
Location::Cell m_dataLocation
Data centering.
Definition CD_EBHelmholtzDomainBC.H:126
EBHelmholtzDomainBC & operator=(const EBHelmholtzDomainBC &a_other)=delete
Disallowed - don't see why you would need it.
EBHelmholtzDomainBC()
Constructor.
Definition CD_EBHelmholtzDomainBC.cpp:23
void multiplyByBcoef(BaseFab< Real > &a_flux, const BaseFab< Real > &a_bco, const int a_dir, const Side::LoHiSide a_side) const
Utility function which multiplies the flux (or actually, dphi/dn) by the B-coefficient....
Definition CD_EBHelmholtzDomainBC.cpp:50
virtual void getFaceFlux(BaseFab< Real > &a_faceFlux, const BaseFab< Real > &a_phi, const BaseFab< Real > &a_Bcoef, const int &a_dir, const Side::LoHiSide &a_side, const DataIndex &a_dit, const bool a_useHomogeneous) const =0
Get face flux. This is for regular cells.
static constexpr int m_nComp
Number of components. Always have m_nComp = 1.
Definition CD_EBHelmholtzDomainBC.H:121
static constexpr int m_comp
Component that everything is defined for. Always have m_comp = 0.
Definition CD_EBHelmholtzDomainBC.H:116
EBHelmholtzDomainBC(const EBHelmholtzDomainBC &a_other)=delete
Disallowed – don't see why you would need it.
EBHelmholtzDomainBC & operator=(const EBHelmholtzDomainBC &&a_other)=delete
Disallowed - don't see why you would need it.
EBHelmholtzDomainBC(const EBHelmholtzDomainBC &&a_other)=delete
Disallowed – don't see why you would need it.
Real m_dx
Grid resolution.
Definition CD_EBHelmholtzDomainBC.H:131
virtual ~EBHelmholtzDomainBC()
Destructor.
Definition CD_EBHelmholtzDomainBC.cpp:28
virtual void define(const Location::Cell a_dataLocation, const EBLevelGrid &a_eblg, const RealVect &a_probLo, const Real a_dx)
Define function.
Definition CD_EBHelmholtzDomainBC.cpp:34
RealVect m_probLo
Lower-left corner of computational domain.
Definition CD_EBHelmholtzDomainBC.H:136
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:37
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:25
Cell
Enum for distinguishing between cell locations.
Definition CD_Location.H:30