minTimeStepCondition.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2015 OpenFOAM Foundation
9  Copyright (C) 2019-2022 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 \*---------------------------------------------------------------------------*/
28 
29 #include "minTimeStepCondition.H"
31 #include "Time.H"
32 
33 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
34 
35 namespace Foam
36 {
37 namespace functionObjects
38 {
39 namespace runTimeControls
40 {
41  defineTypeNameAndDebug(minTimeStepCondition, 0);
43  (
44  runTimeCondition,
45  minTimeStepCondition,
46  dictionary
47  );
48 }
49 }
50 }
51 
52 
53 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
54 
57 (
58  const word& name,
59  const objectRegistry& obr,
60  const dictionary& dict,
61  stateFunctionObject& state
62 )
63 :
64  runTimeCondition(name, obr, dict, state),
65  minValue_(dict.get<scalar>("minValue"))
66 {
67  minValue_ = obr_.time().userTimeToTime(minValue_);
68 }
69 
70 
71 // * * * * * * * * * * * * * * Public Member Functions * * * * * * * * * * * //
72 
74 {
75  bool satisfied = false;
76 
77  if (!active_)
78  {
79  return true;
80  }
81 
82  if (obr_.time().deltaTValue() < minValue_)
83  {
84  satisfied = true;
85  }
86 
87  return satisfied;
88 }
89 
90 
92 {
93  // do nothing
94 }
95 
96 
98 {
99  // do nothing
100 }
101 
102 
103 // ************************************************************************* //
List< ReturnType > get(const UPtrList< T > &list, const AccessOp &aop)
List of values generated by applying the access operation to each list item.
dictionary dict
scalar deltaTValue() const noexcept
Return time step value.
Definition: TimeStateI.H:49
const objectRegistry & obr_
Reference to the object registry.
A list of keyword definitions, which are a keyword followed by a number of values (eg...
Definition: dictionary.H:129
minTimeStepCondition(const word &name, const objectRegistry &obr, const dictionary &dict, stateFunctionObject &state)
Constructor.
Macros for easy insertion into run-time selection tables.
word name(const expressions::valueTypeCode typeCode)
A word representation of a valueTypeCode. Empty for expressions::valueTypeCode::INVALID.
Definition: exprTraits.C:127
A class for handling words, derived from Foam::string.
Definition: word.H:63
const Time & time() const noexcept
Return time registry.
defineTypeNameAndDebug(averageCondition, 0)
addToRunTimeSelectionTable(runTimeCondition, averageCondition, dictionary)
scalar minValue_
Minimum time step value to compare.
Base class for function objects, adding functionality to read/write state information (data required ...
Registry of regIOobjects.
Namespace for OpenFOAM.