31#define TEMPLATE template<template<class> class Field, class Type>
41template<
template<
class>
class Field,
class Type>
45 const FieldField<Field, Type>&
f,
49template<
template<
class>
class Field,
class Type>
50void T(FieldField<Field, Type>& f1,
const FieldField<Field, Type>& f2);
53template<
template<
class>
class Field,
class Type,
direction r>
57 const FieldField<Field, Type>& vf
60template<
template<
class>
class Field,
class Type,
direction r>
61tmp<FieldField<Field, typename powProduct<Type, r>::type>>
68template<
template<
class>
class Field,
class Type,
direction r>
69tmp<FieldField<Field, typename powProduct<Type, r>::type>>
77template<
template<
class>
class Field,
class Type>
81 const FieldField<Field, Type>& vf
84template<
template<
class>
class Field,
class Type>
85tmp<FieldField<Field, typename outerProduct<Type, Type>::type>>
86sqr(
const FieldField<Field, Type>&
f);
88template<
template<
class>
class Field,
class Type>
89tmp<FieldField<Field, typename outerProduct<Type, Type>::type>>
90sqr(
const tmp<FieldField<Field, Type>>& tf);
93template<
template<
class>
class Field,
class Type>
97 const FieldField<Field, Type>&
f
100template<
template<
class>
class Field,
class Type>
101tmp<FieldField<Field, typename typeOfMag<Type>::type>>
102magSqr(
const FieldField<Field, Type>&
f);
104template<
template<
class>
class Field,
class Type>
105tmp<FieldField<Field, typename typeOfMag<Type>::type>>
106magSqr(
const tmp<FieldField<Field, Type>>& tf);
109template<
template<
class>
class Field,
class Type>
113 const FieldField<Field, Type>&
f
116template<
template<
class>
class Field,
class Type>
117tmp<FieldField<Field, typename typeOfMag<Type>::type>>
118mag(
const FieldField<Field, Type>&
f);
120template<
template<
class>
class Field,
class Type>
121tmp<FieldField<Field, typename typeOfMag<Type>::type>>
122mag(
const tmp<FieldField<Field, Type>>& tf);
125template<
template<
class>
class Field,
class Type>
129 const FieldField<Field, Type>&
f
132template<
template<
class>
class Field,
class Type>
133tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptMax
135 const FieldField<Field, Type>&
f
138template<
template<
class>
class Field,
class Type>
139tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptMax
141 const tmp<FieldField<Field, Type>>& tf
145template<
template<
class>
class Field,
class Type>
149 const FieldField<Field, Type>&
f
152template<
template<
class>
class Field,
class Type>
153tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptMin
155 const FieldField<Field, Type>&
f
158template<
template<
class>
class Field,
class Type>
159tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptMin
161 const tmp<FieldField<Field, Type>>& tf
165template<
template<
class>
class Field,
class Type>
169 const FieldField<Field, Type>&
f
172template<
template<
class>
class Field,
class Type>
173tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptAv
175 const FieldField<Field, Type>&
f
178template<
template<
class>
class Field,
class Type>
179tmp<FieldField<Field, typename FieldField<Field, Type>::cmptType>>
cmptAv
181 const tmp<FieldField<Field, Type>>& tf
185template<
template<
class>
class Field,
class Type>
188 FieldField<Field, Type>& cf,
189 const FieldField<Field, Type>&
f
192template<
template<
class>
class Field,
class Type>
193tmp<FieldField<Field, Type>>
cmptMag
195 const FieldField<Field, Type>&
f
198template<
template<
class>
class Field,
class Type>
199tmp<FieldField<Field, Type>>
cmptMag
201 const tmp<FieldField<Field, Type>>& tf
205#define TMP_UNARY_FUNCTION(returnType, func) \
207template<template<class> class Field, class Type> \
208returnType func(const tmp<FieldField<Field, Type>>& tf1);
211template<
template<
class>
class Field,
class Type>
212Type
max(
const FieldField<Field, Type>&
f);
217template<
template<
class>
class Field,
class Type>
218Type
min(
const FieldField<Field, Type>&
f);
223template<
template<
class>
class Field,
class Type>
224Type
sum(
const FieldField<Field, Type>&
f);
229template<
template<
class>
class Field,
class Type>
236template<
template<
class>
class Field,
class Type>
237Type
average(
const FieldField<Field, Type>&
f);
243template<
template<
class>
class Field,
class Type>
244MinMax<Type>
minMax(
const FieldField<Field, Type>&
f);
249template<
template<
class>
class Field,
class Type>
256#define G_UNARY_FUNCTION(ReturnType, gFunc, func, rFunc) \
258template<template<class> class Field, class Type> \
259ReturnType gFunc(const FieldField<Field, Type>& f); \
260TMP_UNARY_FUNCTION(ReturnType, gFunc)
270#undef G_UNARY_FUNCTION
274template<
template<
class>
class Field,
class Type>
277 const FieldField<Field, Type>&
f,
284#undef TMP_UNARY_FUNCTION
322#define PRODUCT_OPERATOR(product, op, opFunc) \
326 template<class> class Field1, \
327 template<class> class Field2, \
333 FieldField<Field1, typename product<Type1, Type2>::type>& f, \
334 const FieldField<Field1, Type1>& f1, \
335 const FieldField<Field2, Type2>& f2 \
340 template<class> class Field1, \
341 template<class> class Field2, \
345tmp<FieldField<Field1, typename product<Type1, Type2>::type>> \
348 const FieldField<Field1, Type1>& f1, \
349 const FieldField<Field2, Type2>& f2 \
352template<template<class> class Field, class Type1, class Type2> \
353tmp<FieldField<Field, typename product<Type1, Type2>::type>> \
356 const FieldField<Field, Type1>& f1, \
357 const tmp<FieldField<Field, Type2>>& tf2 \
362 template<class> class Field1, \
363 template<class> class Field2, \
367tmp<FieldField<Field1, typename product<Type1, Type2>::type>> \
370 const FieldField<Field1, Type1>& f1, \
371 const tmp<FieldField<Field2, Type2>>& tf2 \
376 template<class> class Field1, \
377 template<class> class Field2, \
381tmp<FieldField<Field1, typename product<Type1, Type2>::type>> \
384 const tmp<FieldField<Field1, Type1>>& tf1, \
385 const FieldField<Field2, Type2>& f2 \
390 template<class> class Field1, \
391 template<class> class Field2, \
395tmp<FieldField<Field1, typename product<Type1, Type2>::type>> \
398 const tmp<FieldField<Field1, Type1>>& tf1, \
399 const tmp<FieldField<Field2, Type2>>& tf2 \
404 template<class> class Field, \
412 FieldField<Field, typename product<Type, Form>::type>& f, \
413 const FieldField<Field, Type>& f1, \
414 const VectorSpace<Form,Cmpt,nCmpt>& vs \
419 template<class> class Field, \
425tmp<FieldField<Field, typename product<Type, Form>::type>> \
428 const FieldField<Field, Type>& f1, \
429 const VectorSpace<Form,Cmpt,nCmpt>& vs \
434 template<class> class Field, \
440tmp<FieldField<Field, typename product<Type, Form>::type>> \
443 const tmp<FieldField<Field, Type>>& tf1, \
444 const VectorSpace<Form,Cmpt,nCmpt>& vs \
449 template<class> class Field, \
457 FieldField<Field, typename product<Form, Type>::type>& f, \
458 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
459 const FieldField<Field, Type>& f1 \
464 template<class> class Field, \
470tmp<FieldField<Field, typename product<Form, Type>::type>> \
473 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
474 const FieldField<Field, Type>& f1 \
479 template<class> class Field, \
485tmp<FieldField<Field, typename product<Form, Type>::type>> \
488 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
489 const tmp<FieldField<Field, Type>>& tf1 \
500#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 TERNARY_FUNCTION(ReturnType, Type1, Type2, Type3, Func)
#define TERNARY_TYPE_FUNCTION_FFS(ReturnType, Type1, Type2, Type3, Func)
#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)
Macro functions for FieldField<Type> algebra.
#define G_UNARY_FUNCTION(ReturnType, gFunc, Func, rFunc)
#define TMP_UNARY_FUNCTION(ReturnType, Func)
pTraits< Type >::cmptType cmptType
Component type.
static label worldComm
Communicator for all ranks. May differ from commGlobal() if local worlds are in use.
typeOfRank< typenamepTraits< arg1 >::cmptType, direction(pTraits< arg1 >::rank)+direction(pTraits< arg2 >::rank)>::type type
symmTypeOfRank< typenamepTraits< arg1 >::cmptType, arg2 *direction(pTraits< arg1 >::rank)>::type type
pTraits< typenamepTraits< arg1 >::cmptType >::magType type
#define PRODUCT_OPERATOR(product, op, opFunc)
Type gAverage(const FieldField< Field, Type > &f, const label comm)
The global arithmetic average of a FieldField.
dimensioned< scalarMinMax > minMaxMag(const DimensionedField< Type, GeoMesh > &f1, const label comm)
label max(const labelHashSet &set, label maxValue=labelMin)
Find the max value in labelHashSet, optionally limited by second argument.
Type gSum(const FieldField< Field, Type > &f)
dimensionedSymmTensor sqr(const dimensionedVector &dv)
void subtract(DimensionedField< scalar, GeoMesh > &result, const dimensioned< scalar > &dt1, const DimensionedField< scalar, GeoMesh > &f2)
void component(FieldField< Field, typename FieldField< Field, Type >::cmptType > &sf, const FieldField< Field, Type > &f, const direction d)
void cmptMin(FieldField< Field, typename FieldField< Field, Type >::cmptType > &cf, const FieldField< Field, Type > &f)
dimensioned< Type > cmptDivide(const dimensioned< Type > &, const dimensioned< Type > &)
dimensionSet clamp(const dimensionSet &a, const dimensionSet &range)
void divide(DimensionedField< Type, GeoMesh > &result, const DimensionedField< Type, GeoMesh > &f1, const DimensionedField< scalar, GeoMesh > &f2)
MinMax< scalar > scalarMinMax
A scalar min/max range.
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.
tmp< DimensionedField< typename DimensionedField< Type, GeoMesh >::cmptType, GeoMesh > > cmptAv(const DimensionedField< Type, GeoMesh > &f1)
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)
label min(const labelHashSet &set, label minValue=labelMax)
Find the min value in labelHashSet, optionally limited by second argument.
void cmptMax(FieldField< Field, typename FieldField< Field, Type >::cmptType > &cf, const FieldField< Field, Type > &f)
MinMax< Type > gMinMax(const FieldField< Field, Type > &f)
dimensioned< Type > sum(const DimensionedField< Type, GeoMesh > &f1, const label comm)
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 cmptMag(FieldField< Field, Type > &cf, 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)
void negate(DimensionedField< Type, GeoMesh > &result, const DimensionedField< Type, GeoMesh > &f1)
void multiply(DimensionedField< Type, GeoMesh > &result, const DimensionedField< Type, GeoMesh > &f1, const DimensionedField< scalar, GeoMesh > &f2)
dimensioned< Type > average(const DimensionedField< Type, GeoMesh > &f1, const label comm)
Type gMax(const FieldField< Field, Type > &f)
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)
dimensioned< Type > lerp(const dimensioned< Type > &a, const dimensioned< Type > &b, const scalar t)
dimensioned< typename typeOfMag< Type >::type > sumMag(const DimensionedField< Type, GeoMesh > &f1, const label comm)
Specialisation of FieldField<T> for scalar.
dict add("bounds", meshBb)