Loading...
Searching...
No Matches
boundaryAdjointContributionTemplates.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) 2007-2023 PCOpt/NTUA
9 Copyright (C) 2013-2023 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/>.
28\*---------------------------------------------------------------------------*/
29
30// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
31
32template<class returnType, class sourceType, class castType>
35(
36 PtrList<sourceType>& sourceList,
37 const fvPatchField<returnType>& (castType::*boundaryFunction)(const label),
38 bool (castType::*hasFunction)() const
39)
40{
41 // Objective function contribution
42 auto tdJtotdvar = tmp<Field<returnType>>::New(patch_.size(), Zero);
43 auto& dJtotdvar = tdJtotdvar.ref();
44
45 // Get weighthed contribution
46 for (sourceType& funcI : sourceList)
47 {
48 castType& cfuncI = refCast<castType>(funcI);
49 if ((cfuncI.*hasFunction)())
50 {
51 const fvPatchField<returnType>& dJdvar =
52 (cfuncI.*boundaryFunction)(patch_.index());
53 dJtotdvar += cfuncI.weight()*dJdvar;
54 }
55 }
56
57 return tdJtotdvar;
58}
59
60
61// ************************************************************************* //
A list of pointers to objects of type <T>, with allocation/deallocation management of the pointers....
Definition PtrList.H:67
tmp< Field< returnType > > sumContributions(PtrList< sourceType > &sourceList, const fvPatchField< returnType > &(castType::*boundaryFunction)(const label), bool(castType::*hasFunction)() const)
static autoPtr< boundaryAdjointContribution > New(const word &managerName, const word &adjointSolverName, const word &simulationType, const fvPatch &patch)
Return a reference to the selected turbulence model.
Abstract base class with a fat-interface to all derived classes covering all possible ways in which t...
A class for managing temporary objects.
Definition tmp.H:75
Type & refCast(U &obj)
A dynamic_cast (for references) to Type reference.
Definition typeInfo.H:172
static constexpr const zero Zero
Global zero (0).
Definition zero.H:127