9#include <Kokkos_Core.hpp>
25template<
typename ValueType>
28 SurfaceInterpolationFactory<ValueType>,
29 Parameters<const Executor&, const UnstructuredMesh&, const Input&>>
35 static std::unique_ptr<SurfaceInterpolationFactory<ValueType>>
40 (std::holds_alternative<NeoN::Dictionary>(inputs))
41 ? std::get<NeoN::Dictionary>(inputs).get<std::string>(
"surfaceInterpolation")
42 : std::get<NeoN::TokenList>(inputs).next<std::string>();
48 static std::string
name() {
return "SurfaceInterpolationFactory"; }
73 virtual std::unique_ptr<SurfaceInterpolationFactory<ValueType>>
clone()
const = 0;
81template<
typename ValueType>
85 using VectorValueType = ValueType;
90 : exec_(surfInterp.exec_), mesh_(surfInterp.mesh_),
91 interpolationKernel_(surfInterp.interpolationKernel_->clone()) {};
94 : exec_(surfInterp.exec_), mesh_(surfInterp.mesh_),
95 interpolationKernel_(std::move(surfInterp.interpolationKernel_)) {};
102 : exec_(exec), mesh_(mesh), interpolationKernel_(std::move(interpolationKernel)) {};
105 : exec_(exec), mesh_(mesh),
112 interpolationKernel_->interpolate(src, dst);
121 interpolationKernel_->interpolate(flux, src, dst);
126 interpolationKernel_->weight(src,
weight);
135 interpolationKernel_->weight(flux, src,
weight);
141 std::string nameInterpolated =
"interpolated_" + src.
name;
152 std::string
name =
"interpolated_" + src.
name;
162 std::string
name =
"weight_" + src.
name;
166 weight(src, weightVector);
173 std::string
name =
"weight_" + src.
name;
177 weight(flux, src, weightVector);
185 std::unique_ptr<SurfaceInterpolationFactory<ValueType>> interpolationKernel_;
A factory class for runtime selection of derived classes.
Represents an unstructured mesh in NeoN.
Represents a surface boundary field for a cell-centered finite volume method.
virtual void interpolate(const VolumeField< ValueType > &src, SurfaceField< ValueType > &dst) const =0
static std::string name()
const UnstructuredMesh & mesh_
virtual void interpolate(const SurfaceField< scalar > &flux, const VolumeField< ValueType > &src, SurfaceField< ValueType > &dst) const =0
virtual void weight(const VolumeField< ValueType > &src, SurfaceField< scalar > &weight) const =0
SurfaceInterpolationFactory(const Executor &exec, const UnstructuredMesh &mesh)
static std::unique_ptr< SurfaceInterpolationFactory< ValueType > > create(const Executor &exec, const UnstructuredMesh &uMesh, const Input &inputs)
virtual ~SurfaceInterpolationFactory()
virtual void weight(const SurfaceField< scalar > &flux, const VolumeField< ValueType > &src, SurfaceField< scalar > &weight) const =0
virtual std::unique_ptr< SurfaceInterpolationFactory< ValueType > > clone() const =0
SurfaceField< scalar > weight(const VolumeField< ValueType > &src) const
SurfaceField< scalar > weight(const SurfaceField< scalar > &flux, const VolumeField< ValueType > &src) const
void interpolate(const VolumeField< ValueType > &src, SurfaceField< ValueType > &dst) const
SurfaceInterpolation(const Executor &exec, const UnstructuredMesh &mesh, const Input &input)
void weight(const VolumeField< ValueType > &src, SurfaceField< scalar > &weight) const
SurfaceInterpolation(const Executor &exec, const UnstructuredMesh &mesh, std::unique_ptr< SurfaceInterpolationFactory< ValueType > > interpolationKernel)
SurfaceInterpolation(SurfaceInterpolation &&surfInterp)
SurfaceInterpolation(const SurfaceInterpolation &surfInterp)
void weight(const SurfaceField< scalar > &flux, const VolumeField< ValueType > &src, SurfaceField< scalar > &weight) const
SurfaceField< ValueType > interpolate(const SurfaceField< ValueType > &flux, const VolumeField< ValueType > &src) const
void interpolate(const SurfaceField< scalar > &flux, const VolumeField< ValueType > &src, SurfaceField< ValueType > &dst) const
SurfaceField< ValueType > interpolate(const VolumeField< ValueType > &src) const
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
const std::string & name(const NeoN::Document &doc)
Retrieves the name of a Document.