chombo-discharge
Loading...
Searching...
No Matches
CD_EBHelmholtzDomainBC.H
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
7/*
8 @file CD_EBHelmholtzDomainBC.H
9 @brief Declaration of a domain boundary condition class for EBHelmholtzOp.
10 @author Robert Marskar
11*/
12
13#ifndef CD_EBHELMHOLTZDOMAINBC_H
14#define CD_EBHELMHOLTZDOMAINBC_H
15
16// Chombo includes
17#include <EBLevelGrid.H>
18#include <RefCountedPtr.H>
19#include <LevelData.H>
20#include <EBFluxFAB.H>
21
22// Our includes
23#include <CD_Location.H>
24#include <CD_NamespaceHeader.H>
25
30{
31public:
36
40 virtual ~EBHelmholtzDomainBC();
41
46
51
57
63
72 virtual void
74
86 virtual void
88 const BaseFab<Real>& a_phi,
90 const int& a_dir,
92 const DataIndex& a_dit,
93 const bool a_useHomogeneous) const = 0;
94
106 virtual Real
108 const EBCellFAB& a_phi,
109 const EBFaceFAB& a_Bcoef,
110 const int& a_dir,
111 const Side::LoHiSide& a_side,
112 const DataIndex& a_dit,
113 const bool a_useHomogeneous) const = 0;
114
115protected:
119 constexpr static int m_comp = 0;
120
124 constexpr static int m_nComp = 1;
125
130
135
140
145
153 inline RealVect
154 getBoundaryPosition(const IntVect& a_iv, const int& a_dir, const Side::LoHiSide& a_side) const;
155
167 static void
169};
170
171#include <CD_NamespaceFooter.H>
172
173#include <CD_EBHelmholtzDomainBCImplem.H>
174
175#endif
Declaration of cell positions.
Base class for passing domain boundary conditions into EBHelmholtzOp.
Definition CD_EBHelmholtzDomainBC.H:30
EBLevelGrid m_eblg
Level grid.
Definition CD_EBHelmholtzDomainBC.H:144
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:21
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:129
EBHelmholtzDomainBC & operator=(const EBHelmholtzDomainBC &a_other)=delete
Disallowed - don't see why you would need it.
EBHelmholtzDomainBC()
Constructor.
Definition CD_EBHelmholtzDomainBC.cpp:24
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:124
static constexpr int m_comp
Component that everything is defined for. Always have m_comp = 0.
Definition CD_EBHelmholtzDomainBC.H:119
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.
static void multiplyByBcoef(BaseFab< Real > &a_flux, const BaseFab< Real > &a_bco, const int a_dir, const Side::LoHiSide a_side)
Utility function which multiplies the flux (or actually, dphi/dn) by the B-coefficient....
Definition CD_EBHelmholtzDomainBC.cpp:51
Real m_dx
Grid resolution.
Definition CD_EBHelmholtzDomainBC.H:134
virtual ~EBHelmholtzDomainBC()
Destructor.
Definition CD_EBHelmholtzDomainBC.cpp:29
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:35
RealVect m_probLo
Lower-left corner of computational domain.
Definition CD_EBHelmholtzDomainBC.H:139
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26
Cell
Enum for distinguishing between cell locations.
Definition CD_Location.H:31