31#define TEMPLATE template<class Type, class GeoMesh>
41template<
class Type,
class GeoMesh, direction r>
42tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh>>
56 "pow(" + df.
name() +
',' +
name(r) +
')',
64 pow<Type, r, GeoMesh>(tres.ref().field(), df.
field());
70template<
class Type,
class GeoMesh, direction r>
71tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh>>
86 "pow(" + df.
name() +
',' +
name(r) +
')',
90 pow<Type, r, GeoMesh>(tres.ref().field(), df.
field());
97template<
class Type,
class GeoMesh>
98tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
108 "sqr(" + df.
name() +
')',
116 sqr(tres.ref().field(), df.
field());
121template<
class Type,
class GeoMesh>
122tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh>>
133 "sqr(" + df.
name() +
')',
137 sqr(tres.ref().field(), df.
field());
144template<
class Type,
class GeoMesh>
145tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
155 "magSqr(" + df.
name() +
')',
168template<
class Type,
class GeoMesh>
169tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
180 "magSqr(" + df.
name() +
')',
191template<
class Type,
class GeoMesh>
192tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
202 "mag(" + df.
name() +
')',
210 mag(tres.ref().field(), df.
field());
215template<
class Type,
class GeoMesh>
216tmp<DimensionedField<typename typeOfMag<Type>::type, GeoMesh>>
227 "mag(" + df.
name() +
')',
231 mag(tres.ref().field(), df.
field());
238template<
class Type,
class GeoMesh>
255 "cmptAv(" + df.
name() +
')',
269template<
class Type,
class GeoMesh>
287 "cmptAv(" + df.
name() +
')',
298#define UNARY_REDUCTION_FUNCTION(returnType, func, dfunc) \
300template<class Type, class GeoMesh> \
301dimensioned<returnType> func \
303 const DimensionedField<Type, GeoMesh>& df \
306 return dimensioned<returnType> \
308 #func "(" + df.name() + ')', \
314template<class Type, class GeoMesh> \
315dimensioned<returnType> func \
317 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
320 dimensioned<returnType> res = func(tdf1()); \
334#undef UNARY_REDUCTION_FUNCTION
366#define PRODUCT_OPERATOR(product, op, opFunc) \
368template<class Type1, class Type2, class GeoMesh> \
369tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
372 const DimensionedField<Type1, GeoMesh>& df1, \
373 const DimensionedField<Type2, GeoMesh>& df2 \
376 typedef typename product<Type1, Type2>::type productType; \
379 tmp<DimensionedField<productType, GeoMesh>>::New \
383 '(' + df1.name() + #op + df2.name() + ')', \
388 df1.dimensions() op df2.dimensions() \
391 Foam::opFunc(tres.ref().field(), df1.field(), df2.field()); \
397template<class Type1, class Type2, class GeoMesh> \
398tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
401 const DimensionedField<Type1, GeoMesh>& df1, \
402 const tmp<DimensionedField<Type2, GeoMesh>>& tdf2 \
405 typedef typename product<Type1, Type2>::type productType; \
407 const DimensionedField<Type2, GeoMesh>& df2 = tdf2(); \
410 reuseTmpDimensionedField<productType, Type2, GeoMesh>::New \
413 '(' + df1.name() + #op + df2.name() + ')', \
414 df1.dimensions() op df2.dimensions() \
417 Foam::opFunc(tres.ref().field(), df1.field(), df2.field()); \
424template<class Type1, class Type2, class GeoMesh> \
425tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
428 const tmp<DimensionedField<Type1, GeoMesh>>& tdf1, \
429 const DimensionedField<Type2, GeoMesh>& df2 \
432 typedef typename product<Type1, Type2>::type productType; \
434 const DimensionedField<Type1, GeoMesh>& df1 = tdf1(); \
437 reuseTmpDimensionedField<productType, Type1, GeoMesh>::New \
440 '(' + df1.name() + #op + df2.name() + ')', \
441 df1.dimensions() op df2.dimensions() \
444 Foam::opFunc(tres.ref().field(), df1.field(), df2.field()); \
451template<class Type1, class Type2, class GeoMesh> \
452tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh>> \
455 const tmp<DimensionedField<Type1, GeoMesh>>& tdf1, \
456 const tmp<DimensionedField<Type2, GeoMesh>>& tdf2 \
459 typedef typename product<Type1, Type2>::type productType; \
461 const DimensionedField<Type1, GeoMesh>& df1 = tdf1(); \
462 const DimensionedField<Type2, GeoMesh>& df2 = tdf2(); \
465 reuseTmpTmpDimensionedField \
466 <productType, Type1, Type1, Type2, GeoMesh>::New \
470 '(' + df1.name() + #op + df2.name() + ')', \
471 df1.dimensions() op df2.dimensions() \
474 Foam::opFunc(tres.ref().field(), df1.field(), df2.field()); \
482template<class Form, class Type, class GeoMesh> \
483tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
486 const DimensionedField<Type, GeoMesh>& df1, \
487 const dimensioned<Form>& dvs \
490 typedef typename product<Type, Form>::type productType; \
493 tmp<DimensionedField<productType, GeoMesh>>::New \
497 '(' + df1.name() + #op + dvs.name() + ')', \
502 df1.dimensions() op dvs.dimensions() \
505 Foam::opFunc(tres.ref().field(), df1.field(), dvs.value()); \
511template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
512tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
515 const DimensionedField<Type, GeoMesh>& df1, \
516 const VectorSpace<Form,Cmpt,nCmpt>& vs \
519 return df1 op dimensioned<Form>(static_cast<const Form&>(vs)); \
523template<class Form, class Type, class GeoMesh> \
524tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh>> \
527 const tmp<DimensionedField<Type, GeoMesh>>& tdf1, \
528 const dimensioned<Form>& dvs \
531 typedef typename product<Type, Form>::type productType; \
533 const DimensionedField<Type, GeoMesh>& df1 = tdf1(); \
536 reuseTmpDimensionedField<productType, Type, GeoMesh>::New \
539 '(' + df1.name() + #op + dvs.name() + ')', \
540 df1.dimensions() op dvs.dimensions() \
543 Foam::opFunc(tres.ref().field(), df1.field(), dvs.value()); \
550template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
551tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
554 const tmp<DimensionedField<Type, GeoMesh>>& tdf1, \
555 const VectorSpace<Form,Cmpt,nCmpt>& vs \
558 return tdf1 op dimensioned<Form>(static_cast<const Form&>(vs)); \
562template<class Form, class Type, class GeoMesh> \
563tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
566 const dimensioned<Form>& dvs, \
567 const DimensionedField<Type, GeoMesh>& df1 \
570 typedef typename product<Form, Type>::type productType; \
573 tmp<DimensionedField<productType, GeoMesh>>::New \
577 '(' + dvs.name() + #op + df1.name() + ')', \
582 dvs.dimensions() op df1.dimensions() \
585 Foam::opFunc(tres.ref().field(), dvs.value(), df1.field()); \
591template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
592tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
595 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
596 const DimensionedField<Type, GeoMesh>& df1 \
599 return dimensioned<Form>(static_cast<const Form&>(vs)) op df1; \
603template<class Form, class Type, class GeoMesh> \
604tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
607 const dimensioned<Form>& dvs, \
608 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
611 typedef typename product<Form, Type>::type productType; \
613 const DimensionedField<Type, GeoMesh>& df1 = tdf1(); \
616 reuseTmpDimensionedField<productType, Type, GeoMesh>::New \
619 '(' + dvs.name() + #op + df1.name() + ')', \
620 dvs.dimensions() op df1.dimensions() \
623 Foam::opFunc(tres.ref().field(), dvs.value(), df1.field()); \
630template<class Form, class Cmpt, direction nCmpt, class Type, class GeoMesh> \
631tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh>> \
634 const VectorSpace<Form,Cmpt,nCmpt>& vs, \
635 const tmp<DimensionedField<Type, GeoMesh>>& tdf1 \
638 return dimensioned<Form>(static_cast<const Form&>(vs)) op tdf1; \
650#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)
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
const dimensionSet & dimensions() const
Return dimensions.
const Mesh & mesh() const
Return mesh.
Field< Type >::cmptType cmptType
Component type of the elements of the field.
const Field< Type > & field() const
Return field.
Defines the attributes of an object for which implicit objectRegistry management is supported,...
const word & name() const noexcept
Return the object name.
const objectRegistry & db() const noexcept
Return the local objectRegistry.
const fileName & instance() const noexcept
Read access to instance path component.
A min/max value pair with additional methods. In addition to conveniently storing values,...
static autoPtr< Time > New()
Construct (dummy) Time - no functionObjects or libraries.
An edge is a list of two point labels. The functionality it provides supports the discretisation on a...
A class for managing temporary objects.
The magnitude type for given argument.
pTraits< typenamepTraits< arg1 >::cmptType >::magType type
type
Volume classification types.
#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 > &)
dimensioned< Type > average(const DimensionedField< Type, GeoMesh > &df)
fileName::Type type(const fileName &name, const bool followLink=true)
Return the file type: DIRECTORY or FILE, normally following symbolic links.
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 > &)
tmp< DimensionedField< TypeR, GeoMesh > > New(const tmp< DimensionedField< TypeR, GeoMesh > > &tdf1, const word &name, const dimensionSet &dimensions)
Global function forwards to reuseTmpDimensionedField::New.
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)
word name(const expressions::valueTypeCode typeCode)
A word representation of a valueTypeCode. Empty for INVALID.
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)