- more dictionary-like methods, enforce keyType::LITERAL for all lookups to avoid any spurious keyword matching. - new readEntry, readIfPresent methods - The get() method replaces the now deprecate lookup() method. - Deprecate lookupOrFailsafe() Failsafe behaviour is now an optional parameter for lookupOrDefault, which makes it easier to tailor behaviour at runtime. - output of the names is now always flatted without line-breaks. Thus, os << flatOutput(someEnumNames.names()) << nl; os << someEnumNames << nl; both generate the same output. - Constructor now uses C-string (const char*) directly instead of Foam::word in its initializer_list. - Remove special enum + initializer_list constructor form since it can create unbounded lookup indices. - Removd old hasEnum, hasName forms that were provided during initial transition from NamedEnum. - Added static_assert on Enum contents to restrict to enum or integral values. Should not likely be using this class to enumerate other things since it internally uses an 'int' for its values. Changed volumeType accordingly to enumerate on its type (enum), not the class itself.
197 lines
5.4 KiB
C
197 lines
5.4 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2017 OpenCFD Ltd.
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
isoAdvector | Copyright (C) 2016-2017 DHI
|
|
-------------------------------------------------------------------------------
|
|
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
|
|
setAlphaField
|
|
|
|
Description
|
|
Uses isoCutCell to create a volume fraction field from either a cylinder,
|
|
a sphere or a plane.
|
|
|
|
Original code supplied by Johan Roenby, DHI (2016)
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "fvCFD.H"
|
|
#include "isoCutFace.H"
|
|
#include "isoCutCell.H"
|
|
#include "Enum.H"
|
|
#include "mathematicalConstants.H"
|
|
|
|
using namespace Foam::constant;
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
class shapeSelector
|
|
{
|
|
public:
|
|
|
|
enum class shapeType
|
|
{
|
|
PLANE,
|
|
SPHERE,
|
|
CYLINDER,
|
|
SIN
|
|
};
|
|
|
|
static const Foam::Enum<shapeType> shapeTypeNames;
|
|
};
|
|
|
|
|
|
const Foam::Enum
|
|
<
|
|
shapeSelector::shapeType
|
|
>
|
|
shapeSelector::shapeTypeNames
|
|
({
|
|
{ shapeSelector::shapeType::PLANE, "plane" },
|
|
{ shapeSelector::shapeType::SPHERE, "sphere" },
|
|
{ shapeSelector::shapeType::CYLINDER, "cylinder" },
|
|
{ shapeSelector::shapeType::SIN, "sin" },
|
|
});
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
#include "setRootCase.H"
|
|
#include "createTime.H"
|
|
#include "createNamedMesh.H"
|
|
|
|
Info<< "Reading setAlphaFieldDict\n" << endl;
|
|
|
|
IOdictionary dict
|
|
(
|
|
IOobject
|
|
(
|
|
"setAlphaFieldDict",
|
|
runTime.system(),
|
|
mesh,
|
|
IOobject::MUST_READ,
|
|
IOobject::NO_WRITE
|
|
)
|
|
);
|
|
|
|
const shapeSelector::shapeType surfType
|
|
(
|
|
shapeSelector::shapeTypeNames.get("type", dict)
|
|
);
|
|
const vector centre(dict.get<vector>("centre"));
|
|
const word fieldName(dict.get<word>("field"));
|
|
|
|
Info<< "Reading field " << fieldName << "\n" << endl;
|
|
volScalarField alpha1
|
|
(
|
|
IOobject
|
|
(
|
|
fieldName,
|
|
runTime.timeName(),
|
|
mesh,
|
|
IOobject::MUST_READ,
|
|
IOobject::AUTO_WRITE
|
|
),
|
|
mesh
|
|
);
|
|
|
|
scalar f0 = 0.0;
|
|
scalarField f(mesh.points().size());
|
|
|
|
Info<< "Processing type '" << shapeSelector::shapeTypeNames[surfType]
|
|
<< "'" << endl;
|
|
|
|
switch (surfType)
|
|
{
|
|
case shapeSelector::shapeType::PLANE:
|
|
{
|
|
const vector direction(dict.get<vector>("direction"));
|
|
|
|
f = -(mesh.points() - centre) & (direction/mag(direction));
|
|
f0 = 0.0;
|
|
break;
|
|
}
|
|
case shapeSelector::shapeType::SPHERE:
|
|
{
|
|
const scalar radius(dict.get<scalar>("radius"));
|
|
|
|
f = -mag(mesh.points() - centre);
|
|
f0 = -radius;
|
|
break;
|
|
}
|
|
case shapeSelector::shapeType::CYLINDER:
|
|
{
|
|
const scalar radius(dict.get<scalar>("radius"));
|
|
const vector direction(dict.get<vector>("direction"));
|
|
|
|
f = -sqrt
|
|
(
|
|
sqr(mag(mesh.points() - centre))
|
|
- sqr(mag((mesh.points() - centre) & direction))
|
|
);
|
|
f0 = -radius;
|
|
break;
|
|
}
|
|
case shapeSelector::shapeType::SIN:
|
|
{
|
|
const scalar period(dict.get<scalar>("period"));
|
|
const scalar amplitude(dict.get<scalar>("amplitude"));
|
|
const vector up(dict.get<vector>("up"));
|
|
const vector direction(dict.get<vector>("direction"));
|
|
|
|
const scalarField xx
|
|
(
|
|
(mesh.points() - centre) & direction/mag(direction)
|
|
);
|
|
const scalarField zz((mesh.points() - centre) & up/mag(up));
|
|
|
|
f = amplitude*Foam::sin(2*mathematical::pi*xx/period) - zz;
|
|
f0 = 0;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Define function on mesh points and isovalue
|
|
|
|
// Calculating alpha1 volScalarField from f = f0 isosurface
|
|
isoCutCell icc(mesh, f);
|
|
icc.volumeOfFluid(alpha1, f0);
|
|
|
|
// Writing volScalarField alpha1
|
|
ISstream::defaultPrecision(18);
|
|
alpha1.write();
|
|
|
|
Info<< nl << "Phase-1 volume fraction = "
|
|
<< alpha1.weightedAverage(mesh.Vsc()).value()
|
|
<< " Min(" << alpha1.name() << ") = " << min(alpha1).value()
|
|
<< " Max(" << alpha1.name() << ") - 1 = " << max(alpha1).value() - 1
|
|
<< nl << endl;
|
|
|
|
Info<< "End\n" << endl;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
// ************************************************************************* //
|