208 lines
4.7 KiB
C
208 lines
4.7 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2010-2010 OpenCFD Ltd.
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
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/>.
|
|
|
|
Application
|
|
|
|
Description
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "uLabel.H"
|
|
#include "IOstreams.H"
|
|
#include "PackedBoolList.H"
|
|
#include "IStringStream.H"
|
|
|
|
using namespace Foam;
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
// Main program:
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
PackedBoolList list1(20);
|
|
// set every third one on
|
|
forAll(list1, i)
|
|
{
|
|
list1[i] = !(i % 3);
|
|
}
|
|
|
|
Info<< "\nalternating bit pattern\n";
|
|
list1.printInfo(Info, true);
|
|
|
|
PackedBoolList list2 = ~list1;
|
|
|
|
Info<< "\ncomplementary bit pattern\n";
|
|
list2.printBits(Info);
|
|
|
|
// set every other on
|
|
forAll(list2, i)
|
|
{
|
|
list2[i] = !(i % 2);
|
|
}
|
|
|
|
Info<< "\nalternating bit pattern\n";
|
|
list2.printBits(Info);
|
|
|
|
list2.resize(28, false);
|
|
list2.resize(34, true);
|
|
list2.resize(40, false);
|
|
for (label i=0; i < 4; ++i)
|
|
{
|
|
list2[i] = true;
|
|
}
|
|
|
|
Info<< "\nresized with false, 6 true + 6 false, bottom 4 bits true\n";
|
|
list2.printInfo(Info, true);
|
|
|
|
labelList list2Labels = list2.used();
|
|
|
|
Info<< "\noperator|\n";
|
|
|
|
list1.printBits(Info);
|
|
list2.printBits(Info);
|
|
Info<< "==\n";
|
|
(list1 | list2).printBits(Info);
|
|
|
|
Info<< "\noperator& : does trim\n";
|
|
(list1 & list2).printBits(Info);
|
|
|
|
Info<< "\noperator^\n";
|
|
(list1 ^ list2).printBits(Info);
|
|
|
|
|
|
Info<< "\noperator|=\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 |= list2).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator|= with labelUList\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 |= list2Labels).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator&=\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 &= list2).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator+=\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 += list2).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator+= with labelUList\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 += list2Labels).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator-=\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 -= list2).printBits(Info);
|
|
}
|
|
|
|
Info<< "\noperator-= with labelUList\n";
|
|
{
|
|
PackedBoolList list3 = list1;
|
|
(list3 -= list2Labels).printBits(Info);
|
|
}
|
|
|
|
PackedBoolList list4
|
|
(
|
|
IStringStream
|
|
(
|
|
"(1 n 1 n 1 n 1 1 off 0 0 f f 0 y yes y true y false on t)"
|
|
)()
|
|
);
|
|
|
|
Info<< "\ntest Istream constructor\n";
|
|
|
|
list4.printInfo(Info, true);
|
|
Info<< list4 << " indices: " << list4.used()() <<endl;
|
|
|
|
Info<< "\nassign from labelList\n";
|
|
list4 = labelList
|
|
(
|
|
IStringStream
|
|
(
|
|
"(0 1 2 3 12 13 14 19 20 21)"
|
|
)()
|
|
);
|
|
|
|
list4.printInfo(Info, true);
|
|
Info<< list4 << " indices: " << list4.used()() <<endl;
|
|
|
|
Info<< "\nassign from indices\n";
|
|
list4.read
|
|
(
|
|
IStringStream
|
|
(
|
|
"{0 1 2 3 12 13 14 19 20 21}"
|
|
)()
|
|
);
|
|
|
|
|
|
list4.printInfo(Info, true);
|
|
Info<< list4 << " indices: " << list4.used()() <<endl;
|
|
|
|
List<bool> boolLst(list4.size());
|
|
forAll(list4, i)
|
|
{
|
|
boolLst[i] = list4[i];
|
|
}
|
|
|
|
Info<< "List<bool>: " << boolLst <<endl;
|
|
|
|
|
|
// check roundabout assignments
|
|
PackedList<2> pl2
|
|
(
|
|
IStringStream
|
|
(
|
|
"{(0 3)(1 3)(2 3)(3 3)(12 3)(13 3)(14 3)(19 3)(20 3)(21 3)}"
|
|
)()
|
|
);
|
|
|
|
Info<< "roundabout assignment: " << pl2 << endl;
|
|
|
|
list4.clear();
|
|
forAll(pl2, i)
|
|
{
|
|
list4[i] = pl2[i];
|
|
}
|
|
|
|
list4.write(Info, true) << endl;
|
|
|
|
list4.writeEntry("PackedBoolList", Info);
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|