chombo-discharge
Loading...
Searching...
No Matches
CD_EddingtonSP1DomainBc.H
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
13#ifndef CD_EDDINGTONSP1DOMAINBC_H
14#define CD_EDDINGTONSP1DOMAINBC_H
15
16// Std include
17#include <functional>
18#include <map>
19
20// Chombo includes
21#include <RealVect.H>
22#include <LoHiSide.H>
23
24// Our includes
25#include <CD_NamespaceHeader.H>
26
32{
33public:
37 enum class BcType
38 {
39 Dirichlet,
40 Neumann,
41 Larsen,
42 };
43
48
53
58
63
69
75
83
90
94 virtual ~EddingtonSP1DomainBc();
95
102 void
103 setBc(const DomainSide a_domainSide, const Bc& a_bc);
104
111 Bc&
113
120 const Bc&
121 getBc(const DomainSide a_domainSide) const;
122
123protected:
129};
130
131#include <CD_NamespaceFooter.H>
132
133#endif
Class which maps boundary condition types to a side and direction.
Definition CD_EddingtonSP1DomainBc.H:32
std::pair< BcType, BcFunction > Bc
Alias for mapping a bctype and function.
Definition CD_EddingtonSP1DomainBc.H:57
std::map< DomainSide, Bc > m_bcFunctions
This holds the map to the boundary condition type and side. The first entry in the map is the directi...
Definition CD_EddingtonSP1DomainBc.H:128
Bc & getBc(const DomainSide a_domainSide)
Returns the boundary condition for a side and direction.
Definition CD_EddingtonSP1DomainBc.cpp:46
EddingtonSP1DomainBc(const EddingtonSP1DomainBc &a_domainBc)=default
Copy constructor.
EddingtonSP1DomainBc(const EddingtonSP1DomainBc &&a_domainBc)=delete
Disallowedd move constructor.
void setBc(const DomainSide a_domainSide, const Bc &a_bc)
Set the boundary condition on a domain side. You must set both the type, and the associated function.
Definition CD_EddingtonSP1DomainBc.cpp:40
std::function< Real(const RealVect a_position, const Real a_time)> BcFunction
Function which maps f(R^3,t) : R. Used for setting the associated value and boundary condition type.
Definition CD_EddingtonSP1DomainBc.H:47
EddingtonSP1DomainBc()
Initializing constructor. This populates the bc.
Definition CD_EddingtonSP1DomainBc.cpp:17
std::pair< int, Side::LoHiSide > DomainSide
Alias for mapping a direction and side.
Definition CD_EddingtonSP1DomainBc.H:52
BcType
Boundary condition type.
Definition CD_EddingtonSP1DomainBc.H:38
EddingtonSP1DomainBc & operator=(const EddingtonSP1DomainBc &&a_domainBc)=delete
Disallowed move assignment.
virtual ~EddingtonSP1DomainBc()
Destructor. This.
Definition CD_EddingtonSP1DomainBc.cpp:34
EddingtonSP1DomainBc & operator=(const EddingtonSP1DomainBc &a_domainBc)=default
Copy assignment.
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