16template<
typename ValueType>
19 VolumeBoundaryFactory<ValueType>,
20 Parameters<const UnstructuredMesh&, const Dictionary&, localIdx>>,
25 static std::string
name() {
return "VolumeBoundaryFactory"; }
36 virtual std::unique_ptr<VolumeBoundaryFactory>
clone()
const = 0;
45template<
typename ValueType>
53 mesh.boundaryMesh().offset()[static_cast<
size_t>(
patchID) + 1],
57 dict.get<std::string>(
"type"), mesh, dict,
patchID
63 boundaryCorrectionStrategy_(other.boundaryCorrectionStrategy_->clone())
68 boundaryCorrectionStrategy_->correctBoundaryCondition(domainVector);
74 std::unique_ptr<NeoN::finiteVolume::cellCentred::VolumeBoundaryFactory<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< VolumeBoundaryFactory > clone() const =0
static std::string name()
virtual ~VolumeBoundaryFactory()=default
virtual void correctBoundaryCondition(Field< ValueType > &domainVector)=0
VolumeBoundaryFactory(const UnstructuredMesh &mesh, const Dictionary &, localIdx patchID)
Represents a volume boundary field for a cell-centered finite volume method.
VolumeBoundary(const VolumeBoundary &other)
VolumeBoundary(const UnstructuredMesh &mesh, const Dictionary &dict, localIdx patchID)
virtual void correctBoundaryCondition(Field< ValueType > &domainVector)