31#define TEMPLATE template<class Type, class GeoMesh>
41template<
class Type,
class GeoMesh, direction r>
42tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh>>
45 const DimensionedField<Type, GeoMesh>& df,
49template<
class Type,
class GeoMesh, direction r>
50tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh>>
53 const tmp<DimensionedField<Type, GeoMesh>>& tdf,
57template<
class Type,
class GeoMesh>
58tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
59sqr(
const DimensionedField<Type, GeoMesh>& df);
61template<
class Type,
class GeoMesh>
62tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
63sqr(
const tmp<DimensionedField<Type, GeoMesh>>& tdf);
65template<
class Type,
class GeoMesh>
66tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
67magSqr(
const DimensionedField<Type, GeoMesh>& df);
69template<
class Type,
class GeoMesh>
70tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
71magSqr(
const tmp<DimensionedField<Type, GeoMesh>>& tdf);
73template<
class Type,
class GeoMesh>
74tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
75mag(
const DimensionedField<Type, GeoMesh>& df);
77template<
class Type,
class GeoMesh>
78tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
79mag(
const tmp<DimensionedField<Type, GeoMesh>>& tdf);
81template<
class Type,
class GeoMesh>
90cmptAv(
const DimensionedField<Type, GeoMesh>& df);
92template<
class Type,
class GeoMesh>
101cmptAv(
const tmp<DimensionedField<Type, GeoMesh>>& tdf);
105#define UNARY_REDUCTION_FUNCTION(returnType, func, dfunc) \
107template<class Type, class GeoMesh> \
108dimensioned<returnType> func \
110 const DimensionedField<Type, GeoMesh>& df \
112template<class Type, class GeoMesh> \
113dimensioned<returnType> func \
115 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
127#undef UNARY_REDUCTION_FUNCTION
159#define PRODUCT_OPERATOR(product, op, opFunc) \
161template<class Type1, class Type2, class GeoMesh> \
162tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
165 const DimensionedField<Type1, GeoMesh>& df1, \
166 const DimensionedField<Type2, GeoMesh>& df2 \
169template<class Type1, class Type2, class GeoMesh> \
170tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
173 const DimensionedField<Type1, GeoMesh>& df1, \
174 const tmp<DimensionedField<Type2, GeoMesh>>& tdf2 \
177template<class Type1, class Type2, class GeoMesh> \
178tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
181 const tmp<DimensionedField<Type1, GeoMesh>>& tdf1, \
182 const DimensionedField<Type2, GeoMesh>& df2 \
185template<class Type1, class Type2, class GeoMesh> \
186tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
189 const tmp<DimensionedField<Type1, GeoMesh>>& tdf1, \
190 const tmp<DimensionedField<Type2, GeoMesh>>& tdf2 \
193template<class Form, class Type, class GeoMesh> \
194tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
197 const DimensionedField<Type, GeoMesh>& df1, \
198 const dimensioned<Form>& dvs \
201template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
202tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
205 const DimensionedField<Type, GeoMesh>& df1, \
206 const VectorSpace<Form,Cmpt,nCmpt>& vs \
209template<class Form, class Type, class GeoMesh> \
210tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
213 const tmp<DimensionedField<Type, GeoMesh>>& tdf1, \
214 const dimensioned<Form>& dvs \
217template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
218tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
221 const tmp<DimensionedField<Type, GeoMesh>>& tdf1, \
222 const VectorSpace<Form,Cmpt,nCmpt>& vs \
225template<class Form, class Type, class GeoMesh> \
226tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
229 const dimensioned<Form>& dvs, \
230 const DimensionedField<Type, GeoMesh>& df1 \
233template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
234tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
237 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
238 const DimensionedField<Type, GeoMesh>& df1 \
241template<class Form, class Type, class GeoMesh> \
242tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
245 const dimensioned<Form>& dvs, \
246 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
249template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
250tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
253 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
254 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
265#undef PRODUCT_OPERATOR
#define BINARY_FUNCTION(ReturnType, Type1, Type2, Func)
#define BINARY_TYPE_FUNCTION_FS(ReturnType, Type1, Type2, Func)
#define UNARY_OPERATOR(ReturnType, Type1, Op, OpFunc, Dfunc)
#define BINARY_OPERATOR(ReturnType, Type1, Type2, Op, OpName, OpFunc)
#define BINARY_TYPE_OPERATOR_SF(ReturnType, Type1, Type2, Op, OpName, OpFunc)
#define BINARY_TYPE_OPERATOR_FS(ReturnType, Type1, Type2, Op, OpName, OpFunc)
#define BINARY_TYPE_FUNCTION(ReturnType, Type1, Type2, Func)
#define UNARY_REDUCTION_FUNCTION(returnType, func, dfunc)
Scalar specific part of the implementation of DimensionedField.
Field< Type >::cmptType cmptType
Component type of the elements of the field.
A min/max value pair with additional methods. In addition to conveniently storing values,...
symmTypeOfRank< typenamepTraits< arg1 >::cmptType, arg2 *direction(pTraits< arg1 >::rank)>::type type
pTraits< typenamepTraits< arg1 >::cmptType >::magType type
#define PRODUCT_OPERATOR(product, op, opFunc)
label max(const labelHashSet &set, label maxValue=labelMin)
Find the max value in labelHashSet, optionally limited by second argument.
dimensionSet clip(const dimensionSet &ds1, const dimensionSet &ds2)
Type gSum(const FieldField< Field, Type > &f)
dimensionSet transform(const dimensionSet &ds)
Return the argument; transformations do not change the dimensions.
dimensionedSymmTensor sqr(const dimensionedVector &dv)
dimensioned< Type > sum(const DimensionedField< Type, GeoMesh > &df)
void subtract(FieldField< Field1, typename typeOfSum< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)
dimensioned< Type > cmptDivide(const dimensioned< Type > &, const dimensioned< Type > &)
MinMax< scalar > scalarMinMax
A scalar min/max range.
dimensioned< Type > average(const DimensionedField< Type, GeoMesh > &df)
void dot(FieldField< Field1, typename innerProduct< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)
scalarMinMax gMinMaxMag(const FieldField< Field, Type > &f)
dimensionedScalar pow(const dimensionedScalar &ds, const dimensionedScalar &expt)
MinMax< label > minMax(const labelHashSet &set)
Find the min/max values of labelHashSet.
dimensioned< typename typeOfMag< Type >::type > sumMag(const DimensionedField< Type, GeoMesh > &df)
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)
void add(FieldField< Field1, typename typeOfSum< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)
label min(const labelHashSet &set, label minValue=labelMax)
Find the min value in labelHashSet, optionally limited by second argument.
void negate(FieldField< Field, Type > &res, const FieldField< Field, Type > &f)
void multiply(FieldField< Field, Type > &f, const FieldField< Field, Type > &f1, const FieldField< Field, scalar > &f2)
Type gAverage(const FieldField< Field, Type > &f)
MinMax< Type > gMinMax(const FieldField< Field, Type > &f)
dimensioned< Type > cmptMultiply(const dimensioned< Type > &, const dimensioned< Type > &)
typeOfMag< Type >::type gSumMag(const FieldField< Field, Type > &f)
void dotdot(FieldField< Field1, typename scalarProduct< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)
Type gMin(const FieldField< Field, Type > &f)
void cross(FieldField< Field1, typename crossProduct< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)
tmp< DimensionedField< typename DimensionedField< Type, GeoMesh >::cmptType, GeoMesh > > cmptAv(const DimensionedField< Type, GeoMesh > &df)
dimensioned< scalarMinMax > minMaxMag(const DimensionedField< Type, GeoMesh > &df)
Type gMax(const FieldField< Field, Type > &f)
void divide(FieldField< Field, Type > &f, const FieldField< Field, Type > &f1, const FieldField< Field, scalar > &f2)
dimensioned< typename typeOfMag< Type >::type > magSqr(const dimensioned< Type > &dt)
void outer(FieldField< Field1, typename outerProduct< Type1, Type2 >::type > &f, const FieldField< Field1, Type1 > &f1, const FieldField< Field2, Type2 > &f2)