![]() |
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.
|
This class implements a set of auxiliar, already parallelized, methods to perform some common tasks related with the variable values and fixity. More...
#include <variable_utils.h>
Public Member Functions | |
template<> | |
void | AuxiliaryHistoricalValueSetter (const Variable< array_1d< double, 3 >> &rVariable, const array_1d< double, 3 > &rValue, NodeType &rNode) |
Type Definitions | |
typedef ModelPart::NodeType | NodeType |
The node type. More... | |
typedef ModelPart::ConditionType | ConditionType |
The condition type. More... | |
typedef ModelPart::ElementType | ElementType |
The element type. More... | |
typedef ModelPart::NodesContainerType | NodesContainerType |
The nodes container. More... | |
typedef ModelPart::ConditionsContainerType | ConditionsContainerType |
The conditions container. More... | |
typedef ModelPart::ElementsContainerType | ElementsContainerType |
The elements container. More... | |
typedef Variable< double > | DoubleVarType |
A definition of the double variable. More... | |
typedef Variable< array_1d< double, 3 > > | ArrayVarType |
A definition of the array variable. More... | |
KRATOS_CLASS_POINTER_DEFINITION (VariableUtils) | |
We create the Pointer related to VariableUtils. More... | |
Operations | |
template<class TVarType > | |
void | CopyModelPartNodalVar (const TVarType &rVariable, const TVarType &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const unsigned int ReadBufferStep, const unsigned int WriteBufferStep) |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes. More... | |
template<class TVarType > | |
void | CopyModelPartNodalVar (const TVarType &rVariable, const TVarType &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const unsigned int BuffStep=0) |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes. More... | |
template<class TVarType > | |
void | CopyModelPartNodalVar (const TVarType &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const unsigned int BuffStep=0) |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes. More... | |
template<class TVarType > | |
void | CopyModelPartNodalVarToNonHistoricalVar (const TVarType &rVariable, const TVarType &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const unsigned int BuffStep=0) |
template<class TVarType > | |
void | CopyModelPartNodalVarToNonHistoricalVar (const TVarType &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const unsigned int BuffStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToHistoricalVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int ReadBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToHistoricalVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToHistoricalVar (const Variable< TDataType > &rVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true, const unsigned int WriteBufferStep=0) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedNodalNonHistoricalVarToNonHistoricalVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedElementVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedElementVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedElementVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedConditionVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedConditionVar (const Variable< TDataType > &rOriginVariable, const Variable< TDataType > &rDestinationVariable, ModelPart &rModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TDataType > | |
void | CopyModelPartFlaggedConditionVar (const Variable< TDataType > &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart, const Flags &rFlag, const bool CheckValue=true) |
template<class TVarType > | |
void | CopyModelPartElementalVar (const TVarType &rVariable, const ModelPart &rOriginModelPart, ModelPart &rDestinationModelPart) |
Copies the elemental value of a variable from an origin model part elements to the elements in a destination model part. It is assumed that both origin and destination model parts have the same number of elements. More... | |
template<class TDataType , class TVarType = Variable<TDataType>> | |
void | SetVariable (const TVarType &rVariable, const TDataType &rValue, NodesContainerType &rNodes, const unsigned int Step=0) |
Sets the nodal value of a scalar variable. More... | |
template<class TDataType , class TVarType = Variable<TDataType>> | |
void | SetVariable (const TVarType &rVariable, const TDataType &rValue, NodesContainerType &rNodes, const Flags Flag, const bool CheckValue=true) |
Sets the nodal value of a scalar variable (considering flag) More... | |
template<class TType , class TContainerType > | |
void | SetNonHistoricalVariableToZero (const Variable< TType > &rVariable, TContainerType &rContainer) |
Sets the nodal value of any variable to zero. More... | |
template<class TType > | |
void | SetHistoricalVariableToZero (const Variable< TType > &rVariable, NodesContainerType &rNodes) |
Sets the nodal value of any variable to zero. More... | |
template<class TType , class TContainerType , class TVarType = Variable< TType >> | |
void | SetNonHistoricalVariable (const TVarType &rVariable, const TType &Value, TContainerType &rContainer) |
Sets the container value of any type of non historical variable. More... | |
template<class TType , class TContainerType , class TVarType = Variable< TType >> | |
void | SetNonHistoricalVariable (const TVarType &rVariable, const TType &rValue, TContainerType &rContainer, const Flags Flag, const bool Check=true) |
Sets the container value of any type of non historical variable (considering flag) More... | |
template<class TContainerType , class TVarType > | |
void | EraseNonHistoricalVariable (const TVarType &rVariable, TContainerType &rContainer) |
Erases the container non historical variable. More... | |
template<class TContainerType > | |
void | ClearNonHistoricalData (TContainerType &rContainer) |
Clears the container data value container. More... | |
template<class TDataType , class TContainerType , class TWeightDataType > | |
void | WeightedAccumulateVariableOnNodes (ModelPart &rModelPart, const Variable< TDataType > &rVariable, const Variable< TWeightDataType > &rWeightVariable, const bool IsInverseWeightProvided=false) |
Distributes variable values in TContainerType container to nodes. More... | |
template<class TContainerType > | |
void | SetFlag (const Flags &rFlag, const bool FlagValue, TContainerType &rContainer) |
Sets a flag according to a given status over a given container. More... | |
template<class TContainerType > | |
void | ResetFlag (const Flags &rFlag, TContainerType &rContainer) |
Flips a flag over a given container. More... | |
template<class TContainerType > | |
void | FlipFlag (const Flags &rFlag, TContainerType &rContainer) |
Flips a flag over a given container. More... | |
template<class TDataType , class TVariableType = Variable<TDataType>> | |
void | SaveVariable (const TVariableType &rOriginVariable, const TVariableType &rSavedVariable, NodesContainerType &rNodesContainer) |
Takes the value of a non-historical variable and saves it in another variable For a nodal container, this takes the value of a non-historical variable and saves it in another one. More... | |
template<class TDataType , class TContainerType , class TVariableType = Variable<TDataType>> | |
void | SaveNonHistoricalVariable (const TVariableType &rOriginVariable, const TVariableType &rSavedVariable, TContainerType &rContainer) |
Takes the value of a non-historical variable and saves it in another historical variable For a non-nodal container, this method takes the value of an origin variable and saves it in a destination one. More... | |
template<class TDataType , class TVariableType = Variable<TDataType>> | |
void | CopyVariable (const TVariableType &rOriginVariable, const TVariableType &rDestinationVariable, NodesContainerType &rNodesContainer) |
Takes the value of an historical variable and sets it in another variable This function takes the value of an historical variable and sets in another variable in all the nodes of the provided container. More... | |
NodesContainerType | SelectNodeList (const DoubleVarType &Variable, const double Value, const NodesContainerType &rOriginNodes) |
Returns a list of nodes filtered using the given double variable and value. More... | |
template<class TVarType > | |
int | CheckVariableExists (const TVarType &rVariable, const NodesContainerType &rNodes) |
Checks if all the nodes of a node set has the specified variable. More... | |
template<class TVarType > | |
void | ApplyFixity (const TVarType &rVar, const bool IsFixed, NodesContainerType &rNodes) |
Fixes or frees a variable for all of the nodes in the list. The dof has to exist. More... | |
template<class TVarType > | |
void | ApplyFixity (const TVarType &rVariable, const bool IsFixed, NodesContainerType &rNodes, const Flags &rFlag, const bool CheckValue=true) |
Fixes/Frees dofs based on a flag. More... | |
template<class TVarType > | |
void | ApplyVector (const TVarType &rVar, const Vector &rData, NodesContainerType &rNodes) |
Loops along a vector data to set its values to the nodes contained in a node set. More... | |
array_1d< double, 3 > | SumNonHistoricalNodeVectorVariable (const ArrayVarType &rVar, const ModelPart &rModelPart) |
Returns the nodal value summation of a non-historical vector variable. More... | |
template<class TVarType > | |
double | SumNonHistoricalNodeScalarVariable (const TVarType &rVar, const ModelPart &rModelPart) |
Returns the nodal value summation of a non-historical scalar variable. More... | |
template<class TDataType , class TVarType = Variable<TDataType>> | |
TDataType | SumHistoricalVariable (const TVarType &rVariable, const ModelPart &rModelPart, const unsigned int BuffStep=0) |
This method accumulates and return a variable value For a nodal historical variable, this method accumulates and returns the summation in a model part. More... | |
array_1d< double, 3 > | SumConditionVectorVariable (const ArrayVarType &rVar, const ModelPart &rModelPart) |
Returns the condition value summation of a historical vector variable. More... | |
template<class TVarType > | |
double | SumConditionScalarVariable (const TVarType &rVar, const ModelPart &rModelPart) |
Returns the condition value summation of a historical scalar variable. More... | |
array_1d< double, 3 > | SumElementVectorVariable (const ArrayVarType &rVar, const ModelPart &rModelPart) |
Returns the element value summation of a historical vector variable. More... | |
template<class TVarType > | |
double | SumElementScalarVariable (const TVarType &rVar, const ModelPart &rModelPart) |
Returns the element value summation of a historical scalar variable. More... | |
template<class TVarType > | |
void | AddDof (const TVarType &rVar, ModelPart &rModelPart) |
This function add dofs to the nodes in a model part. It is useful since addition is done in parallel. More... | |
template<class TVarType > | |
void | AddDofWithReaction (const TVarType &rVar, const TVarType &rReactionVar, ModelPart &rModelPart) |
This function add dofs to the nodes in a model part. It is useful since addition is done in parallel. More... | |
bool | CheckVariableKeys () |
This method checks the variable keys. More... | |
void | UpdateCurrentToInitialConfiguration (const ModelPart::NodesContainerType &rNodes) |
This method updates the current nodal coordinates back to the initial coordinates. More... | |
void | UpdateInitialToCurrentConfiguration (const ModelPart::NodesContainerType &rNodes) |
This method updates the initial nodal coordinates to the current coordinates. More... | |
void | UpdateCurrentPosition (const ModelPart::NodesContainerType &rNodes, const ArrayVarType &rUpdateVariable=DISPLACEMENT, const IndexType BufferPosition=0) |
This method updates the current coordinates For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value. More... | |
template<class TVectorType = Vector> | |
TVectorType | GetCurrentPositionsVector (const ModelPart::NodesContainerType &rNodes, const unsigned int Dimension) |
This function returns the CURRENT coordinates of all the nodes in a consecutive vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the vector is in the form (X X X ....) in case Dimension == 2 the vector is in the form (X Y X Y X Y ....) in case Dimension == 3 the vector is in the form (X Y Z X Y Z ....) More... | |
template<class TVectorType = Vector> | |
TVectorType | GetInitialPositionsVector (const ModelPart::NodesContainerType &rNodes, const unsigned int Dimension) |
This function returns the INITIAL coordinates of all the nodes in a consecutive vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the vector is in the form (X0 X0 X0 ....) in case Dimension == 2 the vector is in the form (X0 Y0 X0 Y0 X0 Y0 ....) in case Dimension == 3 the vector is in the form (X0 Y0 Z0 X0 Y0 Z0 ....) More... | |
void | SetCurrentPositionsVector (ModelPart::NodesContainerType &rNodes, const Vector &rPositions) |
This function represent the "set" counterpart of GetCurrentPositionsVector and allows setting the CURRENT coordinates of all the nodes considering them stored in a consecutive 1D vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X, Y, Z) plus such variable value in case Dimension == 1 the expected input vector is in the form (X X X ....) in case Dimension == 2 the expected input vector is in the form (X Y X Y X Y ....) in case Dimension == 3 the expected input vector is in the form (X Y Z X Y Z ....) More... | |
void | SetInitialPositionsVector (ModelPart::NodesContainerType &rNodes, const Vector &rPositions) |
This function represent the "set" counterpart of GetInitialPositionsVector and allows setting the INITIAL coordinates of all the nodes considering them stored in a consecutive 1D vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the expected input vector is in the form (X0 X0 X0 ....) in case Dimension == 2 the expected input vector is in the form (X0 Y0 X0 Y0 X0 Y0 ....) in case Dimension == 3 the expected input vector is in the form (X0 Y0 Z0 X0 Y0 Z0 ....) More... | |
Vector | GetSolutionStepValuesVector (const ModelPart::NodesContainerType &rNodes, const Variable< array_1d< double, 3 >> &rVar, const unsigned int Step, const unsigned int Dimension=3) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once. More... | |
Vector | GetSolutionStepValuesVector (const ModelPart::NodesContainerType &rNodes, const Variable< double > &rVar, const unsigned int Step) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with SCALAR VARIABLES (of type Variable<double>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once. More... | |
void | SetSolutionStepValuesVector (ModelPart::NodesContainerType &rNodes, const Variable< array_1d< double, 3 >> &rVar, const Vector &rData, const unsigned int Step) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) More... | |
void | SetSolutionStepValuesVector (ModelPart::NodesContainerType &rNodes, const Variable< double > &rVar, const Vector &rData, const unsigned int Step) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with SCALAR VARIABLES (of type Variable<double>) More... | |
Vector | GetValuesVector (const ModelPart::NodesContainerType &rNodes, const Variable< array_1d< double, 3 >> &rVar, const unsigned int Dimension=3) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once also note that this version accesses NON HISTORICAL data. More... | |
Vector | GetValuesVector (const ModelPart::NodesContainerType &rNodes, const Variable< double > &rVar) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with SCALAR VARIABLES (of type Variable<double>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once also note that this version accesses NON HISTORICAL data. More... | |
void | SetValuesVector (ModelPart::NodesContainerType &rNodes, const Variable< array_1d< double, 3 >> &rVar, const Vector &rData) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) also note that this version accesses NON HISTORICAL data. More... | |
void | SetValuesVector (ModelPart::NodesContainerType &rNodes, const Variable< double > &rVar, const Vector &rData) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with SCALAR VARIABLES (of type Variable<double>) also note that this version accesses NON HISTORICAL data. More... | |
template<class TContainerType , class... TVariableArgs> | |
static void | SetNonHistoricalVariablesToZero (TContainerType &rContainer, const TVariableArgs &... rVariableArgs) |
Set the Non Historical Variables To Zero This method sets the provided list of variables to zero in the non-historical database. More... | |
template<class... TVariableArgs> | |
static void | SetHistoricalVariablesToZero (NodesContainerType &rNodes, const TVariableArgs &... rVariableArgs) |
Set the Historical Variables To Zero This method sets the provided list of variables to zero in the nodal historical database. More... | |
static void | AddDofsList (const std::vector< std::string > &rDofsVarNamesList, ModelPart &rModelPart) |
Add a list of DOFs to the nodes Provided a list with the DOFs variable names, this method adds such variables as DOFs to the nodes of the given model part. Note that the addition is performed at once. More... | |
static void | AddDofsWithReactionsList (const std::vector< std::array< std::string, 2 >> &rDofsAndReactionsNamesList, ModelPart &rModelPart) |
Add a list of DOFs to the nodes Provided a list with the DOFs and reactions variable names, this method adds such variables as DOFs and reaction to the nodes of the given model part. Note that the addition is performed at once. More... | |
template<Globals::DataLocation TLocation, class TEntity , class TValue > | |
static bool | HasValue (const TEntity &rEntity, const Variable< TValue > &rVariable) |
Check whether a Node, Element, Condition, ProcessInfo, or ModelPart stores a value for the provided Variable. More... | |
template<Globals::DataLocation TLocation, class TEntity , class TValue > | |
static std::conditional_t< std::is_arithmetic_v< TValue >, TValue, const TValue & > | GetValue (const TEntity &rEntity, const Variable< TValue > &rVariable) |
Fetch the value of a variable stored in an entity. More... | |
template<Globals::DataLocation TLocation, class TEntity , class TValue > | |
static TValue & | GetValue (TEntity &rEntity, const Variable< TValue > &rVariable) |
Fetch the value of a variable stored in an entity. More... | |
template<Globals::DataLocation TLocation, class TEntity , class TValue > | |
static void | SetValue (TEntity &rEntity, const Variable< TValue > &rVariable, std::conditional_t< std::is_arithmetic_v< TValue >, TValue, const TValue & > Value) |
Overwrite the value of a variable stored in an entity. More... | |
This class implements a set of auxiliar, already parallelized, methods to perform some common tasks related with the variable values and fixity.
The methods are exported to python in order to add this improvements to the python interface
typedef Variable< array_1d<double, 3 > > Kratos::VariableUtils::ArrayVarType |
A definition of the array variable.
The conditions container.
The condition type.
typedef Variable< double > Kratos::VariableUtils::DoubleVarType |
A definition of the double variable.
The elements container.
The element type.
The nodes container.
The node type.
|
inline |
This function add dofs to the nodes in a model part. It is useful since addition is done in parallel.
rVar | The variable to be added as DoF |
rModelPart | reference to the model part that contains the objective element set |
|
static |
Add a list of DOFs to the nodes Provided a list with the DOFs variable names, this method adds such variables as DOFs to the nodes of the given model part. Note that the addition is performed at once.
rDofsVarNamesList | List with the string variable names to be added as DOFs |
rModelPart | Model part to which the DOFs are added |
|
static |
Add a list of DOFs to the nodes Provided a list with the DOFs and reactions variable names, this method adds such variables as DOFs and reaction to the nodes of the given model part. Note that the addition is performed at once.
rDofsAndReactionsNamesList | List with the DOF and reaction string variable names to be added as DOFs and reaction |
rModelPart | Model part to which the DOFs are added |
|
inline |
This function add dofs to the nodes in a model part. It is useful since addition is done in parallel.
rVar | The variable to be added as DoF |
rReactionVar | The corresponding reaction to the added DoF |
rModelPart | reference to the model part that contains the objective element set |
|
inline |
Fixes or frees a variable for all of the nodes in the list. The dof has to exist.
rVar | reference to the variable to be fixed or freed |
IsFixed | if true fixes, if false frees |
rNodes | reference to the nodes set to be frixed or freed |
|
inline |
Fixes/Frees dofs based on a flag.
This method fixes/frees given rVariable, if rFlag matches CheckValue provided for that specific node.
TVarType | Variable type |
rVariable | Variable to be fixed or freed |
IsFixed | True to fix variable, false to free variable |
rNodes | Nodes container |
rFlag | Flag to be checked to fix or free |
CheckValue | Flag value which is checked against |
|
inline |
Loops along a vector data to set its values to the nodes contained in a node set.
rVar | reference to the variable to be fixed or freed |
rData | rData vector. Note that its lenght must equal the number of nodes |
rNodes | reference to the nodes set to be set |
void Kratos::VariableUtils::AuxiliaryHistoricalValueSetter | ( | const Variable< array_1d< double, 3 >> & | rVariable, |
const array_1d< double, 3 > & | rValue, | ||
NodeType & | rNode | ||
) |
|
inline |
Checks if all the nodes of a node set has the specified variable.
rVariable | reference to a variable to be checked |
rNodes | reference to the nodes set to be checked |
bool Kratos::VariableUtils::CheckVariableKeys | ( | ) |
This method checks the variable keys.
|
inline |
Clears the container data value container.
rContainer | Reference to the objective container |
|
inline |
Copies the elemental value of a variable from an origin model part elements to the elements in a destination model part. It is assumed that both origin and destination model parts have the same number of elements.
rVariable | reference to the variable to be set |
rOriginModelPart | origin model part from where the values are retrieved |
rDestinationModelPart | destination model part to where the values are copied to |
BuffStep | buffer step |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes.
rVariable | reference to the variable to get the value from and to save in |
rOriginModelPart | origin model part from where the values are retrieved |
rDestinationModelPart | destination model part to where the values are copied to |
BuffStep | buffer step |
|
inline |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes.
rVariable | reference to the variable to get the value from |
rDestinationVariable | reference to the variable to be set |
rOriginModelPart | origin model part from where the values are retrieved |
rDestinationModelPart | destination model part to where the values are copied to |
BuffStep | buffer step |
|
inline |
Copies the nodal value of a variable from an origin model part nodes to the nodes in a destination model part. It is assumed that both origin and destination model parts have the same number of nodes.
rVariable | reference to the variable to get the value from |
rDestinationVariable | reference to the variable to be set |
rOriginModelPart | origin model part from where the values are retrieved |
rDestinationModelPart | destination model part to where the values are copied to |
ReadBufferStep | origin buffer step |
WriteBufferStep | destination buffer step |
|
inline |
|
inline |
|
inline |
Takes the value of an historical variable and sets it in another variable This function takes the value of an historical variable and sets in another variable in all the nodes of the provided container.
TDataType | The variable data type |
Variable<TDataType> | The variable type |
rOriginVariable | Reference to the origin variable |
rDestinationVariable | Reference to the destination variable |
rNodesContainer | Reference to the nodes container |
|
inline |
Erases the container non historical variable.
rVariable | reference to the scalar variable to be erased |
rContainer | Reference to the objective container |
|
inline |
Flips a flag over a given container.
rFlag | flag to be set |
rContainer | Reference to the objective container |
template Vector Kratos::VariableUtils::GetCurrentPositionsVector< Vector > | ( | const ModelPart::NodesContainerType & | rNodes, |
const unsigned int | Dimension | ||
) |
This function returns the CURRENT coordinates of all the nodes in a consecutive vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the vector is in the form (X X X ....) in case Dimension == 2 the vector is in the form (X Y X Y X Y ....) in case Dimension == 3 the vector is in the form (X Y Z X Y Z ....)
rNodes | array of nodes from which coordinates will be extracted |
Dimension | number of desired components |
template Vector Kratos::VariableUtils::GetInitialPositionsVector< Vector > | ( | const ModelPart::NodesContainerType & | rNodes, |
const unsigned int | Dimension | ||
) |
This function returns the INITIAL coordinates of all the nodes in a consecutive vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the vector is in the form (X0 X0 X0 ....) in case Dimension == 2 the vector is in the form (X0 Y0 X0 Y0 X0 Y0 ....) in case Dimension == 3 the vector is in the form (X0 Y0 Z0 X0 Y0 Z0 ....)
rNodes | array of nodes from which coordinates will be extracted |
Dimension | number of desired components |
Vector Kratos::VariableUtils::GetSolutionStepValuesVector | ( | const ModelPart::NodesContainerType & | rNodes, |
const Variable< array_1d< double, 3 >> & | rVar, | ||
const unsigned int | Step, | ||
const unsigned int | Dimension = 3 |
||
) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
Step | step in the database |
Dimension | number of components in output |
Vector Kratos::VariableUtils::GetSolutionStepValuesVector | ( | const ModelPart::NodesContainerType & | rNodes, |
const Variable< double > & | rVar, | ||
const unsigned int | Step | ||
) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with SCALAR VARIABLES (of type Variable<double>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
Step | step in the database |
|
inlinestatic |
|
inlinestatic |
Vector Kratos::VariableUtils::GetValuesVector | ( | const ModelPart::NodesContainerType & | rNodes, |
const Variable< array_1d< double, 3 >> & | rVar, | ||
const unsigned int | Dimension = 3 |
||
) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once also note that this version accesses NON HISTORICAL data.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
Step | step in the database |
Dimension | number of components in output |
Vector Kratos::VariableUtils::GetValuesVector | ( | const ModelPart::NodesContainerType & | rNodes, |
const Variable< double > & | rVar | ||
) |
This function allows getting the database entries corresponding to rVar contained on all rNodes flattened so that the components of interest appear in the output vector. This version works with SCALAR VARIABLES (of type Variable<double>) In case Dimension is 1 one would obtain only the first component, for Dimension 2 the x and y component and for Dimension==3 the 3 components at once also note that this version accesses NON HISTORICAL data.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
Step | step in the database |
Kratos::VariableUtils::KRATOS_CLASS_POINTER_DEFINITION | ( | VariableUtils | ) |
We create the Pointer related to VariableUtils.
|
inline |
Flips a flag over a given container.
rFlag | flag to be set |
rContainer | Reference to the objective container |
|
inline |
Takes the value of a non-historical variable and saves it in another historical variable For a non-nodal container, this method takes the value of an origin variable and saves it in a destination one.
TDataType | The variable data type |
TContainerType | The container type |
Variable<TDataType> | The variable type |
rOriginVariable | Reference to the origin variable |
rSavedVariable | Reference to the destination variable |
rContainer | Reference to the container of interest |
|
inline |
Takes the value of a non-historical variable and saves it in another variable For a nodal container, this takes the value of a non-historical variable and saves it in another one.
TDataType | The variable data type |
Variable<TDataType> | The variable type |
rOriginVariable | Reference to the origin variable |
rSavedVariable | Reference to the destination variable |
rNodesContainer | Reference to the nodal container |
ModelPart::NodesContainerType Kratos::VariableUtils::SelectNodeList | ( | const DoubleVarType & | Variable, |
const double | Value, | ||
const NodesContainerType & | rOriginNodes | ||
) |
Returns a list of nodes filtered using the given double variable and value.
Variable | reference to the double variable to be filtered |
Value | Filtering Value |
rOriginNodes | Reference to the objective node set |
void Kratos::VariableUtils::SetCurrentPositionsVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Vector & | rPositions | ||
) |
This function represent the "set" counterpart of GetCurrentPositionsVector and allows setting the CURRENT coordinates of all the nodes considering them stored in a consecutive 1D vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X, Y, Z) plus such variable value in case Dimension == 1 the expected input vector is in the form (X X X ....) in case Dimension == 2 the expected input vector is in the form (X Y X Y X Y ....) in case Dimension == 3 the expected input vector is in the form (X Y Z X Y Z ....)
rNodes | array of nodes from which coordinates will be extracted |
rPositions | vector containing the CURRENT positions |
|
inline |
Sets a flag according to a given status over a given container.
rFlag | flag to be set |
FlagValue | flag value to be set |
rContainer | Reference to the objective container |
|
inlinestatic |
Set the Historical Variables To Zero This method sets the provided list of variables to zero in the nodal historical database.
TVariableArgs | Variadic template argument representing the variables types |
rNodes | Nodes container to be initialized to zero |
rVariableArgs | Variables to be set to zero |
|
inline |
Sets the nodal value of any variable to zero.
rVariable | reference to the scalar variable to be set |
rNodes | reference to the objective node set |
void Kratos::VariableUtils::SetInitialPositionsVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Vector & | rPositions | ||
) |
This function represent the "set" counterpart of GetInitialPositionsVector and allows setting the INITIAL coordinates of all the nodes considering them stored in a consecutive 1D vector. it allows working in 1D,2D or 3D For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value in case Dimension == 1 the expected input vector is in the form (X0 X0 X0 ....) in case Dimension == 2 the expected input vector is in the form (X0 Y0 X0 Y0 X0 Y0 ....) in case Dimension == 3 the expected input vector is in the form (X0 Y0 Z0 X0 Y0 Z0 ....)
rNodes | array of nodes from which coordinates will be extracted |
rPositions | vector containing the INITIAL positions |
|
inline |
Sets the container value of any type of non historical variable (considering flag)
rVariable | reference to the scalar variable to be set |
Value | Value to be set |
rContainer | Reference to the objective container |
Flag | The flag to be considered in the assignation |
Check | What is checked from the flag |
|
inline |
Sets the container value of any type of non historical variable.
rVariable | reference to the scalar variable to be set |
Value | Value to be set |
rContainer | Reference to the objective container |
|
inlinestatic |
Set the Non Historical Variables To Zero This method sets the provided list of variables to zero in the non-historical database.
TContainerType | Container type (nodes, elements or conditions) |
TVariableArgs | Variadic template argument representing the variables types |
rContainer | Container to be initialized to zero |
rVariableArgs | Variables to be set to zero |
|
inline |
Sets the nodal value of any variable to zero.
rVariable | reference to the scalar variable to be set |
rContainer | reference to the objective container |
void Kratos::VariableUtils::SetSolutionStepValuesVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Variable< array_1d< double, 3 >> & | rVar, | ||
const Vector & | rData, | ||
const unsigned int | Step | ||
) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>)
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
rData | input vector (must be of size rNodes.size()*Dimension) |
Step | database step to which we will write |
void Kratos::VariableUtils::SetSolutionStepValuesVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Variable< double > & | rVar, | ||
const Vector & | rData, | ||
const unsigned int | Step | ||
) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with SCALAR VARIABLES (of type Variable<double>)
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
rData | input vector (must be of size rNodes.size()*Dimension) |
Step | database step to which we will write |
|
inlinestatic |
void Kratos::VariableUtils::SetValuesVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Variable< array_1d< double, 3 >> & | rVar, | ||
const Vector & | rData | ||
) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with VECTOR VARIABLES (of type Variable<array_1d<double,3>>) also note that this version accesses NON HISTORICAL data.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
rData | input vector (must be of size rNodes.size()*Dimension) |
Step | database step to which we will write |
void Kratos::VariableUtils::SetValuesVector | ( | ModelPart::NodesContainerType & | rNodes, |
const Variable< double > & | rVar, | ||
const Vector & | rData | ||
) |
This function allows setting the database entries corresponding to rVar contained on all rNodes given a flat array in which all the variable components are present consecutively. This version works with SCALAR VARIABLES (of type Variable<double>) also note that this version accesses NON HISTORICAL data.
rNodes | array of nodes from which data will be extracted |
rVar | the variable being addressed |
rData | input vector (must be of size rNodes.size()*Dimension) |
Step | database step to which we will write |
|
inline |
Sets the nodal value of a scalar variable (considering flag)
rVariable | reference to the scalar variable to be set |
rValue | Value to be set |
rNodes | reference to the objective node set |
Flag | The flag to be considered in the assignation |
Check | What is checked from the flag |
|
inline |
|
inline |
Returns the condition value summation of a historical scalar variable.
rVar | reference to the scalar variable to be summed |
rModelPart | reference to the model part that contains the objective condition set |
array_1d< double, 3 > Kratos::VariableUtils::SumConditionVectorVariable | ( | const ArrayVarType & | rVar, |
const ModelPart & | rModelPart | ||
) |
Returns the condition value summation of a historical vector variable.
rVar | reference to the vector variable to be summed |
rModelPart | reference to the model part that contains the objective condition set |
|
inline |
Returns the element value summation of a historical scalar variable.
rVar | reference to the scalar variable to be summed |
rModelPart | reference to the model part that contains the objective element set |
array_1d< double, 3 > Kratos::VariableUtils::SumElementVectorVariable | ( | const ArrayVarType & | rVar, |
const ModelPart & | rModelPart | ||
) |
Returns the element value summation of a historical vector variable.
rVar | reference to the vector variable to be summed |
rModelPart | reference to the model part that contains the objective element set |
|
inline |
This method accumulates and return a variable value For a nodal historical variable, this method accumulates and returns the summation in a model part.
rVariable | Nodal historical variable to be accumulated |
rModelPart | Model part in where the summation is done |
BuffStep | Buffer position |
|
inline |
Returns the nodal value summation of a non-historical scalar variable.
rVar | reference to the scalar variable to be summed |
rModelPart | reference to the model part that contains the objective node set |
array_1d< double, 3 > Kratos::VariableUtils::SumNonHistoricalNodeVectorVariable | ( | const ArrayVarType & | rVar, |
const ModelPart & | rModelPart | ||
) |
Returns the nodal value summation of a non-historical vector variable.
rVar | reference to the vector variable to summed |
rModelPart | reference to the model part that contains the objective node set |
void Kratos::VariableUtils::UpdateCurrentPosition | ( | const ModelPart::NodesContainerType & | rNodes, |
const ArrayVarType & | rUpdateVariable = DISPLACEMENT , |
||
const IndexType | BufferPosition = 0 |
||
) |
This method updates the current coordinates For each node, this method takes the value of the provided variable and updates the current position as the initial position (X0, Y0, Z0) plus such variable value.
rNodes | |
rUpdateVariable | variable to retrieve the updating values from |
void Kratos::VariableUtils::UpdateCurrentToInitialConfiguration | ( | const ModelPart::NodesContainerType & | rNodes | ) |
This method updates the current nodal coordinates back to the initial coordinates.
rNodes | the nodes to be updated |
void Kratos::VariableUtils::UpdateInitialToCurrentConfiguration | ( | const ModelPart::NodesContainerType & | rNodes | ) |
This method updates the initial nodal coordinates to the current coordinates.
rNodes | the nodes to be updated |
template void Kratos::VariableUtils::WeightedAccumulateVariableOnNodes< array_1d< double, 3 >, ModelPart::ElementsContainerType, double > | ( | ModelPart & | rModelPart, |
const Variable< TDataType > & | rVariable, | ||
const Variable< TWeightDataType > & | rWeightVariable, | ||
const bool | IsInverseWeightProvided = false |
||
) |
Distributes variable values in TContainerType container to nodes.
This method distributes variables values stored in TContainerType data value container in rModelPart to nodes. Constant weighting is used for each node based on rWeightVariable value. The result is stored in nodal non-historical data value container under the same rVariable. If IsInverseWeightProvided is true, then the weights provided by rWeightVariable is inverted to get nodal weight. Otherwise, the value given by rWeightVariable is used as weight.
TDataType | Data type |
TContainerType | ContainerType of model part |
TWeightDataType | Data type of weight variable (this should be either int or double) |