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 multivariateUpwind_H
00037 #define multivariateUpwind_H
00038
00039 #include "multivariateSurfaceInterpolationScheme.H"
00040 #include "surfaceFields.H"
00041
00042
00043
00044 namespace Foam
00045 {
00046
00047
00048
00049
00050
00051 template<class Type>
00052 class multivariateUpwind
00053 :
00054 public multivariateSurfaceInterpolationScheme<Type>
00055 {
00056
00057
00058 const surfaceScalarField& faceFlux_;
00059
00060
00061
00062
00063
00064 multivariateUpwind(const multivariateUpwind&);
00065
00066
00067 void operator=(const multivariateUpwind&);
00068
00069
00070 public:
00071
00072
00073 TypeName("upwind");
00074
00075
00076
00077
00078
00079 multivariateUpwind
00080 (
00081 const fvMesh& mesh,
00082 const typename multivariateSurfaceInterpolationScheme<Type>::
00083 fieldTable& fields,
00084 const surfaceScalarField& faceFlux,
00085 Istream& schemeData
00086 )
00087 :
00088 multivariateSurfaceInterpolationScheme<Type>
00089 (
00090 mesh,
00091 fields,
00092 faceFlux,
00093 schemeData
00094 ),
00095 faceFlux_(faceFlux)
00096 {}
00097
00098
00099
00100
00101
00102
00103 class fieldScheme
00104 :
00105 public multivariateSurfaceInterpolationScheme<Type>::fieldScheme
00106 {
00107
00108
00109 const surfaceScalarField& faceFlux_;
00110
00111 public:
00112
00113
00114
00115 fieldScheme
00116 (
00117 const GeometricField<Type, fvPatchField, volMesh>& field,
00118 const surfaceScalarField& faceFlux
00119 )
00120 :
00121 multivariateSurfaceInterpolationScheme<Type>::
00122 fieldScheme(field),
00123 faceFlux_(faceFlux)
00124 {}
00125
00126
00127
00128
00129
00130 tmp<surfaceScalarField> weights
00131 (
00132 const GeometricField<Type, fvPatchField, volMesh>&
00133 ) const
00134 {
00135 return pos(faceFlux_);
00136 }
00137 };
00138
00139 tmp<surfaceInterpolationScheme<Type> > operator()
00140 (
00141 const GeometricField<Type, fvPatchField, volMesh>& field
00142 ) const
00143 {
00144 return tmp<surfaceInterpolationScheme<Type> >
00145 (
00146 new fieldScheme(field, faceFlux_)
00147 );
00148 }
00149 };
00150
00151
00152
00153
00154 }
00155
00156
00157
00158 #endif
00159
00160