OneConstant.H
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) 2017 OpenFOAM Foundation
9  Copyright (C) 2020-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 Class
28  Foam::Function1Types::OneConstant
29 
30 Description
31  Templated function that returns the corresponding 1 (one).
32 
33  Usage:
34  \verbatim
35  <entryName> one;
36  \endverbatim
37 
38 SourceFiles
39  OneConstant.C
40 
41 \*---------------------------------------------------------------------------*/
42 
43 #ifndef Function1Types_OneConstant_H
44 #define Function1Types_OneConstant_H
45 
46 #include "Function1.H"
47 
48 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
49 
50 namespace Foam
51 {
52 namespace Function1Types
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class OneConstant Declaration
57 \*---------------------------------------------------------------------------*/
58 
59 template<class Type>
60 class OneConstant
61 :
62  public Function1<Type>
63 {
64 public:
65 
66  //- Runtime type information
67  TypeName("one");
68 
69 
70  // Generated Methods
71 
72  //- Default copy construct
73  OneConstant(const OneConstant<Type>&) = default;
74 
75  //- No copy assignment
76  void operator=(const OneConstant<Type>&) = delete;
77 
78 
79  // Constructors
80 
81  //- Construct from entry name and optional registry
82  explicit OneConstant
83  (
84  const word& entryName,
85  const objectRegistry* obrPtr = nullptr
86  );
87 
88  //- Construct from entry name, dictionary and optional registry
90  (
91  const word& entryName,
92  const dictionary& dict,
93  const objectRegistry* obrPtr = nullptr
94  );
95 
96  //- Construct and return a clone
97  virtual tmp<Function1<Type>> clone() const
98  {
99  return tmp<Function1<Type>>(new OneConstant<Type>(*this));
100  }
101 
102 
103  //- Destructor
104  virtual ~OneConstant() = default;
105 
106 
107  // Member Functions
108 
109  //- Value is independent of x
110  virtual inline bool constant() const { return true; }
111 
112  //- Return constant value
113  virtual inline Type value(const scalar) const
114  {
115  return pTraits<Type>::one;
116  }
117 
118  //- Integrate between two values
119  virtual inline Type integrate(const scalar x1, const scalar x2) const
120  {
121  return (x2 - x1)*pTraits<Type>::one;
122  }
123 
124  //- Return value as a function of (scalar) independent variable
125  virtual tmp<Field<Type>> value(const scalarField& x) const;
127  //- Integrate between two (scalar) values
128  virtual tmp<Field<Type>> integrate
129  (
130  const scalarField& x1,
131  const scalarField& x2
132  ) const;
133 
134  //- Write as primitive (inline) format
135  virtual void writeData(Ostream& os) const;
136 };
137 
138 
139 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
140 
141 } // End namespace Function1Types
142 } // End namespace Foam
143 
144 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
145 
146 #ifdef NoRepository
147  #include "OneConstant.C"
148 #endif
149 
150 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
151 
152 #endif
153 
154 // ************************************************************************* //
Top level data entry class for use in dictionaries. Provides a mechanism to specify a variable as a c...
virtual tmp< Function1< Type > > clone() const
Construct and return a clone.
Definition: OneConstant.H:104
const word const dictionary & dict
Definition: Function1.H:140
OneConstant(const OneConstant< Type > &)=default
Default copy construct.
A list of keyword definitions, which are a keyword followed by a number of values (eg...
Definition: dictionary.H:129
void operator=(const OneConstant< Type > &)=delete
No copy assignment.
A traits class, which is primarily used for primitives and vector-space.
Definition: pTraits.H:75
virtual ~OneConstant()=default
Destructor.
const word & entryName
Definition: Function1.H:140
Templated function that returns the corresponding 1 (one).
Definition: OneConstant.H:55
A class for handling words, derived from Foam::string.
Definition: word.H:63
TypeName("one")
Runtime type information.
An Ostream is an abstract base class for all output systems (streams, files, token lists...
Definition: Ostream.H:56
OBJstream os(runTime.globalPath()/outputName)
const word const dictionary const objectRegistry * obrPtr
Definition: Function1.H:140
virtual Type value(const scalar) const
Return constant value.
Definition: OneConstant.H:126
virtual Type integrate(const scalar x1, const scalar x2) const
Integrate between two values.
Definition: OneConstant.H:134
A class for managing temporary objects.
Definition: HashPtrTable.H:50
Registry of regIOobjects.
virtual void writeData(Ostream &os) const
Write as primitive (inline) format.
Definition: OneConstant.C:73
virtual bool constant() const
Value is independent of x.
Definition: OneConstant.H:121
Namespace for OpenFOAM.