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 #ifndef FieldField_H
00036 #define FieldField_H
00037
00038 #include <OpenFOAM/tmp.H>
00039 #include <OpenFOAM/PtrList.H>
00040 #include <OpenFOAM/scalar.H>
00041 #include <OpenFOAM/direction.H>
00042 #include <OpenFOAM/VectorSpace.H>
00043
00044
00045
00046 namespace Foam
00047 {
00048
00049
00050
00051 template<template<class> class Field, class Type>
00052 class FieldField;
00053
00054 template<template<class> class Field, class Type>
00055 Ostream& operator<<
00056 (
00057 Ostream&,
00058 const FieldField<Field, Type>&
00059 );
00060
00061 template<template<class> class Field, class Type>
00062 Ostream& operator<<
00063 (
00064 Ostream&,
00065 const tmp<FieldField<Field, Type> >&
00066 );
00067
00068
00069
00070
00071
00072
00073 template<template<class> class Field, class Type>
00074 class FieldField
00075 :
00076 public refCount,
00077 public PtrList<Field<Type> >
00078 {
00079
00080 public:
00081
00082
00083 typedef typename pTraits<Type>::cmptType cmptType;
00084
00085
00086
00087
00088
00089
00090 FieldField();
00091
00092
00093
00094 explicit FieldField(const label);
00095
00096
00097
00098
00099 FieldField(const word&, const FieldField<Field, Type>&);
00100
00101
00102 FieldField(const FieldField<Field, Type>&);
00103
00104
00105 FieldField(FieldField<Field, Type>&, bool reUse);
00106
00107
00108 FieldField(const PtrList<Field<Type> >&);
00109
00110
00111 # ifdef ConstructFromTmp
00112 FieldField(const tmp<FieldField<Field, Type> >&);
00113 # endif
00114
00115
00116 FieldField(Istream&);
00117
00118
00119 tmp<FieldField<Field, Type> > clone() const;
00120
00121
00122
00123 template<class Type2>
00124 static tmp<FieldField<Field, Type> > NewCalculatedType
00125 (
00126 const FieldField<Field, Type2>& ff
00127 )
00128 # ifdef __INTEL_COMPILER
00129 {
00130 FieldField<Field, Type>* nffPtr
00131 (
00132 new FieldField<Field, Type>(ff.size())
00133 );
00134
00135 forAll(*nffPtr, i)
00136 {
00137 nffPtr->set(i, Field<Type>::NewCalculatedType(ff[i]).ptr());
00138 }
00139
00140 return tmp<FieldField<Field, Type> >(nffPtr);
00141 }
00142 # else
00143 ;
00144 # endif
00145
00146
00147
00148
00149 void negate();
00150
00151
00152 tmp<FieldField<Field, cmptType> > component(const direction) const;
00153
00154
00155 void replace(const direction, const FieldField<Field, cmptType>&);
00156
00157
00158 void replace(const direction, const cmptType&);
00159
00160
00161 tmp<FieldField<Field, Type> > T() const;
00162
00163
00164
00165
00166 void operator=(const FieldField<Field, Type>&);
00167 void operator=(const tmp<FieldField<Field, Type> >&);
00168 void operator=(const Type&);
00169
00170 void operator+=(const FieldField<Field, Type>&);
00171 void operator+=(const tmp<FieldField<Field, Type> >&);
00172
00173 void operator-=(const FieldField<Field, Type>&);
00174 void operator-=(const tmp<FieldField<Field, Type> >&);
00175
00176 void operator*=(const FieldField<Field, scalar>&);
00177 void operator*=(const tmp<FieldField<Field, scalar> >&);
00178
00179 void operator/=(const FieldField<Field, scalar>&);
00180 void operator/=(const tmp<FieldField<Field, scalar> >&);
00181
00182 void operator+=(const Type&);
00183 void operator-=(const Type&);
00184
00185 void operator*=(const scalar&);
00186 void operator/=(const scalar&);
00187
00188
00189
00190
00191 friend Ostream& operator<< <Field, Type>
00192 (
00193 Ostream&,
00194 const FieldField<Field, Type>&
00195 );
00196
00197 friend Ostream& operator<< <Field, Type>
00198 (
00199 Ostream&,
00200 const tmp<FieldField<Field, Type> >&
00201 );
00202 };
00203
00204
00205
00206
00207 }
00208
00209
00210
00211 #include <OpenFOAM/FieldFieldFunctions.H>
00212
00213 #ifdef NoRepository
00214 # include <OpenFOAM/FieldField.C>
00215 #endif
00216
00217
00218
00219 #endif
00220
00221