13 #ifndef KRATOS_CONSERVATIVE_ELEMENT_RV_H_INCLUDED
14 #define KRATOS_CONSERVATIVE_ELEMENT_RV_H_INCLUDED
50 template<std::
size_t TNumNodes>
127 return Kratos::make_intrusive<ConservativeElementRV<TNumNodes>>(NewId, this->
GetGeometry().
Create(ThisNodes), pProperties);
137 Element::Pointer
Create(
IndexType NewId, GeometryType::Pointer pGeom,
typename PropertiesType::Pointer pProperties)
const override
139 return Kratos::make_intrusive<ConservativeElementRV<TNumNodes>>(NewId, pGeom, pProperties);
151 p_new_elem->SetData(this->
GetData());
152 p_new_elem->Set(
Flags(*
this));
163 std::string
Info()
const override
165 return "ConservativeElementRV";
190 double& rArtViscosity,
191 double& rArtDiffusion,
198 double& rHeightresidual,
213 void save(
Serializer& rSerializer)
const override
Implementation of a linear element for shallow water problems.
Definition: conservative_element.h:52
static constexpr IndexType mLocalSize
Definition: conservative_element.h:182
Implementation of a linear element for shallow water problems.
Definition: conservative_element_rv.h:52
ConservativeElement< TNumNodes > ConservativeElementType
Definition: conservative_element_rv.h:63
std::string Info() const override
Turn back information as a string.
Definition: conservative_element_rv.h:163
ConservativeElementType::PropertiesType PropertiesType
Definition: conservative_element_rv.h:69
Element::Pointer Clone(IndexType NewId, NodesArrayType const &ThisNodes) const override
Create a new element pointer and clone the previous element data.
Definition: conservative_element_rv.h:148
ConservativeElementRV()
Default constructor.
Definition: conservative_element_rv.h:92
KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(ConservativeElementRV)
ConservativeElementRV(IndexType NewId, GeometryType::Pointer pGeometry)
Constructor using Geometry.
Definition: conservative_element_rv.h:102
Node NodeType
Definition: conservative_element_rv.h:59
ConservativeElementType::LocalVectorType LocalVectorType
Definition: conservative_element_rv.h:75
void GetNodalData(ElementData &rData, const GeometryType &rGeometry, int Step=0) override
Definition: conservative_element_rv.cpp:30
std::size_t IndexType
Definition: conservative_element_rv.h:57
Element::Pointer Create(IndexType NewId, GeometryType::Pointer pGeom, typename PropertiesType::Pointer pProperties) const override
Create a new element pointer.
Definition: conservative_element_rv.h:137
void CalculateArtificialViscosity(BoundedMatrix< double, 3, 3 > &rViscosity, BoundedMatrix< double, 2, 2 > &rDiffusion, const ElementData &rData, const array_1d< double, TNumNodes > &rN, const BoundedMatrix< double, TNumNodes, 2 > &rDN_DX) override
Definition: conservative_element_rv.cpp:44
ConservativeElementRV(IndexType NewId, GeometryType::Pointer pGeometry, typename PropertiesType::Pointer pProperties)
Constructor using Geometry and Properties.
Definition: conservative_element_rv.h:107
void ShockCapturingParameters(double &rArtViscosity, double &rArtDiffusion, const ElementData &rData, const array_1d< double, TNumNodes > &rN, const BoundedMatrix< double, 3, 2 > &rDN_DX)
Definition: conservative_element_rv.cpp:67
~ ConservativeElementRV() override
Destructor.
Definition: conservative_element_rv.h:112
Geometry< NodeType > GeometryType
Definition: conservative_element_rv.h:61
ConservativeElementType::ElementData ElementData
Definition: conservative_element_rv.h:71
ConservativeElementType::NodesArrayType NodesArrayType
Definition: conservative_element_rv.h:67
ConservativeElementRV(IndexType NewId, const NodesArrayType &ThisNodes)
Constructor using an array of nodes.
Definition: conservative_element_rv.h:97
static constexpr IndexType mLocalSize
Definition: conservative_element_rv.h:174
void AlgebraicResidual(array_1d< double, 3 > &rFlowResidual, double &rHeightresidual, BoundedMatrix< double, 3, 3 > &rFlowGrad, array_1d< double, 3 > &rHeightGrad, const ElementData &rData, const array_1d< double, TNumNodes > &rN, const BoundedMatrix< double, 3, 2 > &rDN_DX)
Definition: conservative_element_rv.cpp:100
ConservativeElementType::LocalMatrixType LocalMatrixType
Definition: conservative_element_rv.h:73
ConservativeElementType::WaveElementType WaveElementType
Definition: conservative_element_rv.h:65
ConservativeElementType::ShapeFunctionsGradientsType ShapeFunctionsGradientsType
Definition: conservative_element_rv.h:77
Element::Pointer Create(IndexType NewId, NodesArrayType const &ThisNodes, typename PropertiesType::Pointer pProperties) const override
Create a new element pointer.
Definition: conservative_element_rv.h:125
Base class for all Elements.
Definition: element.h:60
PropertiesType::Pointer pGetProperties()
returns the pointer to the property of the element. Does not throw an error, to allow copying of elem...
Definition: element.h:1014
std::size_t IndexType
Definition: flags.h:74
Flags()
Default constructor.
Definition: flags.h:119
GeometryType & GetGeometry()
Returns the reference of the geometry.
Definition: geometrical_object.h:158
DataValueContainer & GetData()
Definition: geometrical_object.h:212
Geometry base class.
Definition: geometry.h:71
virtual Pointer Create(PointsArrayType const &rThisPoints) const
Creates a new geometry pointer.
Definition: geometry.h:813
Definition: amatrix_interface.h:41
This class defines the node.
Definition: node.h:65
PointerVector is a container like stl vector but using a vector to store pointers to its data.
Definition: pointer_vector.h:72
Properties encapsulates data shared by different Elements or Conditions. It can store any type of dat...
Definition: properties.h:69
The serialization consists in storing the state of an object into a storage format like data file or ...
Definition: serializer.h:123
Implementation of a linear element for shallow water problems.
Definition: wave_element.h:55
Short class definition.
Definition: array_1d.h:61
#define KRATOS_SERIALIZE_SAVE_BASE_CLASS(Serializer, BaseType)
Definition: define.h:812
#define KRATOS_SERIALIZE_LOAD_BASE_CLASS(Serializer, BaseType)
Definition: define.h:815
REF: G. R. Cowper, GAUSSIAN QUADRATURE FORMULAS FOR TRIANGLES.
Definition: mesh_condition.cpp:21
def load(f)
Definition: ode_solve.py:307
Definition: wave_element.h:299