00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 #ifndef snGradScheme_H
00037 #define snGradScheme_H
00038
00039 #include "tmp.H"
00040 #include "volFieldsFwd.H"
00041 #include "surfaceFieldsFwd.H"
00042 #include "typeInfo.H"
00043 #include "runTimeSelectionTables.H"
00044
00045
00046
00047 namespace Foam
00048 {
00049
00050 class fvMesh;
00051
00052
00053
00054 namespace fv
00055 {
00056
00057
00058
00059
00060
00061 template<class Type>
00062 class snGradScheme
00063 :
00064 public refCount
00065 {
00066
00067
00068
00069 const fvMesh& mesh_;
00070
00071
00072
00073
00074
00075 void operator=(const snGradScheme&);
00076
00077
00078 public:
00079
00080
00081 virtual const word& type() const = 0;
00082
00083
00084
00085
00086 declareRunTimeSelectionTable
00087 (
00088 tmp,
00089 snGradScheme,
00090 Mesh,
00091 (const fvMesh& mesh, Istream& schemeData),
00092 (mesh, schemeData)
00093 );
00094
00095
00096
00097
00098
00099 snGradScheme(const fvMesh& mesh)
00100 :
00101 mesh_(mesh)
00102 {}
00103
00104
00105
00106
00107
00108 static tmp<snGradScheme<Type> > New
00109 (
00110 const fvMesh& mesh,
00111 Istream& schemeData
00112 );
00113
00114
00115
00116
00117 virtual ~snGradScheme();
00118
00119
00120
00121
00122
00123 const fvMesh& mesh() const
00124 {
00125 return mesh_;
00126 }
00127
00128
00129
00130
00131 static tmp<GeometricField<Type, fvPatchField, surfaceMesh> >
00132 snGrad
00133 (
00134 const GeometricField<Type, fvPatchField, volMesh>&,
00135 const tmp<surfaceScalarField>&
00136 );
00137
00138
00139 virtual tmp<surfaceScalarField> deltaCoeffs
00140 (
00141 const GeometricField<Type, fvPatchField, volMesh>&
00142 ) const = 0;
00143
00144
00145 virtual bool corrected() const
00146 {
00147 return false;
00148 }
00149
00150
00151
00152 virtual tmp<GeometricField<Type, fvPatchField, surfaceMesh> >
00153 correction(const GeometricField<Type, fvPatchField, volMesh>&) const
00154 {
00155 return tmp<GeometricField<Type, fvPatchField, surfaceMesh> >(NULL);
00156 }
00157
00158
00159
00160 virtual tmp<GeometricField<Type, fvPatchField, surfaceMesh> >
00161 snGrad(const GeometricField<Type, fvPatchField, volMesh>&) const;
00162
00163
00164
00165 tmp<GeometricField<Type, fvPatchField, surfaceMesh> >
00166 snGrad
00167 (
00168 const tmp<GeometricField<Type, fvPatchField, volMesh> >&
00169 ) const;
00170 };
00171
00172
00173
00174
00175 }
00176
00177
00178
00179 }
00180
00181
00182
00183
00184
00185 #define makeSnGradTypeScheme(SS, Type) \
00186 \
00187 defineNamedTemplateTypeNameAndDebug(SS<Type>, 0); \
00188 \
00189 snGradScheme<Type>::addMeshConstructorToTable<SS<Type> > \
00190 add##SS##Type##MeshConstructorToTable_;
00191
00192 #define makeSnGradScheme(SS) \
00193 \
00194 makeSnGradTypeScheme(SS, scalar) \
00195 makeSnGradTypeScheme(SS, vector) \
00196 makeSnGradTypeScheme(SS, tensor) \
00197 makeSnGradTypeScheme(SS, sphericalTensor)
00198
00199
00200
00201
00202 #ifdef NoRepository
00203 # include "snGradScheme.C"
00204 #endif
00205
00206
00207
00208 #endif
00209
00210