16template<
typename ValueType>
19 SurfaceBoundaryFactory<ValueType>,
20 Parameters<const UnstructuredMesh&, const Dictionary&, localIdx>>,
25 static std::string
name() {
return "SurfaceBoundaryFactory"; }
34 virtual std::unique_ptr<SurfaceBoundaryFactory>
clone()
const = 0;
43template<
typename ValueType>
51 mesh.boundaryMesh().offset()[static_cast<
size_t>(
patchID) + 1],
55 dict.get<std::string>(
"type"), mesh, dict,
patchID
61 boundaryCorrectionStrategy_(other.boundaryCorrectionStrategy_->clone())
66 boundaryCorrectionStrategy_->correctBoundaryCondition(domainVector);
73 std::unique_ptr<NeoN::finiteVolume::cellCentred::SurfaceBoundaryFactory<ValueType>>
74 boundaryCorrectionStrategy_;
A class representing a dictionary that stores key-value pairs.
Represents the domain fields for a computational domain.
A factory class for runtime selection of derived classes.
Represents an unstructured mesh in NeoN.
A base class for implementing derived boundary conditions.
virtual std::unique_ptr< SurfaceBoundaryFactory > clone() const =0
static std::string name()
virtual void correctBoundaryCondition(Field< ValueType > &field)=0
SurfaceBoundaryFactory(const UnstructuredMesh &mesh, const Dictionary &, localIdx patchID)
Represents a surface boundary field for a cell-centered finite volume method.
virtual void correctBoundaryCondition(Field< ValueType > &domainVector)
SurfaceBoundary(const UnstructuredMesh &mesh, const Dictionary &dict, localIdx patchID)
SurfaceBoundary(const SurfaceBoundary &other)