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 lnGradScheme_H
00037 #define lnGradScheme_H
00038
00039 #include "tmp.H"
00040 #include "areaFieldsFwd.H"
00041 #include "edgeFieldsFwd.H"
00042 #include "typeInfo.H"
00043 #include "runTimeSelectionTables.H"
00044
00045
00046
00047 namespace Foam
00048 {
00049
00050 class faMesh;
00051
00052
00053
00054 namespace fa
00055 {
00056
00057
00058
00059
00060
00061 template<class Type>
00062 class lnGradScheme
00063 :
00064 public refCount
00065 {
00066
00067
00068
00069 const faMesh& mesh_;
00070
00071
00072
00073
00074
00075 void operator=(const lnGradScheme&);
00076
00077
00078 public:
00079
00080
00081
00082 declareRunTimeSelectionTable
00083 (
00084 tmp,
00085 lnGradScheme,
00086 Mesh,
00087 (const faMesh& mesh, Istream& schemeData),
00088 (mesh, schemeData)
00089 );
00090
00091
00092
00093
00094
00095 lnGradScheme(const faMesh& mesh)
00096 :
00097 mesh_(mesh)
00098 {}
00099
00100
00101
00102
00103
00104 static tmp<lnGradScheme<Type> > New
00105 (
00106 const faMesh& mesh,
00107 Istream& schemeData
00108 );
00109
00110
00111
00112
00113 virtual ~lnGradScheme();
00114
00115
00116
00117
00118
00119 const faMesh& mesh() const
00120 {
00121 return mesh_;
00122 }
00123
00124
00125
00126
00127 static tmp<GeometricField<Type, faPatchField, edgeMesh> >
00128 lnGrad
00129 (
00130 const GeometricField<Type, faPatchField, areaMesh>&,
00131 const tmp<edgeScalarField>&,
00132 const tmp<edgeScalarField>&
00133 );
00134
00135
00136
00137 static tmp<GeometricField<Type, faPatchField, edgeMesh> >
00138 lnGrad
00139 (
00140 const GeometricField<Type, faPatchField, areaMesh>&,
00141 const tmp<edgeScalarField>&
00142 );
00143
00144
00145
00146 virtual tmp<edgeScalarField> deltaCoeffs
00147 (
00148 const GeometricField<Type, faPatchField, areaMesh>&
00149 ) const = 0;
00150
00151
00152 virtual bool corrected() const
00153 {
00154 return false;
00155 }
00156
00157
00158
00159 virtual tmp<GeometricField<Type, faPatchField, edgeMesh> >
00160 correction(const GeometricField<Type, faPatchField, areaMesh>&) const
00161 {
00162 return tmp<GeometricField<Type, faPatchField, edgeMesh> >(NULL);
00163 }
00164
00165
00166
00167 virtual tmp<GeometricField<Type, faPatchField, edgeMesh> >
00168 lnGrad(const GeometricField<Type, faPatchField, areaMesh>&) const;
00169
00170
00171
00172 tmp<GeometricField<Type, faPatchField, edgeMesh> >
00173 lnGrad
00174 (
00175 const tmp<GeometricField<Type, faPatchField, areaMesh> >&
00176 ) const;
00177 };
00178
00179
00180
00181
00182 }
00183
00184
00185
00186 }
00187
00188
00189
00190
00191
00192 #define makeLnGradTypeScheme(SS, Type) \
00193 \
00194 defineNamedTemplateTypeNameAndDebug(SS<Type>, 0); \
00195 \
00196 lnGradScheme<Type>::addMeshConstructorToTable<SS<Type> > \
00197 add##SS##Type##MeshConstructorToTable_;
00198
00199 #define makeLnGradScheme(SS) \
00200 \
00201 makeLnGradTypeScheme(SS, scalar) \
00202 makeLnGradTypeScheme(SS, vector) \
00203 makeLnGradTypeScheme(SS, tensor)
00204
00205
00206
00207
00208 #ifdef NoRepository
00209 # include "lnGradScheme.C"
00210 #endif
00211
00212
00213
00214 #endif
00215
00216