8#include <Kokkos_Core.hpp>
21template<
typename ValueType>
24 FaceNormalGradientFactory<ValueType>,
25 Parameters<const Executor&, const UnstructuredMesh&, const Input&>>
30 static std::unique_ptr<FaceNormalGradientFactory>
35 (std::holds_alternative<NeoFOAM::Dictionary>(inputs))
36 ? std::get<NeoFOAM::Dictionary>(inputs).get<std::string>(
"faceNormalGradient")
37 : std::get<NeoFOAM::TokenList>(inputs).next<std::string>();
43 static std::string
name() {
return "FaceNormalGradientFactory"; }
57 virtual std::unique_ptr<FaceNormalGradientFactory<ValueType>>
clone()
const = 0;
65template<
typename ValueType>
72 : exec_(faceNGrad.exec_), mesh_(faceNGrad.mesh_),
73 faceNormalGradKernel_(faceNGrad.faceNormalGradKernel_->clone()) {};
76 : exec_(faceNGrad.exec_), mesh_(faceNGrad.mesh_),
77 faceNormalGradKernel_(std::move(faceNGrad.faceNormalGradKernel_)) {};
84 : exec_(exec), mesh_(mesh), faceNormalGradKernel_(std::move(faceNormalGradient)) {};
87 : exec_(exec), mesh_(mesh),
95 faceNormalGradKernel_->faceNormalGrad(volField, surfaceField);
103 std::string nameInterpolated =
"interpolated_" + volField.
name;
115 std::unique_ptr<FaceNormalGradientFactory<ValueType>> faceNormalGradKernel_;
A factory class for runtime selection of derived classes.
Represents an unstructured mesh in NeoFOAM.
virtual std::unique_ptr< FaceNormalGradientFactory< ValueType > > clone() const =0
static std::unique_ptr< FaceNormalGradientFactory > create(const Executor &exec, const UnstructuredMesh &uMesh, const Input &inputs)
virtual ~FaceNormalGradientFactory()
virtual void faceNormalGrad(const VolumeField< ValueType > &volField, SurfaceField< ValueType > &surfaceField) const =0
virtual const SurfaceField< scalar > & deltaCoeffs() const =0
static std::string name()
const UnstructuredMesh & mesh_
FaceNormalGradientFactory(const Executor &exec, const UnstructuredMesh &mesh)
const SurfaceField< scalar > & deltaCoeffs() const
FaceNormalGradient(const Executor &exec, const UnstructuredMesh &mesh, std::unique_ptr< FaceNormalGradientFactory< ValueType > > faceNormalGradient)
FaceNormalGradient(const Executor &exec, const UnstructuredMesh &mesh, const Input &input)
SurfaceField< ValueType > faceNormalGrad(const VolumeField< ValueType > &volField) const
FaceNormalGradient(FaceNormalGradient &&faceNGrad)
void faceNormalGrad(const VolumeField< ValueType > &volField, SurfaceField< ValueType > &surfaceField) const
FaceNormalGradient(const FaceNormalGradient &faceNGrad)
Represents a surface boundary field for a cell-centered finite volume method.
Represents a surface field in a finite volume method.
Represents a volume field in a finite volume method.
std::vector< BoundaryType > createCalculatedBCs(const UnstructuredMesh &mesh)
std::variant< Dictionary, TokenList > Input
std::variant< SerialExecutor, CPUExecutor, GPUExecutor > Executor