KratosMultiphysics
KRATOS Multiphysics (Kratos) is a framework for building parallel, multi-disciplinary simulation software, aiming at modularity, extensibility, and high performance. Kratos is written in C++, and counts with an extensive Python interface.
List of all members
Kratos::AdjointLocalStressResponseFunction Class Reference

AdjointLocalStressResponseFunction. More...

#include <adjoint_local_stress_response_function.h>

Inheritance diagram for Kratos::AdjointLocalStressResponseFunction:
Collaboration diagram for Kratos::AdjointLocalStressResponseFunction:

Public Types

Type Definitions
typedef Element::DofsVectorType DofsVectorType
 
typedef Variable< double > * Array1DComponentsPointerType
 
- Public Types inherited from Kratos::AdjointStructuralResponseFunction
typedef std::size_t IndexType
 
typedef std::size_t SizeType
 

Public Member Functions

Pointer Definitions

Pointer definition of AdjointLocalStressResponseFunction

 KRATOS_CLASS_POINTER_DEFINITION (AdjointLocalStressResponseFunction)
 
Life Cycle
 AdjointLocalStressResponseFunction (ModelPart &rModelPart, Parameters ResponseSettings)
 Default constructor. More...
 
 ~AdjointLocalStressResponseFunction () override
 Destructor. More...
 
Operations
void FinalizeSolutionStep () override
 
void CalculateGradient (const Element &rAdjointElement, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo) override
 Calculate the local gradient w.r.t. primal solution. More...
 
void CalculatePartialSensitivity (Element &rAdjointElement, const Variable< double > &rVariable, const Matrix &rSensitivityMatrix, Vector &rSensitivityGradient, const ProcessInfo &rProcessInfo) override
 Calculate the partial sensitivity w.r.t. design variable. More...
 
void CalculatePartialSensitivity (Condition &rAdjointCondition, const Variable< double > &rVariable, const Matrix &rSensitivityMatrix, Vector &rSensitivityGradient, const ProcessInfo &rProcessInfo) override
 Calculate the partial sensitivity w.r.t. design variable. More...
 
void CalculatePartialSensitivity (Element &rAdjointElement, const Variable< array_1d< double, 3 >> &rVariable, const Matrix &rSensitivityMatrix, Vector &rSensitivityGradient, const ProcessInfo &rProcessInfo) override
 Calculate the partial sensitivity w.r.t. design variable. More...
 
void CalculatePartialSensitivity (Condition &rAdjointCondition, const Variable< array_1d< double, 3 >> &rVariable, const Matrix &rSensitivityMatrix, Vector &rSensitivityGradient, const ProcessInfo &rProcessInfo) override
 Calculate the partial sensitivity w.r.t. design variable. More...
 
double CalculateValue (ModelPart &rModelPart) override
 Calculate the scalar valued response function. More...
 
virtual void CalculateGradient (const Condition &rAdjointCondition, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo) override
 
- Public Member Functions inherited from Kratos::AdjointStructuralResponseFunction
 AdjointStructuralResponseFunction (ModelPart &rModelPart, Parameters ResponseSettings)
 Constructor. More...
 
virtual ~AdjointStructuralResponseFunction () override
 Destructor. More...
 
virtual void Initialize () override
 
virtual void CalculateGradient (const Condition &rAdjointCondition, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo) override
 Calculate the local gradient w.r.t. primal solution. More...
 
virtual void CalculateGradient (const Element &rAdjointElement, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. primal solution. More...
 
virtual void CalculateGradient (const Condition &rAdjointCondition, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. primal solution. More...
 
 KRATOS_CLASS_POINTER_DEFINITION (AdjointStructuralResponseFunction)
 
- Public Member Functions inherited from Kratos::AdjointResponseFunction
 KRATOS_CLASS_POINTER_DEFINITION (AdjointResponseFunction)
 
 AdjointResponseFunction ()
 Constructor. More...
 
virtual ~AdjointResponseFunction ()
 Destructor. More...
 
virtual void InitializeSolutionStep ()
 
virtual void CalculateFirstDerivativesGradient (const Element &rAdjointElement, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. first derivatives of primal solution. More...
 
virtual void CalculateFirstDerivativesGradient (const Condition &rAdjointCondition, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. first derivatives of primal solution. More...
 
virtual void CalculateSecondDerivativesGradient (const Element &rAdjointElement, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. second derivatives of primal solution. More...
 
virtual void CalculateSecondDerivativesGradient (const Condition &rAdjointCondition, const Matrix &rResidualGradient, Vector &rResponseGradient, const ProcessInfo &rProcessInfo)
 Calculate the local gradient w.r.t. second derivatives of primal solution. More...
 

Additional Inherited Members

- Protected Attributes inherited from Kratos::AdjointStructuralResponseFunction
ModelPartmrModelPart
 

Detailed Description

AdjointLocalStressResponseFunction.

This is a response function which traces one chosen type (e.g. MXX) of stress or stress-resultant of a single element as response. It is designed to be used in adjoint sensitivity analysis.

Member Typedef Documentation

◆ Array1DComponentsPointerType

◆ DofsVectorType

Constructor & Destructor Documentation

◆ AdjointLocalStressResponseFunction()

Kratos::AdjointLocalStressResponseFunction::AdjointLocalStressResponseFunction ( ModelPart rModelPart,
Parameters  ResponseSettings 
)

Default constructor.

◆ ~AdjointLocalStressResponseFunction()

Kratos::AdjointLocalStressResponseFunction::~AdjointLocalStressResponseFunction ( )
override

Destructor.

Member Function Documentation

◆ CalculateGradient() [1/2]

void Kratos::AdjointStructuralResponseFunction::CalculateGradient
override

◆ CalculateGradient() [2/2]

void Kratos::AdjointLocalStressResponseFunction::CalculateGradient ( const Element rAdjointElement,
const Matrix rResidualGradient,
Vector rResponseGradient,
const ProcessInfo rProcessInfo 
)
overridevirtual

Calculate the local gradient w.r.t. primal solution.

Parameters
[in]rAdjointElementthe adjoint element.
[in]rResidualGradientthe transposed gradient of the element's residual w.r.t. primal.
[out]rResponseGradientthe gradient of the response function.
[in]rProcessInfothe current process info.

Reimplemented from Kratos::AdjointResponseFunction.

◆ CalculatePartialSensitivity() [1/4]

void Kratos::AdjointLocalStressResponseFunction::CalculatePartialSensitivity ( Condition rAdjointCondition,
const Variable< array_1d< double, 3 >> &  rVariable,
const Matrix rSensitivityMatrix,
Vector rSensitivityGradient,
const ProcessInfo rProcessInfo 
)
overridevirtual

Calculate the partial sensitivity w.r.t. design variable.

Parameters
[in]rAdjointConditionthe adjoint condition.
[in]rVariablethe design variable.
[in]rSensitivityMatrixthe transposed gradient of the condition's residual w.r.t. design variable.
[out]rSensitivityGradientthe gradient of the response function.
[in]rProcessInfothe current process info.

Reimplemented from Kratos::AdjointResponseFunction.

◆ CalculatePartialSensitivity() [2/4]

void Kratos::AdjointLocalStressResponseFunction::CalculatePartialSensitivity ( Condition rAdjointCondition,
const Variable< double > &  rVariable,
const Matrix rSensitivityMatrix,
Vector rSensitivityGradient,
const ProcessInfo rProcessInfo 
)
overridevirtual

Calculate the partial sensitivity w.r.t. design variable.

Parameters
[in]rAdjointConditionthe adjoint condition.
[in]rVariablethe design variable.
[in]rSensitivityMatrixthe transposed gradient of the condition's residual w.r.t. design variable.
[out]rSensitivityGradientthe gradient of the response function.
[in]rProcessInfothe current process info.

Reimplemented from Kratos::AdjointResponseFunction.

◆ CalculatePartialSensitivity() [3/4]

void Kratos::AdjointLocalStressResponseFunction::CalculatePartialSensitivity ( Element rAdjointElement,
const Variable< array_1d< double, 3 >> &  rVariable,
const Matrix rSensitivityMatrix,
Vector rSensitivityGradient,
const ProcessInfo rProcessInfo 
)
overridevirtual

Calculate the partial sensitivity w.r.t. design variable.

Parameters
[in]rAdjointElementthe adjoint element.
[in]rVariablethe design variable.
[in]rSensitivityMatrixthe transposed gradient of the element's residual w.r.t. design variable.
[out]rSensitivityGradientthe gradient of the response function.
[in]rProcessInfothe current process info.

Reimplemented from Kratos::AdjointResponseFunction.

◆ CalculatePartialSensitivity() [4/4]

void Kratos::AdjointLocalStressResponseFunction::CalculatePartialSensitivity ( Element rAdjointElement,
const Variable< double > &  rVariable,
const Matrix rSensitivityMatrix,
Vector rSensitivityGradient,
const ProcessInfo rProcessInfo 
)
overridevirtual

Calculate the partial sensitivity w.r.t. design variable.

Parameters
[in]rAdjointElementthe adjoint element.
[in]rVariablethe design variable.
[in]rSensitivityMatrixthe transposed gradient of the element's residual w.r.t. design variable.
[out]rSensitivityGradientthe gradient of the response function.
[in]rProcessInfothe current process info.

Reimplemented from Kratos::AdjointResponseFunction.

◆ CalculateValue()

double Kratos::AdjointLocalStressResponseFunction::CalculateValue ( ModelPart rModelPart)
overridevirtual

Calculate the scalar valued response function.

Reimplemented from Kratos::AdjointStructuralResponseFunction.

◆ FinalizeSolutionStep()

void Kratos::AdjointLocalStressResponseFunction::FinalizeSolutionStep ( )
overridevirtual

Reimplemented from Kratos::AdjointResponseFunction.

◆ KRATOS_CLASS_POINTER_DEFINITION()

Kratos::AdjointLocalStressResponseFunction::KRATOS_CLASS_POINTER_DEFINITION ( AdjointLocalStressResponseFunction  )

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