17template<
typename ValueType>
20 SurfaceBoundaryFactory<ValueType>,
21 Parameters<const UnstructuredMesh&, const Dictionary&, localIdx>>,
26 static std::string
name() {
return "SurfaceBoundaryFactory"; }
35 virtual std::unique_ptr<SurfaceBoundaryFactory>
clone()
const = 0;
44template<
typename ValueType>
52 mesh.boundaryMesh().offset()[static_cast<
size_t>(
patchID) + 1],
56 dict.get<std::string>(
"type"), mesh, dict,
patchID
62 boundaryCorrectionStrategy_(other.boundaryCorrectionStrategy_->clone())
67 boundaryCorrectionStrategy_->correctBoundaryCondition(domainVector);
74 std::unique_ptr<NeoN::finiteVolume::cellCentred::SurfaceBoundaryFactory<ValueType>>
75 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)