35 #ifndef surfaceInterpolationScheme_H 36 #define surfaceInterpolationScheme_H 78 TypeName(
"surfaceInterpolationScheme");
105 (mesh, faceFlux, schemeData)
161 template<
class SFType>
234 typename innerProduct<vector, Type>::type,
285 #define makeSurfaceInterpolationTypeScheme(SS, Type) \ 287 defineNamedTemplateTypeNameAndDebug(SS<Type>, 0); \ 289 surfaceInterpolationScheme<Type>::addMeshConstructorToTable<SS<Type>> \ 290 add##SS##Type##MeshConstructorToTable_; \ 292 surfaceInterpolationScheme<Type>::addMeshFluxConstructorToTable<SS<Type>> \ 293 add##SS##Type##MeshFluxConstructorToTable_; 295 #define makeSurfaceInterpolationScheme(SS) \ 297 makeSurfaceInterpolationTypeScheme(SS, scalar) \ 298 makeSurfaceInterpolationTypeScheme(SS, vector) \ 299 makeSurfaceInterpolationTypeScheme(SS, sphericalTensor) \ 300 makeSurfaceInterpolationTypeScheme(SS, symmTensor) \ 301 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.
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.
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.
virtual ~surfaceInterpolationScheme()
Destructor.
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.