ENH: autoLayerDriver: better layering information message
[OpenFOAM-2.0.x.git] / src / OpenFOAM / fields / DimensionedFields / DimensionedField / DimensionedFieldFunctions.C
blob66f6c7bee1e0fbc843c0e6dcce1c3bebe9d92f82
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 \*---------------------------------------------------------------------------*/
26 #include "DimensionedFieldReuseFunctions.H"
28 #define TEMPLATE template<class Type, class GeoMesh>
29 #include "DimensionedFieldFunctionsM.C"
31 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
33 namespace Foam
36 // * * * * * * * * * * * * * * * Global functions  * * * * * * * * * * * * * //
38 template<class Type, class GeoMesh, int r>
39 tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh> >
40 pow
42     const DimensionedField<Type, GeoMesh>& df,
43     typename powProduct<Type, r>::type
46     typedef typename powProduct<Type, r>::type powProductType;
48     tmp<DimensionedField<powProductType, GeoMesh> > tPow
49     (
50         new DimensionedField<powProductType, GeoMesh>
51         (
52             IOobject
53             (
54                 "pow(" + df.name() + ',' + name(r) + ')',
55                 df.instance(),
56                 df.db()
57             ),
58             df.mesh(),
59             pow(df.dimensions(), r)
60         )
61     );
63     pow<Type, r, GeoMesh>(tPow().field(), df.field());
65     return tPow;
69 template<class Type, class GeoMesh, int r>
70 tmp<DimensionedField<typename powProduct<Type, r>::type, GeoMesh> >
71 pow
73     const tmp<DimensionedField<Type, GeoMesh> >& tdf,
74     typename powProduct<Type, r>::type
77     typedef typename powProduct<Type, r>::type powProductType;
79     const DimensionedField<Type, GeoMesh>& df = tdf();
81     tmp<DimensionedField<powProductType, GeoMesh> > tPow =
82         reuseTmpDimensionedField<powProductType, Type, GeoMesh>::New
83         (
84             tdf,
85             "pow(" + df.name() + ',' + name(r) + ')',
86             pow(df.dimensions(), r)
87         );
89     pow<Type, r, GeoMesh>(tPow().field(), df.field());
91     reuseTmpDimensionedField<powProductType, Type, GeoMesh>::clear(tdf);
93     return tPow;
96 template<class Type, class GeoMesh>
97 tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh> >
98 sqr(const DimensionedField<Type, GeoMesh>& df)
100     typedef typename outerProduct<Type, Type>::type outerProductType;
102     tmp<DimensionedField<outerProductType, GeoMesh> > tSqr
103     (
104         new DimensionedField<outerProductType, GeoMesh>
105         (
106             IOobject
107             (
108                 "sqr(" + df.name() + ')',
109                 df.instance(),
110                 df.db()
111             ),
112             df.mesh(),
113             sqr(df.dimensions())
114         )
115     );
117     sqr(tSqr().field(), df.field());
119     return tSqr;
122 template<class Type, class GeoMesh>
123 tmp<DimensionedField<typename outerProduct<Type, Type>::type, GeoMesh> >
124 sqr(const tmp<DimensionedField<Type, GeoMesh> >& tdf)
126     typedef typename outerProduct<Type, Type>::type outerProductType;
128     const DimensionedField<Type, GeoMesh>& df = tdf();
130     tmp<DimensionedField<outerProductType, GeoMesh> > tSqr =
131         reuseTmpDimensionedField<outerProductType, Type, GeoMesh>::New
132         (
133             tdf,
134             "sqr(" + df.name() + ')',
135             sqr(df.dimensions())
136         );
138     sqr(tSqr().field(), df.field());
140     reuseTmpDimensionedField<outerProductType, Type, GeoMesh>::clear(tdf);
142     return tSqr;
146 template<class Type, class GeoMesh>
147 tmp<DimensionedField<scalar, GeoMesh> > magSqr
149     const DimensionedField<Type, GeoMesh>& df
152     tmp<DimensionedField<scalar, GeoMesh> > tMagSqr
153     (
154         new DimensionedField<scalar, GeoMesh>
155         (
156             IOobject
157             (
158                 "magSqr(" + df.name() + ')',
159                 df.instance(),
160                 df.db()
161             ),
162             df.mesh(),
163             sqr(df.dimensions())
164         )
165     );
167     magSqr(tMagSqr().field(), df.field());
169     return tMagSqr;
172 template<class Type, class GeoMesh>
173 tmp<DimensionedField<scalar, GeoMesh> > magSqr
175     const tmp<DimensionedField<Type, GeoMesh> >& tdf
178     const DimensionedField<Type, GeoMesh>& df = tdf();
180     tmp<DimensionedField<scalar, GeoMesh> > tMagSqr =
181         reuseTmpDimensionedField<scalar, Type, GeoMesh>::New
182         (
183             tdf,
184             "magSqr(" + df.name() + ')',
185             sqr(df.dimensions())
186         );
188     magSqr(tMagSqr().field(), df.field());
190     reuseTmpDimensionedField<scalar, Type, GeoMesh>::clear(tdf);
192     return tMagSqr;
196 template<class Type, class GeoMesh>
197 tmp<DimensionedField<scalar, GeoMesh> > mag
199     const DimensionedField<Type, GeoMesh>& df
202     tmp<DimensionedField<scalar, GeoMesh> > tMag
203     (
204         new DimensionedField<scalar, GeoMesh>
205         (
206             IOobject
207             (
208                 "mag(" + df.name() + ')',
209                 df.instance(),
210                 df.db()
211             ),
212             df.mesh(),
213             df.dimensions()
214         )
215     );
217     mag(tMag().field(), df.field());
219     return tMag;
222 template<class Type, class GeoMesh>
223 tmp<DimensionedField<scalar, GeoMesh> > mag
225     const tmp<DimensionedField<Type, GeoMesh> >& tdf
228     const DimensionedField<Type, GeoMesh>& df = tdf();
230     tmp<DimensionedField<scalar, GeoMesh> > tMag =
231         reuseTmpDimensionedField<scalar, Type, GeoMesh>::New
232         (
233             tdf,
234             "mag(" + df.name() + ')',
235             df.dimensions()
236         );
238     mag(tMag().field(), df.field());
240     reuseTmpDimensionedField<scalar, Type, GeoMesh>::clear(tdf);
242     return tMag;
246 template<class Type, class GeoMesh>
249     DimensionedField
250         <typename DimensionedField<Type, GeoMesh>::cmptType, GeoMesh>
252 cmptAv(const DimensionedField<Type, GeoMesh>& df)
254     typedef typename DimensionedField<Type, GeoMesh>::cmptType cmptType;
256     tmp<DimensionedField<cmptType, GeoMesh> > CmptAv
257     (
258         new DimensionedField<scalar, GeoMesh>
259         (
260             IOobject
261             (
262                 "cmptAv(" + df.name() + ')',
263                 df.instance(),
264                 df.db()
265             ),
266             df.mesh(),
267             df.dimensions()
268         )
269     );
271     cmptAv(CmptAv().field(), df.field());
273     return CmptAv;
276 template<class Type, class GeoMesh>
279     DimensionedField
280         <typename DimensionedField<Type, GeoMesh>::cmptType, GeoMesh>
282 cmptAv(const tmp<DimensionedField<Type, GeoMesh> >& tdf)
284     typedef typename DimensionedField<Type, GeoMesh>::cmptType
285         cmptType;
287     const DimensionedField<Type, GeoMesh>& df = tdf();
289     tmp<DimensionedField<cmptType, GeoMesh> > CmptAv =
290         reuseTmpDimensionedField<cmptType, Type, GeoMesh>::New
291         (
292             tdf,
293             "cmptAv(" + df.name() + ')',
294             df.dimensions()
295         );
297     cmptAv(CmptAv().field(), df.field());
299     reuseTmpDimensionedField<cmptType, Type, GeoMesh>::clear(tdf);
301     return CmptAv;
304 #define UNARY_REDUCTION_FUNCTION(returnType, func, dfunc)                     \
305                                                                               \
306 template<class Type, class GeoMesh>                                           \
307 dimensioned<returnType> func                                                  \
308 (                                                                             \
309     const DimensionedField<Type, GeoMesh>& df                                 \
310 )                                                                             \
311 {                                                                             \
312     return dimensioned<Type>                                                  \
313     (                                                                         \
314         #func "(" + df.name() + ')',                                          \
315         df.dimensions(),                                                      \
316         dfunc(df.field())                                                     \
317     );                                                                        \
318 }                                                                             \
319                                                                               \
320 template<class Type, class GeoMesh>                                           \
321 dimensioned<returnType> func                                                  \
322 (                                                                             \
323     const tmp<DimensionedField<Type, GeoMesh> >& tdf1                         \
324 )                                                                             \
325 {                                                                             \
326     dimensioned<returnType> res = func(tdf1());                               \
327     tdf1.clear();                                                             \
328     return res;                                                               \
331 UNARY_REDUCTION_FUNCTION(Type, max, gMax)
332 UNARY_REDUCTION_FUNCTION(Type, min, gMin)
333 UNARY_REDUCTION_FUNCTION(Type, sum, gSum)
334 UNARY_REDUCTION_FUNCTION(scalar, sumMag, gSumMag)
335 UNARY_REDUCTION_FUNCTION(Type, average, gAverage)
337 #undef UNARY_REDUCTION_FUNCTION
340 BINARY_FUNCTION(Type, Type, Type, max)
341 BINARY_FUNCTION(Type, Type, Type, min)
342 BINARY_FUNCTION(Type, Type, Type, cmptMultiply)
343 BINARY_FUNCTION(Type, Type, Type, cmptDivide)
345 BINARY_TYPE_FUNCTION(Type, Type, Type, max)
346 BINARY_TYPE_FUNCTION(Type, Type, Type, min)
347 BINARY_TYPE_FUNCTION(Type, Type, Type, cmptMultiply)
348 BINARY_TYPE_FUNCTION(Type, Type, Type, cmptDivide)
351 // * * * * * * * * * * * * * * * Global operators  * * * * * * * * * * * * * //
353 UNARY_OPERATOR(Type, Type, -, negate, transform)
355 BINARY_OPERATOR(Type, Type, scalar, *, '*', multiply)
356 BINARY_OPERATOR(Type, scalar, Type, *, '*', multiply)
357 BINARY_OPERATOR(Type, Type, scalar, /, '|', divide)
359 BINARY_TYPE_OPERATOR_SF(Type, scalar, Type, *, '*', multiply)
360 BINARY_TYPE_OPERATOR_FS(Type, Type, scalar, *, '*', multiply)
362 BINARY_TYPE_OPERATOR_FS(Type, Type, scalar, /, '|', divide)
365 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
367 #define PRODUCT_OPERATOR(product, op, opFunc)                                 \
368                                                                               \
369 template<class Type1, class Type2, class GeoMesh>                             \
370 tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh> >         \
371 operator op                                                                   \
372 (                                                                             \
373     const DimensionedField<Type1, GeoMesh>& df1,                              \
374     const DimensionedField<Type2, GeoMesh>& df2                               \
375 )                                                                             \
376 {                                                                             \
377     typedef typename product<Type1, Type2>::type productType;                 \
378     tmp<DimensionedField<productType, GeoMesh> > tRes                         \
379     (                                                                         \
380         new DimensionedField<productType, GeoMesh>                            \
381         (                                                                     \
382             IOobject                                                          \
383             (                                                                 \
384                 '(' + df1.name() + #op + df2.name() + ')',                    \
385                 df1.instance(),                                               \
386                 df1.db()                                                      \
387             ),                                                                \
388             df1.mesh(),                                                       \
389             df1.dimensions() op df2.dimensions()                              \
390         )                                                                     \
391     );                                                                        \
392                                                                               \
393     Foam::opFunc(tRes().field(), df1.field(), df2.field());                   \
394                                                                               \
395     return tRes;                                                              \
396 }                                                                             \
397                                                                               \
398 template<class Type1, class Type2, class GeoMesh>                             \
399 tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh> >         \
400 operator op                                                                   \
401 (                                                                             \
402     const DimensionedField<Type1, GeoMesh>& df1,                              \
403     const tmp<DimensionedField<Type2, GeoMesh> >& tdf2                        \
404 )                                                                             \
405 {                                                                             \
406     typedef typename product<Type1, Type2>::type productType;                 \
407                                                                               \
408     const DimensionedField<Type2, GeoMesh>& df2 = tdf2();                     \
409                                                                               \
410     tmp<DimensionedField<productType, GeoMesh> > tRes =                       \
411         reuseTmpDimensionedField<productType, Type2, GeoMesh>::New            \
412         (                                                                     \
413             tdf2,                                                             \
414             '(' + df1.name() + #op + df2.name() + ')',                        \
415             df1.dimensions() op df2.dimensions()                              \
416         );                                                                    \
417                                                                               \
418     Foam::opFunc(tRes().field(), df1.field(), df2.field());                   \
419                                                                               \
420     reuseTmpDimensionedField<productType, Type2, GeoMesh>::clear(tdf2);       \
421                                                                               \
422     return tRes;                                                              \
423 }                                                                             \
424                                                                               \
425 template<class Type1, class Type2, class GeoMesh>                             \
426 tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh> >         \
427 operator op                                                                   \
428 (                                                                             \
429     const tmp<DimensionedField<Type1, GeoMesh> >& tdf1,                       \
430     const DimensionedField<Type2, GeoMesh>& df2                               \
431 )                                                                             \
432 {                                                                             \
433     typedef typename product<Type1, Type2>::type productType;                 \
434                                                                               \
435     const DimensionedField<Type1, GeoMesh>& df1 = tdf1();                     \
436                                                                               \
437     tmp<DimensionedField<productType, GeoMesh> > tRes =                       \
438         reuseTmpDimensionedField<productType, Type1, GeoMesh>::New            \
439         (                                                                     \
440             tdf1,                                                             \
441             '(' + df1.name() + #op + df2.name() + ')',                        \
442             df1.dimensions() op df2.dimensions()                              \
443         );                                                                    \
444                                                                               \
445     Foam::opFunc(tRes().field(), df1.field(), df2.field());                   \
446                                                                               \
447     reuseTmpDimensionedField<productType, Type1, GeoMesh>::clear(tdf1);       \
448                                                                               \
449     return tRes;                                                              \
450 }                                                                             \
451                                                                               \
452 template<class Type1, class Type2, class GeoMesh>                             \
453 tmp<DimensionedField<typename product<Type1, Type2>::type, GeoMesh> >         \
454 operator op                                                                   \
455 (                                                                             \
456     const tmp<DimensionedField<Type1, GeoMesh> >& tdf1,                       \
457     const tmp<DimensionedField<Type2, GeoMesh> >& tdf2                        \
458 )                                                                             \
459 {                                                                             \
460     typedef typename product<Type1, Type2>::type productType;                 \
461                                                                               \
462     const DimensionedField<Type1, GeoMesh>& df1 = tdf1();                     \
463     const DimensionedField<Type2, GeoMesh>& df2 = tdf2();                     \
464                                                                               \
465     tmp<DimensionedField<productType, GeoMesh> > tRes =                       \
466         reuseTmpTmpDimensionedField                                           \
467         <productType, Type1, Type1, Type2, GeoMesh>::New                      \
468         (                                                                     \
469             tdf1,                                                             \
470             tdf2,                                                             \
471             '(' + df1.name() + #op + df2.name() + ')',                        \
472             df1.dimensions() op df2.dimensions()                              \
473         );                                                                    \
474                                                                               \
475     Foam::opFunc(tRes().field(), df1.field(), df2.field());                   \
476                                                                               \
477     reuseTmpTmpDimensionedField                                               \
478         <productType, Type1, Type1, Type2, GeoMesh>::clear(tdf1, tdf2);       \
479                                                                               \
480     return tRes;                                                              \
481 }                                                                             \
482                                                                               \
483 template<class Form, class Type, class GeoMesh>                               \
484 tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh> >           \
485 operator op                                                                   \
486 (                                                                             \
487     const DimensionedField<Type, GeoMesh>& df1,                               \
488     const dimensioned<Form>& dvs                                              \
489 )                                                                             \
490 {                                                                             \
491     typedef typename product<Type, Form>::type productType;                   \
492                                                                               \
493     tmp<DimensionedField<productType, GeoMesh> > tRes                         \
494     (                                                                         \
495         new DimensionedField<productType, GeoMesh>                            \
496         (                                                                     \
497             IOobject                                                          \
498             (                                                                 \
499                 '(' + df1.name() + #op + dvs.name() + ')',                    \
500                 df1.instance(),                                               \
501                 df1.db()                                                      \
502             ),                                                                \
503             df1.mesh(),                                                       \
504             df1.dimensions() op dvs.dimensions()                              \
505         )                                                                     \
506     );                                                                        \
507                                                                               \
508     Foam::opFunc(tRes().field(), df1.field(), dvs.value());                   \
509                                                                               \
510     return tRes;                                                              \
511 }                                                                             \
512                                                                               \
513 template<class Form, class Cmpt, int nCmpt, class Type, class GeoMesh>        \
514 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
515 operator op                                                                   \
516 (                                                                             \
517     const DimensionedField<Type, GeoMesh>& df1,                               \
518     const VectorSpace<Form,Cmpt,nCmpt>& vs                                    \
519 )                                                                             \
520 {                                                                             \
521     return df1 op dimensioned<Form>(static_cast<const Form&>(vs));            \
522 }                                                                             \
523                                                                               \
524                                                                               \
525 template<class Form, class Type, class GeoMesh>                               \
526 tmp<DimensionedField<typename product<Type, Form>::type, GeoMesh> >           \
527 operator op                                                                   \
528 (                                                                             \
529     const tmp<DimensionedField<Type, GeoMesh> >& tdf1,                        \
530     const dimensioned<Form>& dvs                                              \
531 )                                                                             \
532 {                                                                             \
533     typedef typename product<Type, Form>::type productType;                   \
534                                                                               \
535     const DimensionedField<Type, GeoMesh>& df1 = tdf1();                      \
536                                                                               \
537     tmp<DimensionedField<productType, GeoMesh> > tRes =                       \
538         reuseTmpDimensionedField<productType, Type, GeoMesh>::New             \
539         (                                                                     \
540             tdf1,                                                             \
541             '(' + df1.name() + #op + dvs.name() + ')',                        \
542             df1.dimensions() op dvs.dimensions()                              \
543         );                                                                    \
544                                                                               \
545     Foam::opFunc(tRes().field(), df1.field(), dvs.value());                   \
546                                                                               \
547     reuseTmpDimensionedField<productType, Type, GeoMesh>::clear(tdf1);        \
548                                                                               \
549     return tRes;                                                              \
550 }                                                                             \
551                                                                               \
552 template<class Form, class Cmpt, int nCmpt, class Type, class GeoMesh>        \
553 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
554 operator op                                                                   \
555 (                                                                             \
556     const tmp<DimensionedField<Type, GeoMesh> >& tdf1,                        \
557     const VectorSpace<Form,Cmpt,nCmpt>& vs                                    \
558 )                                                                             \
559 {                                                                             \
560     return tdf1 op dimensioned<Form>(static_cast<const Form&>(vs));           \
561 }                                                                             \
562                                                                               \
563                                                                               \
564 template<class Form, class Type, class GeoMesh>                               \
565 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
566 operator op                                                                   \
567 (                                                                             \
568     const dimensioned<Form>& dvs,                                             \
569     const DimensionedField<Type, GeoMesh>& df1                                \
570 )                                                                             \
571 {                                                                             \
572     typedef typename product<Form, Type>::type productType;                   \
573     tmp<DimensionedField<productType, GeoMesh> > tRes                         \
574     (                                                                         \
575         new DimensionedField<productType, GeoMesh>                            \
576         (                                                                     \
577             IOobject                                                          \
578             (                                                                 \
579                 '(' + dvs.name() + #op + df1.name() + ')',                    \
580                 df1.instance(),                                               \
581                 df1.db()                                                      \
582             ),                                                                \
583             df1.mesh(),                                                       \
584             dvs.dimensions() op df1.dimensions()                              \
585         )                                                                     \
586     );                                                                        \
587                                                                               \
588     Foam::opFunc(tRes().field(), dvs.value(), df1.field());                   \
589                                                                               \
590     return tRes;                                                              \
591 }                                                                             \
592                                                                               \
593 template<class Form, class Cmpt, int nCmpt, class Type, class GeoMesh>        \
594 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
595 operator op                                                                   \
596 (                                                                             \
597     const VectorSpace<Form,Cmpt,nCmpt>& vs,                                   \
598     const DimensionedField<Type, GeoMesh>& df1                                \
599 )                                                                             \
600 {                                                                             \
601     return dimensioned<Form>(static_cast<const Form&>(vs)) op df1;            \
602 }                                                                             \
603                                                                               \
604 template<class Form, class Type, class GeoMesh>                               \
605 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
606 operator op                                                                   \
607 (                                                                             \
608     const dimensioned<Form>& dvs,                                             \
609     const tmp<DimensionedField<Type, GeoMesh> >& tdf1                         \
610 )                                                                             \
611 {                                                                             \
612     typedef typename product<Form, Type>::type productType;                   \
613                                                                               \
614     const DimensionedField<Type, GeoMesh>& df1 = tdf1();                      \
615                                                                               \
616     tmp<DimensionedField<productType, GeoMesh> > tRes =                       \
617         reuseTmpDimensionedField<productType, Type, GeoMesh>::New             \
618         (                                                                     \
619             tdf1,                                                             \
620             '(' + dvs.name() + #op + df1.name() + ')',                        \
621             dvs.dimensions() op df1.dimensions()                              \
622         );                                                                    \
623                                                                               \
624     Foam::opFunc(tRes().field(), dvs.value(), df1.field());                   \
625                                                                               \
626     reuseTmpDimensionedField<productType, Type, GeoMesh>::clear(tdf1);        \
627                                                                               \
628     return tRes;                                                              \
629 }                                                                             \
630                                                                               \
631 template<class Form, class Cmpt, int nCmpt, class Type, class GeoMesh>        \
632 tmp<DimensionedField<typename product<Form, Type>::type, GeoMesh> >           \
633 operator op                                                                   \
634 (                                                                             \
635     const VectorSpace<Form,Cmpt,nCmpt>& vs,                                   \
636     const tmp<DimensionedField<Type, GeoMesh> >& tdf1                         \
637 )                                                                             \
638 {                                                                             \
639     return dimensioned<Form>(static_cast<const Form&>(vs)) op tdf1;           \
642 PRODUCT_OPERATOR(typeOfSum, +, add)
643 PRODUCT_OPERATOR(typeOfSum, -, subtract)
645 PRODUCT_OPERATOR(outerProduct, *, outer)
646 PRODUCT_OPERATOR(crossProduct, ^, cross)
647 PRODUCT_OPERATOR(innerProduct, &, dot)
648 PRODUCT_OPERATOR(scalarProduct, &&, dotdot)
650 #undef PRODUCT_OPERATOR
653 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
655 } // End namespace Foam
657 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
659 #include "undefFieldFunctionsM.H"
661 // ************************************************************************* //