Loading...
Searching...
No Matches
constrainedOptimisationMethod.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) 2007-2021 PCOpt/NTUA
9 Copyright (C) 2013-2021 FOSS GP
10 Copyright (C) 2019 OpenCFD Ltd.
11-------------------------------------------------------------------------------
12License
13 This file is part of OpenFOAM.
14
15 OpenFOAM is free software: you can redistribute it and/or modify it
16 under the terms of the GNU General Public License as published by
17 the Free Software Foundation, either version 3 of the License, or
18 (at your option) any later version.
19
20 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
21 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
22 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
23 for more details.
24
25 You should have received a copy of the GNU General Public License
26 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
27
28
29Class
30 Foam::constrainedOptimisationMethod
31
32Description
33 Abstract base class for optimisation methods supporting constraints.
34 Does not add functionality to updateMethod but act as a means
35 to categorize constrained optimisation methods for performing sanity checks
36
37SourceFiles
38 constrainedOptimisationMethod.C
39
40\*---------------------------------------------------------------------------*/
41
42#ifndef constrainedOptimisationMethod_H
43#define constrainedOptimisationMethod_H
44
46#include "fvMesh.H"
47#include "dictionary.H"
48#include "designVariables.H"
49
50// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
51
52namespace Foam
53{
55/*---------------------------------------------------------------------------*\
56 Class constrainedOptimisationMethod Declaration
57\*---------------------------------------------------------------------------*/
58
59class constrainedOptimisationMethod
60{
61private:
62
63 // Private Member Functions
64
65 //- No copy construct
66 constrainedOptimisationMethod
67 (
68 const constrainedOptimisationMethod&
69 ) = delete;
70
71 //- No copy assignment
72 void operator=(const constrainedOptimisationMethod&) = delete;
73
74
75public:
76
77 //- Runtime type information
78 TypeName("constrainedOptimisationMethod");
80 // Declare table with available constrainedOptimisation methods.
81 // Not used for run-time selection, just for keeping track of the
82 // available methods
83
85 (
86 autoPtr,
87 constrainedOptimisationMethod,
89 (
90 const fvMesh& mesh,
91 const dictionary& dict,
92 autoPtr<designVariables>& designVars,
93 const label nConstraints,
94 const word& type
95 ),
96 (mesh, dict, designVars, nConstraints, type)
97 );
98
99
100 // Constructors
101
102 //- Construct from components
103 constrainedOptimisationMethod
104 (
105 const fvMesh& mesh,
106 const dictionary& dict,
107 autoPtr<designVariables>& designVars,
108 const label nConstraints,
109 const word& type
110 );
111
112
113 //- Destructor
114 virtual ~constrainedOptimisationMethod() = default;
115};
116
117
118// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
120} // End namespace Foam
121
122// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
123
124#endif
125
126// ************************************************************************* //
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition autoPtr.H:65
TypeName("constrainedOptimisationMethod")
Runtime type information.
declareRunTimeSelectionTable(autoPtr, constrainedOptimisationMethod, dictionary,(const fvMesh &mesh, const dictionary &dict, autoPtr< designVariables > &designVars, const label nConstraints, const word &type),(mesh, dict, designVars, nConstraints, type))
virtual ~constrainedOptimisationMethod()=default
Destructor.
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition dictionary.H:133
Mesh data needed to do the Finite Volume discretisation.
Definition fvMesh.H:85
A class for handling words, derived from Foam::string.
Definition word.H:66
dynamicFvMesh & mesh
Namespace for OpenFOAM.
Macros to ease declaration of run-time selection tables.
#define declareRunTimeSelectionTable(ptrWrapper, baseType, argNames, argList, parList)
Declare a run-time selection (variables and adder classes).
dictionary dict
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.
Definition typeInfo.H:68