objectiveForce.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-2020, 2022 PCOpt/NTUA
9  Copyright (C) 2013-2020, 2022 FOSS GP
10  Copyright (C) 2019 OpenCFD Ltd.
11 -------------------------------------------------------------------------------
12 License
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 
29 Class
30  Foam::objectives::objectiveForce
31 
32 Description
33 
34 SourceFiles
35  objectiveForce.C
36 
37 \*---------------------------------------------------------------------------*/
38 
39 #ifndef objectiveForce_H
40 #define objectiveForce_H
41 
43 #include "wallFvPatch.H"
44 #include "createZeroField.H"
45 
46 
47 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
48 
49 namespace Foam
50 {
51 
52 namespace objectives
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class objectiveForce Declaration
57 \*---------------------------------------------------------------------------*/
58 
59 class objectiveForce
60 :
62 {
63 protected:
64 
65  // Protected Data
66 
69  scalar Aref_;
70  scalar rhoInf_;
71  scalar UInf_;
72 
73 
74 public:
75 
76  //- Runtime type information
77  TypeName("force");
78 
79 
80  // Constructors
81 
82  //- Construct from components
84  (
85  const fvMesh& mesh,
86  const dictionary& dict,
87  const word& adjointSolverName,
88  const word& primalSolverName
89  );
90 
91 
92  //- Destructor
93  virtual ~objectiveForce() = default;
94 
95 
96  // Member Functions
97 
98  //- Return the objective function value
99  virtual scalar J();
100 
101  //- Update values to be added to the adjoint wall velocity
102  virtual void update_boundarydJdp();
103 
104  //- Update delta(n dS)/delta b multiplier
105  virtual void update_dSdbMultiplier();
106 
107  //- Update delta(x)/delta b multiplier
108  virtual void update_dxdbMultiplier();
109 
110  //- Update dJ/dnut multiplier
111  virtual void update_boundarydJdnut();
112 
113  //- Update dJ/dGradU multiplier
114  virtual void update_boundarydJdGradU();
115 
116  //- Return denominator, without density
117  virtual scalar denom() const;
118 
119  //- Return force direction
120  virtual const vector& forceDirection() const;
121 };
122 
123 
124 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
125 
126 } // End namespace objectives
127 } // End namespace Foam
128 
129 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
130 
131 #endif
132 
133 // ************************************************************************* //
const dictionary & dict() const
Return objective dictionary.
Definition: objective.C:91
A list of keyword definitions, which are a keyword followed by a number of values (eg...
Definition: dictionary.H:129
virtual void update_boundarydJdGradU()
Update dJ/dGradU multiplier.
TypeName("force")
Runtime type information.
objectiveForce(const fvMesh &mesh, const dictionary &dict, const word &adjointSolverName, const word &primalSolverName)
Construct from components.
virtual void update_boundarydJdnut()
Update dJ/dnut multiplier.
virtual void update_boundarydJdp()
Update values to be added to the adjoint wall velocity.
virtual void update_dSdbMultiplier()
Update delta(n dS)/delta b multiplier.
dynamicFvMesh & mesh
A class for handling words, derived from Foam::string.
Definition: word.H:63
virtual scalar denom() const
Return denominator, without density.
A Vector of values with scalar precision, where scalar is float/double depending on the compilation f...
virtual const vector & forceDirection() const
Return force direction.
virtual ~objectiveForce()=default
Destructor.
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:78
virtual void update_dxdbMultiplier()
Update delta(x)/delta b multiplier.
virtual scalar J()
Return the objective function value.
Abstract base class for objective functions in incompressible flows.
Namespace for OpenFOAM.