Public Member Functions | Static Public Member Functions | Protected Attributes | List of all members
adjointSensitivity Class Referenceabstract

Abstract base class for adjoint-based sensitivities in incompressible flows. More...

Inheritance diagram for adjointSensitivity:
Inheritance graph
[legend]
Collaboration diagram for adjointSensitivity:
Collaboration graph
[legend]

Public Member Functions

 TypeName ("adjointSensitivity")
 Runtime type information. More...
 
 declareRunTimeSelectionTable (autoPtr, adjointSensitivity, dictionary,(const fvMesh &mesh, const dictionary &dict, incompressibleAdjointSolver &adjointSolver),(mesh, dict, adjointSolver))
 
 adjointSensitivity (const fvMesh &mesh, const dictionary &dict, incompressibleAdjointSolver &adjointSolver)
 Construct from components. More...
 
virtual ~adjointSensitivity ()=default
 Destructor. More...
 
const incompressibleVarsprimalVars () const
 Get primal variables. More...
 
const incompressibleAdjointVarsadjointVars () const
 Get adjoint variables. More...
 
const incompressibleAdjointSolveradjointSolver () const
 Get adjoint solver. More...
 
virtual void accumulateIntegrand (const scalar dt)=0
 Accumulate sensitivity integrands. More...
 
virtual void assembleSensitivities ()=0
 Assemble sensitivities. More...
 
virtual const scalarFieldcalculateSensitivities ()
 Calculates and returns sensitivity fields. More...
 
const scalarFieldgetSensitivities () const
 Returns the sensitivity fields. More...
 
virtual void clearSensitivities ()
 Zero sensitivity fields and their constituents. More...
 
virtual void write (const word &baseName=word::null)
 Write sensitivity fields. More...
 
tmp< volTensorFieldcomputeGradDxDbMultiplier ()
 Compute the volTensorField multiplying grad(dxdb) for the volume-based approach to compute shape sensitivity derivatives. More...
 
tmp< volVectorFieldadjointMeshMovementSource ()
 Compute source term for adjoint mesh movement equation. More...
 
- Public Member Functions inherited from sensitivity
 TypeName ("sensitivity")
 Runtime type information. More...
 
 sensitivity (const fvMesh &mesh, const dictionary &dict)
 Construct from components. More...
 
virtual ~sensitivity ()=default
 Destructor. More...
 
const dictionarydict () const
 Return the construction dictionary. More...
 
virtual bool readDict (const dictionary &dict)
 Read dictionary if changed. More...
 
virtual void computeDerivativesSize ()
 Compute design variables number. Does nothing in the base. More...
 

Static Public Member Functions

static autoPtr< adjointSensitivityNew (const fvMesh &mesh, const dictionary &dict, incompressibleAdjointSolver &adjointSolver)
 Return a reference to the selected turbulence model. More...
 

Protected Attributes

scalarField derivatives_
 
incompressibleAdjointSolveradjointSolver_
 
const incompressibleVarsprimalVars_
 
incompressibleAdjointVarsadjointVars_
 
objectiveManagerobjectiveManager_
 
- Protected Attributes inherited from sensitivity
const fvMeshmesh_
 
dictionary dict_
 
autoPtr< volScalarFieldfieldSensPtr_
 

Detailed Description

Abstract base class for adjoint-based sensitivities in incompressible flows.

Reference:

    For the FI and ESI formulations
        Kavvadias, I., Papoutsis-Kiachagias, E., & Giannakoglou, K. (2015).
        On the proper treatment of grid sensitivities in continuous adjoint
        methods for shape optimization.
        Journal of Computational Physics, 301, 1–18.
        http://doi.org/10.1016/j.jcp.2015.08.012

    For the SI formulation
        Papoutsis-Kiachagias, E. M., & Giannakoglou, K. C. (2014).
        Continuous Adjoint Methods for Turbulent Flows, Applied to Shape
        and Topology Optimization: Industrial Applications.
        Archives of Computational Methods in Engineering, 23(2), 255–299.
        http://doi.org/10.1007/s11831-014-9141-9
Source files

Definition at line 74 of file adjointSensitivityIncompressible.H.

Constructor & Destructor Documentation

◆ adjointSensitivity()

adjointSensitivity ( const fvMesh mesh,
const dictionary dict,
incompressibleAdjointSolver adjointSolver 
)

Construct from components.

Definition at line 46 of file adjointSensitivityIncompressible.C.

◆ ~adjointSensitivity()

virtual ~adjointSensitivity ( )
virtualdefault

Destructor.

Member Function Documentation

◆ TypeName()

TypeName ( "adjointSensitivity"  )

Runtime type information.

◆ declareRunTimeSelectionTable()

declareRunTimeSelectionTable ( autoPtr  ,
adjointSensitivity  ,
dictionary  ,
(const fvMesh &mesh, const dictionary &dict, incompressibleAdjointSolver &adjointSolver ,
(mesh, dict, adjointSolver  
)

◆ New()

autoPtr< adjointSensitivity > New ( const fvMesh mesh,
const dictionary dict,
incompressibleAdjointSolver adjointSolver 
)
static

Return a reference to the selected turbulence model.

Definition at line 64 of file adjointSensitivityIncompressible.C.

References dict, Foam::endl(), Foam::exit(), Foam::FatalIOError, FatalIOErrorInLookup, Foam::Info, and mesh.

Referenced by adjointSimple::adjointSimple(), and sensitivityMultiple::sensitivityMultiple().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ primalVars()

const incompressibleVars& primalVars ( ) const
inline

Get primal variables.

Definition at line 168 of file adjointSensitivityIncompressible.H.

References adjointSensitivity::primalVars_.

◆ adjointVars()

const incompressibleAdjointVars& adjointVars ( ) const
inline

Get adjoint variables.

Definition at line 176 of file adjointSensitivityIncompressible.H.

References adjointSensitivity::adjointVars_.

◆ adjointSolver()

const incompressibleAdjointSolver& adjointSolver ( ) const
inline

Get adjoint solver.

Definition at line 184 of file adjointSensitivityIncompressible.H.

References adjointSensitivity::adjointSolver_.

◆ accumulateIntegrand()

virtual void accumulateIntegrand ( const scalar  dt)
pure virtual

Accumulate sensitivity integrands.

Corresponds to the flow and adjoint part of the sensitivities

Implemented in sensitivitySurface, sensitivitySurfacePoints, FIBase, SIBase, shapeSensitivities, and sensitivityMultiple.

◆ assembleSensitivities()

virtual void assembleSensitivities ( )
pure virtual

Assemble sensitivities.

Adds the geometric part of the sensitivities

Implemented in sensitivitySurface, sensitivitySurfacePoints, sensitivityBezierFI, sensitivityVolBSplinesFI, FIBase, sensitivityVolBSplines, SIBase, shapeSensitivities, sensitivityBezier, and sensitivityMultiple.

Referenced by adjointSensitivity::calculateSensitivities().

Here is the caller graph for this function:

◆ calculateSensitivities()

const scalarField & calculateSensitivities ( )
virtual

Calculates and returns sensitivity fields.

Used with optimisation libraries

Implements sensitivity.

Reimplemented in sensitivityMultiple.

Definition at line 96 of file adjointSensitivityIncompressible.C.

References adjointSensitivity::assembleSensitivities(), adjointSensitivity::derivatives_, Foam::type(), and adjointSensitivity::write().

Here is the call graph for this function:

◆ getSensitivities()

const scalarField & getSensitivities ( ) const

Returns the sensitivity fields.

Assumes it has already been updated/computed

Definition at line 104 of file adjointSensitivityIncompressible.C.

References adjointSensitivity::derivatives_.

◆ clearSensitivities()

void clearSensitivities ( )
virtual

◆ write()

void write ( const word baseName = word::null)
virtual

Write sensitivity fields.

If valid, copies boundaryFields to volFields and writes them. Virtual to be reimplemented by control points-based methods (Bezier, RBF) which do not need to write fields

Reimplemented from sensitivity.

Reimplemented in sensitivitySurface, sensitivitySurfacePoints, sensitivityBezierFI, sensitivityVolBSplinesFI, SIBase, sensitivityVolBSplines, shapeSensitivities, sensitivityBezier, and sensitivityMultiple.

Definition at line 120 of file adjointSensitivityIncompressible.C.

References sensitivity::write().

Referenced by adjointSensitivity::calculateSensitivities(), shapeSensitivities::write(), sensitivitySurfacePoints::write(), and sensitivitySurface::write().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ computeGradDxDbMultiplier()

tmp< volTensorField > computeGradDxDbMultiplier ( )

Compute the volTensorField multiplying grad(dxdb) for the volume-based approach to compute shape sensitivity derivatives.

Definition at line 126 of file adjointSensitivityIncompressible.C.

References adjointSensitivity::adjointSolver_, and incompressibleAdjointSolver::computeGradDxDbMultiplier().

Referenced by FIBase::accumulateIntegrand(), and adjointSensitivity::adjointMeshMovementSource().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ adjointMeshMovementSource()

tmp< volVectorField > adjointMeshMovementSource ( )

Member Data Documentation

◆ derivatives_

scalarField derivatives_
protected

◆ adjointSolver_

incompressibleAdjointSolver& adjointSolver_
protected

◆ primalVars_

const incompressibleVars& primalVars_
protected

◆ adjointVars_

incompressibleAdjointVars& adjointVars_
protected

◆ objectiveManager_

objectiveManager& objectiveManager_
protected

The documentation for this class was generated from the following files: