37 #ifndef surfaceInterpolationScheme_H 38 #define surfaceInterpolationScheme_H 80 TypeName(
"surfaceInterpolationScheme");
107 (
mesh, faceFlux, schemeData)
163 template<
class SFType>
284 #define makeSurfaceInterpolationTypeScheme(SS, Type) \ 286 defineNamedTemplateTypeNameAndDebug(SS<Type>, 0); \ 288 surfaceInterpolationScheme<Type>::addMeshConstructorToTable<SS<Type>> \ 289 add##SS##Type##MeshConstructorToTable_; \ 291 surfaceInterpolationScheme<Type>::addMeshFluxConstructorToTable<SS<Type>> \ 292 add##SS##Type##MeshFluxConstructorToTable_; 294 #define makeSurfaceInterpolationScheme(SS) \ 296 makeSurfaceInterpolationTypeScheme(SS, scalar) \ 297 makeSurfaceInterpolationTypeScheme(SS, vector) \ 298 makeSurfaceInterpolationTypeScheme(SS, sphericalTensor) \ 299 makeSurfaceInterpolationTypeScheme(SS, symmTensor) \ 300 makeSurfaceInterpolationTypeScheme(SS, tensor)
virtual bool corrected() const
Return true if this scheme uses an explicit correction.
declareRunTimeSelectionTable(tmp, surfaceInterpolationScheme, Mesh,(const fvMesh &mesh, Istream &schemeData),(mesh, schemeData))
Mesh data needed to do the Finite Volume discretisation.
Reference counter for various OpenFOAM components.
Forwards and collection of common volume field types.
An Istream is an abstract base class for all input systems (streams, files, token lists etc)...
const fvMesh & mesh() const
Return mesh reference.
static tmp< surfaceInterpolationScheme< Type > > New(const fvMesh &mesh, Istream &schemeData)
Return new tmp interpolation scheme.
virtual ~surfaceInterpolationScheme()=default
Destructor.
static tmp< GeometricField< typename innerProduct< typename SFType::value_type, Type >::type, fvsPatchField, surfaceMesh > > dotInterpolate(const SFType &Sf, const GeometricField< Type, fvPatchField, volMesh > &vf, const tmp< surfaceScalarField > &tlambdas)
Return the face-interpolate of the given cell field.
static tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > interpolate(const GeometricField< Type, fvPatchField, volMesh > &, const tmp< surfaceScalarField > &, const tmp< surfaceScalarField > &)
Return the face-interpolate of the given cell field.
Mesh data needed to do the Finite Volume discretisation.
virtual tmp< surfaceScalarField > weights(const GeometricField< Type, fvPatchField, volMesh > &) const =0
Return the interpolation weighting factors for the given field.
Macros to ease declaration of run-time selection tables.
A class for managing temporary objects.
TypeName("surfaceInterpolationScheme")
Runtime type information.
typeOfRank< typename pTraits< arg1 >::cmptType, direction(pTraits< arg1 >::rank)+direction(pTraits< arg2 >::rank) - 2 >::type type
Abstract base class for surface interpolation schemes.
An abstract base class with a fat-interface to all derived classes covering all possible ways in whic...
virtual tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > correction(const GeometricField< Type, fvPatchField, volMesh > &) const
Return the explicit correction to the face-interpolate.