- exprValueFieldTag is an extended version of exprValue, with additional Field/List uniformity handling - the exprValueFieldTag reduce() method provides a more efficient method than using a regular combine operator. Since fields are usually non-uniform, will mostly only need the bitwise reduce and not a more expensive gather/combine. ENH: output of exprValue (scalar type) now includes '.' - prevents scalar/label ambiguity for values like '100.0', which would otherwise be written as '100' and thus interpreted as a label value when re-reading.
197 lines
5.1 KiB
C++
197 lines
5.1 KiB
C++
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | www.openfoam.com
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
Copyright (C) 2023-2024 OpenCFD Ltd.
|
|
-------------------------------------------------------------------------------
|
|
License
|
|
This file is part of OpenFOAM.
|
|
|
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
|
under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
Description
|
|
Test exprValue uniformity checks
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "argList.H"
|
|
#include "IOobject.H"
|
|
#include "IOstreams.H"
|
|
#include "labelList.H"
|
|
#include "scalarField.H"
|
|
#include "vectorField.H"
|
|
#include "DynamicList.H"
|
|
#include "Random.H"
|
|
#include "exprValueFieldTag.H"
|
|
|
|
using namespace Foam;
|
|
|
|
Ostream& printInfo(const expressions::exprValueFieldTag& tag)
|
|
{
|
|
tag.print(Pout);
|
|
return Pout;
|
|
}
|
|
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
// Main program:
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
using fieldTag = expressions::exprValueFieldTag;
|
|
|
|
Random rnd(123456);
|
|
|
|
argList::noCheckProcessorDirectories();
|
|
|
|
#include "setRootCase.H"
|
|
|
|
DynamicList<fieldTag> allTags;
|
|
|
|
{
|
|
scalarField fld1(20);
|
|
scalarField fld2a(20, Zero);
|
|
scalarField fld2b(10, 3.10);
|
|
scalarField fld3;
|
|
|
|
for (auto& val : fld1)
|
|
{
|
|
val = rnd.position<scalar>(0, 20);
|
|
}
|
|
|
|
if (!UPstream::master())
|
|
{
|
|
fld2b.resize(5);
|
|
fld2b *= 2;
|
|
}
|
|
|
|
fieldTag tag1(fld1.begin(), fld1.end());
|
|
fieldTag tag2a(fld2a.begin(), fld2a.end());
|
|
fieldTag tag2b(fld2b.begin(), fld2b.end());
|
|
fieldTag tag3(fld3.begin(), fld3.end());
|
|
fieldTag tag4(fld3.begin(), fld3.end());
|
|
|
|
printInfo(tag1) << nl;
|
|
printInfo(tag2a) << nl;
|
|
printInfo(tag2b) << nl;
|
|
printInfo(tag3) << nl;
|
|
|
|
{
|
|
Pout<< "Test reduce" << nl;
|
|
|
|
fieldTag work(fld2b.begin(), fld2b.end());
|
|
|
|
Pout<< "Before" << nl;
|
|
printInfo(work) << nl;
|
|
|
|
work.reduce();
|
|
|
|
Pout<< "After" << nl;
|
|
printInfo(work) << nl;
|
|
Pout<< "====" << nl;
|
|
}
|
|
|
|
allTags.clear();
|
|
allTags.push_back(tag1);
|
|
allTags.push_back(tag2a);
|
|
allTags.push_back(tag2b);
|
|
allTags.push_back(tag3);
|
|
allTags.push_back(tag4);
|
|
allTags.push_back(fieldTag::make_empty<tensor>());
|
|
|
|
|
|
// Add some other types
|
|
{
|
|
vectorField vfld2a(20, vector::uniform(1.23));
|
|
|
|
allTags.emplace_back
|
|
(
|
|
vfld2a.begin(),
|
|
vfld2a.end()
|
|
);
|
|
allTags.emplace_back(vector(1.01, 2.02, 3.03));
|
|
allTags.emplace_back(12.4);
|
|
|
|
allTags.emplace_back().set_value(vector::uniform(2.0));
|
|
allTags.back().set_empty();
|
|
}
|
|
Info<< "all tags: " << allTags << nl;
|
|
|
|
Foam::sort(allTags);
|
|
|
|
Info<< "sorted: " << allTags << nl;
|
|
|
|
fieldTag result;
|
|
|
|
result = fieldTag::combineOp{}(tag1, tag2a);
|
|
printInfo(result) << nl;
|
|
|
|
Info<< "combine: ";
|
|
printInfo(tag2a) << " and ";
|
|
printInfo(tag2b) << nl;
|
|
|
|
result = fieldTag::combineOp{}(tag2a, tag2b);
|
|
printInfo(result) << nl;
|
|
}
|
|
|
|
{
|
|
vectorField fld2a(20, Foam::zero{});
|
|
vectorField fld2b(10, vector::uniform(3.10));
|
|
|
|
fieldTag tag2a(fld2a.begin(), fld2a.end());
|
|
fieldTag tag2b(fld2b.begin(), fld2b.end());
|
|
|
|
printInfo(tag2a) << nl;
|
|
printInfo(tag2b) << nl;
|
|
|
|
fieldTag result;
|
|
|
|
Info<< "combine: ";
|
|
printInfo(tag2a) << " and ";
|
|
printInfo(tag2b) << nl;
|
|
|
|
result = fieldTag::combineOp{}(tag2a, tag2b);
|
|
printInfo(result) << nl;
|
|
}
|
|
|
|
if (UPstream::parRun())
|
|
{
|
|
scalarField fld;
|
|
|
|
if (!UPstream::master())
|
|
{
|
|
fld.resize(UPstream::myProcNo(), UPstream::myProcNo());
|
|
}
|
|
|
|
fieldTag oldTag(fld.begin(), fld.end());
|
|
|
|
printInfo(oldTag) << " input: " << fld << " <- before reduce" << nl;
|
|
|
|
fieldTag newTag = returnReduce(oldTag, fieldTag::combineOp());
|
|
|
|
printInfo(newTag) << " <- after reduce" << nl;
|
|
}
|
|
|
|
|
|
Info<< "\nEnd\n" << nl;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|