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>& f1,
49template<
class Type,
class GeoMesh, direction r>
50tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh>>
53 const tmp<DimensionedField<Type, GeoMesh>>& tf1,
57template<
class Type,
class GeoMesh>
58tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
59sqr(
const DimensionedField<Type, GeoMesh>& f1);
61template<
class Type,
class GeoMesh>
62tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
63sqr(
const tmp<DimensionedField<Type, GeoMesh>>& tf1);
65template<
class Type,
class GeoMesh>
66tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
67magSqr(
const DimensionedField<Type, GeoMesh>& f1);
69template<
class Type,
class GeoMesh>
70tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
71magSqr(
const tmp<DimensionedField<Type, GeoMesh>>& tf1);
73template<
class Type,
class GeoMesh>
74tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
75mag(
const DimensionedField<Type, GeoMesh>& f1);
77template<
class Type,
class GeoMesh>
78tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
79mag(
const tmp<DimensionedField<Type, GeoMesh>>& tf1);
81template<
class Type,
class GeoMesh>
90cmptAv(
const DimensionedField<Type, GeoMesh>& f1);
92template<
class Type,
class GeoMesh>
101cmptAv(
const tmp<DimensionedField<Type, GeoMesh>>& tf1);
105#define UNARY_REDUCTION_FUNCTION(ReturnType, Func, gFunc) \
107template<class Type, class GeoMesh> \
108dimensioned<ReturnType> Func \
110 const DimensionedField<Type, GeoMesh>& f1, \
111 const label comm = UPstream::worldComm \
113template<class Type, class GeoMesh> \
114dimensioned<ReturnType> Func \
116 const tmp<DimensionedField<Type, GeoMesh>>& tf1, \
117 const label comm = UPstream::worldComm \
129#undef UNARY_REDUCTION_FUNCTION
147template<
class Type,
class GeoMesh>
150 DimensionedField<Type, GeoMesh>& result,
151 const DimensionedField<Type, GeoMesh>& f1,
155template<
class Type,
class GeoMesh>
156tmp<DimensionedField<Type, GeoMesh>>
159 const DimensionedField<Type, GeoMesh>& f1,
163template<
class Type,
class GeoMesh>
164tmp<DimensionedField<Type, GeoMesh>>
167 const tmp<DimensionedField<Type, GeoMesh>>& tf1,
196#define PRODUCT_OPERATOR(product, Op, OpFunc) \
198template<class Type1, class Type2, class GeoMesh> \
199tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
202 const DimensionedField<Type1, GeoMesh>& f1, \
203 const DimensionedField<Type2, GeoMesh>& f2 \
206template<class Type1, class Type2, class GeoMesh> \
207tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
210 const DimensionedField<Type1, GeoMesh>& f1, \
211 const tmp<DimensionedField<Type2, GeoMesh>>& tf2 \
214template<class Type1, class Type2, class GeoMesh> \
215tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
218 const tmp<DimensionedField<Type1, GeoMesh>>& tf1, \
219 const DimensionedField<Type2, GeoMesh>& f2 \
222template<class Type1, class Type2, class GeoMesh> \
223tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
226 const tmp<DimensionedField<Type1, GeoMesh>>& tf1, \
227 const tmp<DimensionedField<Type2, GeoMesh>>& tf2 \
230template<class Form, class Type, class GeoMesh> \
231tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
234 const DimensionedField<Type, GeoMesh>& f1, \
235 const dimensioned<Form>& dvs \
238template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
239tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
242 const DimensionedField<Type, GeoMesh>& f1, \
243 const VectorSpace<Form,Cmpt,nCmpt>& vs \
246template<class Form, class Type, class GeoMesh> \
247tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
250 const tmp<DimensionedField<Type, GeoMesh>>& tf1, \
251 const dimensioned<Form>& dvs \
254template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
255tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
258 const tmp<DimensionedField<Type, GeoMesh>>& tf1, \
259 const VectorSpace<Form,Cmpt,nCmpt>& vs \
262template<class Form, class Type, class GeoMesh> \
263tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
266 const dimensioned<Form>& dvs, \
267 const DimensionedField<Type, GeoMesh>& f2 \
270template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
271tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
274 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
275 const DimensionedField<Type, GeoMesh>& f2 \
278template<class Form, class Type, class GeoMesh> \
279tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
282 const dimensioned<Form>& dvs, \
283 const tmp<DimensionedField<Type, GeoMesh>>& tf2 \
286template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
287tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
290 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
291 const tmp<DimensionedField<Type, GeoMesh>>& tf2 \
302#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)
#define UNARY_REDUCTION_FUNCTION(ReturnType, Func, gFunc)
Scalar specific part of the implementation of DimensionedField.
Field< Type >::cmptType cmptType
Component type of the field elements.
symmTypeOfRank< typenamepTraits< arg1 >::cmptType, arg2 *direction(pTraits< arg1 >::rank)>::type type
pTraits< typenamepTraits< arg1 >::cmptType >::magType type
Represents 0/1 range or concept. Used for tagged dispatch or clamping.
#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)
dimensioned< Type > cmptDivide(const dimensioned< Type > &, const dimensioned< Type > &)
refinementData transform(const tensor &, const refinementData val)
No-op rotational transform for base types.
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.
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 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)
dict add("bounds", meshBb)