functionObjects::stopAt: New abstract base class for run stop conditions

By default the case stops following the next write but stopping immediately with
or without writing are also options.

The stopAtFile functionObject derived from stopAt stops the run when a file
predefined file is created in the case directory:

Description
    Stops the run when the specified file is created in the case directory.

    The default name of the trigger file is \c $FOAM_CASE/<name> where \c
    <name> is the name of the functionObject entry and the default action is \c
    nextWrite.

    Currently the following action types are supported:
    - noWriteNow
    - writeNow
    - nextWrite

    Examples of function object specification:
    \verbatim
    stop
    {
        type stopAtFile;
        libs ("libutilityFunctionObjects.so");
    }
    \endverbatim
    will stop the run at the next write after the file "stop" is created in the
    case directory.

    \verbatim
    stop
    {
        type stopAtFile;
        libs ("libutilityFunctionObjects.so");
        file "$FOAM_CASE/stop";
        action writeNow;
    }
    \endverbatim
    will write the fields and stop the run when the file "stop" is created in
    the case directory.

Usage
    \table
        Property | Description            | Required | Default value
        type     | type name: stopAtFile  | yes      |
        file     | Trigger file path name | no       | $FOAM_CASE/<name>
        action   | Action executed        | no       | nextWrite
    \endtable
This commit is contained in:
Henry Weller
2020-07-16 17:44:51 +01:00
parent c140e681cb
commit 7379f4525f
7 changed files with 483 additions and 254 deletions

View File

@ -0,0 +1,168 @@
/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration | Website: https://openfoam.org
\\ / A nd | Copyright (C) 2020 OpenFOAM Foundation
\\/ 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/>.
\*---------------------------------------------------------------------------*/
#include "stopAt.H"
#include "Time.H"
#include "addToRunTimeSelectionTable.H"
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
namespace Foam
{
namespace functionObjects
{
defineTypeNameAndDebug(stopAt, 0);
}
}
template<>
const char* Foam::NamedEnum
<
Foam::functionObjects::stopAt::actionType,
3
>::names[] =
{
"noWriteNow",
"writeNow",
"nextWrite"
};
const Foam::NamedEnum
<
Foam::functionObjects::stopAt::actionType,
3
> Foam::functionObjects::stopAt::actionTypeNames_;
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
Foam::functionObjects::stopAt::stopAt
(
const word& name,
const Time& runTime,
const dictionary& dict
)
:
functionObject(name),
time_(runTime),
action_(actionType::nextWrite),
stopped_(false)
{
read(dict);
}
// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
Foam::functionObjects::stopAt::~stopAt()
{}
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
bool Foam::functionObjects::stopAt::read(const dictionary& dict)
{
if (dict.found("action"))
{
action_ = actionTypeNames_.read(dict.lookup("action"));
}
else
{
action_ = actionType::nextWrite;
}
return true;
}
bool Foam::functionObjects::stopAt::execute()
{
if (!stopped_)
{
bool stopCondition = condition();
reduce(stopCondition, orOp<bool>());
if (stopCondition)
{
switch (action_)
{
case actionType::noWriteNow :
{
if (time_.stopAt(Time::stopAtControl::noWriteNow))
{
Info<< type() << "(timeIndex="
<< time_.timeIndex()
<< "): stopping now without writing"
<< endl;
}
break;
}
case actionType::writeNow :
{
if (time_.stopAt(Time::stopAtControl::writeNow))
{
Info<< type() << "(timeIndex="
<< time_.timeIndex()
<< "): stopping now after writing"
<< endl;
}
break;
}
case actionType::nextWrite :
{
if (time_.stopAt(Time::stopAtControl::nextWrite))
{
Info<< type() << "(timeIndex="
<< time_.timeIndex()
<< "): stopping after next write"
<< endl;
}
break;
}
}
stopped_ = true;
}
}
return true;
}
bool Foam::functionObjects::stopAt::write()
{
return true;
}
bool Foam::functionObjects::stopAt::end()
{
return true;
}
// ************************************************************************* //