![]() |
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.
|
#include <triangle_2d_3_ausas_incised_shape_functions.h>
Public Member Functions | |
Life Cycle | |
Triangle2D3AusasIncisedShapeFunctions (const GeometryPointerType rpInputGeometry, const Vector &rNodalDistancesWithExtrapolated, const Vector &rExtrapolatedEdgeRatios) | |
Default constructor. More... | |
~Triangle2D3AusasIncisedShapeFunctions () | |
Destructor. More... | |
Input and output | |
std::string | Info () const override |
Turn back information as a string. More... | |
void | PrintInfo (std::ostream &rOStream) const override |
Print information about this object. More... | |
void | PrintData (std::ostream &rOStream) const override |
Print object's data. More... | |
Operations | |
const Vector & | GetExtrapolatedEdgeRatios () const |
![]() | |
Triangle2D3AusasModifiedShapeFunctions (const GeometryPointerType rpInputGeometry, const Vector &rNodalDistances) | |
Default constructor. More... | |
~Triangle2D3AusasModifiedShapeFunctions () | |
Destructor. More... | |
std::string | Info () const override |
Turn back information as a string. More... | |
void | PrintInfo (std::ostream &rOStream) const override |
Print information about this object. More... | |
void | PrintData (std::ostream &rOStream) const override |
Print object's data. More... | |
const DivideGeometry< Node >::Pointer | pGetSplittingUtil () const override |
KRATOS_CLASS_POINTER_DEFINITION (Triangle2D3AusasModifiedShapeFunctions) | |
Pointer definition of Triangle2D3AusasModifiedShapeFunctions. More... | |
![]() | |
AusasModifiedShapeFunctions (const GeometryPointerType rpInputGeometry, const Vector &rNodalDistances) | |
Default constructor. More... | |
~AusasModifiedShapeFunctions () | |
Destructor. More... | |
KRATOS_CLASS_POINTER_DEFINITION (AusasModifiedShapeFunctions) | |
Pointer definition of AusasModifiedShapeFunctions. More... | |
![]() | |
ModifiedShapeFunctions (const GeometryPointerType pInputGeometry, const Vector &rNodalDistances) | |
Default constructor. More... | |
virtual | ~ModifiedShapeFunctions () |
Destructor. More... | |
const GeometryPointerType | GetInputGeometry () const |
const Vector & | GetNodalDistances () const |
double | ComputePositiveSideDomainSize () const |
Compute the positive domain size For the given input geometry, this method calculates the positive side volume (or area in 2D) More... | |
double | ComputeNegativeSideDomainSize () const |
Compute the negative domain size For the given input geometry, this method calculates the negative side volume (or area in 2D) More... | |
void | ComputePositiveSideShapeFunctionsAndWeights (Matrix &rPositiveSideShapeFunctionsValues, Vector &rPositiveSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputeNegativeSideShapeFunctionsAndWeights (Matrix &rNegativeSideShapeFunctionsValues, Vector &rNegativeSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputePositiveSideShapeFunctionsAndGradientsValues (Matrix &rPositiveSideShapeFunctionsValues, ShapeFunctionsGradientsType &rPositiveSideShapeFunctionsGradientsValues, Vector &rPositiveSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputeNegativeSideShapeFunctionsAndGradientsValues (Matrix &rNegativeSideShapeFunctionsValues, ShapeFunctionsGradientsType &rNegativeSideShapeFunctionsGradientsValues, Vector &rNegativeSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputeInterfacePositiveSideShapeFunctionsAndGradientsValues (Matrix &rInterfacePositiveSideShapeFunctionsValues, ShapeFunctionsGradientsType &rInterfacePositiveSideShapeFunctionsGradientsValues, Vector &rInterfacePositiveSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputeInterfaceNegativeSideShapeFunctionsAndGradientsValues (Matrix &rInterfaceNegativeSideShapeFunctionsValues, ShapeFunctionsGradientsType &rInterfaceNegativeSideShapeFunctionsGradientsValues, Vector &rInterfaceNegativeSideWeightsValues, const IntegrationMethodType IntegrationMethod) |
void | ComputePositiveExteriorFaceShapeFunctionsAndGradientsValues (Matrix &rPositiveExteriorFaceShapeFunctionsValues, ShapeFunctionsGradientsType &rPositiveExteriorFaceShapeFunctionsGradientsValues, Vector &rPositiveExteriorFaceWeightsValues, const unsigned int FaceId, const IntegrationMethodType IntegrationMethod) |
void | ComputeNegativeExteriorFaceShapeFunctionsAndGradientsValues (Matrix &rNegativeExteriorFaceShapeFunctionsValues, ShapeFunctionsGradientsType &rNegativeExteriorFaceShapeFunctionsGradientsValues, Vector &rNegativeExteriorFaceWeightsValues, const unsigned int FaceId, const IntegrationMethodType IntegrationMethod) |
void | ComputePositiveSideInterfaceAreaNormals (AreaNormalsContainerType &rPositiveSideInterfaceAreaNormal, const IntegrationMethodType IntegrationMethod) |
void | ComputeNegativeSideInterfaceAreaNormals (AreaNormalsContainerType &rNegativeSideInterfaceAreaNormal, const IntegrationMethodType IntegrationMethod) |
void | ComputePositiveExteriorFaceAreaNormals (AreaNormalsContainerType &rPositiveExteriorFaceAreaNormal, const unsigned int FaceId, const IntegrationMethodType IntegrationMethod) |
void | ComputeNegativeExteriorFaceAreaNormals (AreaNormalsContainerType &rNegativeExteriorFaceAreaNormal, const unsigned int FaceId, const IntegrationMethodType IntegrationMethod) |
void | ComputeShapeFunctionsOnPositiveEdgeIntersections (Matrix &rPositiveEdgeIntersectionsShapeFunctionsValues) |
void | ComputeShapeFunctionsOnNegativeEdgeIntersections (Matrix &rNegativeEdgeIntersectionsShapeFunctionsValues) |
bool | IsSplit () const |
KRATOS_CLASS_POINTER_DEFINITION (ModifiedShapeFunctions) | |
Pointer definition of ModifiedShapeFunctions. More... | |
Protected Member Functions | |
Protected Operations | |
void | SetPositiveSideCondensationMatrix (Matrix &rPosSideCondMatrix) override |
Set the Positive Side Condensation Matrix object This function sets the positive side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides. More... | |
void | SetNegativeSideCondensationMatrix (Matrix &rNegSideCondMatrix) override |
Set the Negative Side Condensation Matrix object This function sets the negative side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides. More... | |
void | SetPositiveSideCondensationMatrix (Matrix &rPosSideCondMatrix, const std::vector< int > &rEdgeNodeI, const std::vector< int > &rEdgeNodeJ, const std::vector< int > &rSplitEdges) |
void | SetNegativeSideCondensationMatrix (Matrix &rNegSideCondMatrix, const std::vector< int > &rEdgeNodeI, const std::vector< int > &rEdgeNodeJ, const std::vector< int > &rSplitEdges) |
![]() | |
void | SetPositiveSideCondensationMatrix (Matrix &rPosSideCondMatrix) override |
Set the Positive Side Condensation Matrix object This function sets the positive side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides. More... | |
void | SetNegativeSideCondensationMatrix (Matrix &rNegSideCondMatrix) override |
Set the Negative Side Condensation Matrix object This function sets the negative side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides. More... | |
![]() | |
void | SetCondensationMatrix (Matrix &rIntPointCondMatrix) override |
void | SetPositiveSideCondensationMatrix (Matrix &rPosSideCondMatrix, const std::vector< int > &rEdgeNodeI, const std::vector< int > &rEdgeNodeJ, const std::vector< int > &rSplitEdges) |
void | SetNegativeSideCondensationMatrix (Matrix &rNegSideCondMatrix, const std::vector< int > &rEdgeNodeI, const std::vector< int > &rEdgeNodeJ, const std::vector< int > &rSplitEdges) |
![]() | |
void | SetCondensationMatrix (Matrix &rIntPointCondMatrix, const std::vector< int > &rEdgeNodeI, const std::vector< int > &rEdgeNodeJ, const std::vector< int > &rSplitEdges) |
void | ComputeValuesOnOneSide (Matrix &rShapeFunctionsValues, ShapeFunctionsGradientsType &rShapeFunctionsGradientsValues, Vector &rWeightsValues, const std::vector< IndexedPointGeometryPointerType > &rSubdivisionsVector, const Matrix &rPmatrix, const IntegrationMethodType IntegrationMethod) |
void | ComputeFaceValuesOnOneSide (Matrix &rInterfaceShapeFunctionsValues, ShapeFunctionsGradientsType &rInterfaceShapeFunctionsGradientsValues, Vector &rInterfaceWeightsValues, const std::vector< IndexedPointGeometryPointerType > &rInterfacesVector, const std::vector< IndexedPointGeometryPointerType > &rParentGeometriesVector, const std::vector< unsigned int > &rInterfacesParentIdsVector, const Matrix &rPmatrix, const IntegrationMethodType IntegrationMethod) |
void | ComputeFaceNormalOnOneSide (AreaNormalsContainerType &rInterfaceAreaNormalValues, const std::vector< IndexedPointGeometryPointerType > &rInterfacesVector, const IntegrationMethodType IntegrationMethod) |
void | ComputeEdgeIntersectionValuesOnOneSide (const Matrix &rPmatrix, Matrix &rEdgeShapeFunctionValues) |
Protected Attributes | |
Protected member Variables | |
const std::array< size_t, 3 > | edge_id_for_geometry {{2, 0, 1}} |
const std::array< std::array< size_t, 2 >, 3 > | node_ids_for_geometry {{{{0,1}}, {{1,2}}, {{2,0}}}} |
![]() | |
DivideTriangle2D3< Node >::Pointer | mpTriangleSplitter |
Type Definitions | |
typedef AusasModifiedShapeFunctions | BaseType |
typedef BaseType::GeometryPointerType | GeometryPointerType |
KRATOS_CLASS_POINTER_DEFINITION (Triangle2D3AusasIncisedShapeFunctions) | |
Pointer definition of Triangle2D3AusasIncisedShapeFunctions. More... | |
typedef BaseType::GeometryPointerType Kratos::Triangle2D3AusasIncisedShapeFunctions::GeometryPointerType |
Kratos::Triangle2D3AusasIncisedShapeFunctions::Triangle2D3AusasIncisedShapeFunctions | ( | const GeometryPointerType | pInputGeometry, |
const Vector & | rNodalDistancesWithExtrapolated, | ||
const Vector & | rExtrapolatedEdgeRatios | ||
) |
Default constructor.
Triangle2D3AusasIncisedShapeFunctions implementation Default constructor
Kratos::Triangle2D3AusasIncisedShapeFunctions::~Triangle2D3AusasIncisedShapeFunctions | ( | ) |
Destructor.
const Vector & Kratos::Triangle2D3AusasIncisedShapeFunctions::GetExtrapolatedEdgeRatios | ( | ) | const |
Returns a reference to the extrapolated edge ratios vector member variable.
|
overridevirtual |
Turn back information as a string.
Reimplemented from Kratos::AusasModifiedShapeFunctions.
Kratos::Triangle2D3AusasIncisedShapeFunctions::KRATOS_CLASS_POINTER_DEFINITION | ( | Triangle2D3AusasIncisedShapeFunctions | ) |
Pointer definition of Triangle2D3AusasIncisedShapeFunctions.
|
overridevirtual |
Print object's data.
Reimplemented from Kratos::AusasModifiedShapeFunctions.
|
overridevirtual |
Print information about this object.
Reimplemented from Kratos::AusasModifiedShapeFunctions.
|
overrideprotectedvirtual |
Set the Negative Side Condensation Matrix object This function sets the negative side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides.
rNegSideCondMatrix | Negative side condensation matrix |
Reimplemented from Kratos::AusasModifiedShapeFunctions.
|
protected |
Returns the intersection points and extrapolated intersection points condensation matrix for negative side Ausas shape functions for incised elements. This matrix is used to transform the subdivisions shape funtion values to the original geometry ones. It has size (n_nodes+n_edges)x(n_nodes).
rNegSideCondMatrix | Reference to the (extrapolated) intersection points condensation matrix to be changed. |
rEdgeNodeI | Integers array containing the nodes "I" that conform the edges. |
rEdgeNodeJ | Integers array containing the nodes "J" that conform the edges. |
rSplitEdges | Integers array containing the original nodes ids and the intersected edges nodes ones. |
|
overrideprotectedvirtual |
Set the Positive Side Condensation Matrix object This function sets the positive side condensation matrix Note that for the Ausas FE space a different condensation matrix is required for the positive and negative sides.
rPosSideCondMatrix | Positive side condensation matrix |
Reimplemented from Kratos::AusasModifiedShapeFunctions.
|
protected |
Returns the intersection points and extrapolated intersection points condensation matrix for positive side Ausas shape functions for incised elements. This matrix is used to transform the subdivisions shape funtion values to the original geometry ones. It has size (n_nodes+n_edges)x(n_nodes).
rPosSideCondMatrix | Reference to the extrapolated) intersection points condensation matrix to be changed. |
rEdgeNodeI | Integers array containing the nodes "I" that conform the edges. |
rEdgeNodeJ | Integers array containing the nodes "J" that conform the edges. |
rSplitEdges | Integers array containing the original nodes ids and the intersected edges nodes ones. |
|
protected |
|
protected |