OOFEM 3.0
Loading...
Searching...
No Matches
oofem::RigidArmNode Class Reference

#include <rigidarmnode.h>

Inheritance diagram for oofem::RigidArmNode:
Collaboration diagram for oofem::RigidArmNode:

Public Member Functions

 RigidArmNode (int n, Domain *aDomain)
virtual ~RigidArmNode (void)
 Destructor.
void initializeFrom (InputRecord &ir, int priority) override
void postInitialize () override
 Performs post initialization steps. Called after all components are created and initialized.
void updateLocalNumbering (EntityRenumberingFunctor &f) override
int checkConsistency () override
void computeMasterContribution (std::map< DofIDItem, IntArray > &masterDofID, std::map< DofIDItem, FloatArray > &masterContribution)
const char * giveClassName () const override
const char * giveInputRecordName () const override
bool isDofTypeCompatible (dofType type) const override
 Returns true if dof of given type is allowed to be associated to receiver.
Public Member Functions inherited from oofem::Node
 Node (int n, Domain *aDomain)
void setCoordinates (FloatArray coords)
virtual double giveUpdatedCoordinate (int ic, TimeStep *tStep, double scale=1.)
virtual void giveUpdatedCoordinates (FloatArray &answer, TimeStep *tStep, double scale=1.)
bool hasLocalCS ()
 Returns nonzero if node has prescribed local coordinate system.
FloatMatrixgiveLocalCoordinateTriplet ()
bool hasSameLCS (Node *remote)
bool computeL2GTransformation (FloatMatrix &answer, const IntArray &dofIDArry) override
bool requiresTransformation () override
void computeLoadVector (FloatArray &answer, Load *load, CharType type, TimeStep *tStep, ValueModeType mode) override
void updateYourself (TimeStep *tStep) override
void initializeFrom (InputRecord &ir) override
void initializeFinish () override
 Performs post initialization steps.
void giveInputRecord (DynamicInputRecord &input) override
void printYourself () override
 Prints receiver state on stdout. Useful for debugging.
virtual int giveQcNodeType ()
void saveContext (DataStream &stream, ContextMode mode) override
void restoreContext (DataStream &stream, ContextMode mode) override
void drawYourself (oofegGraphicContext &gc, TimeStep *tStep) override
Public Member Functions inherited from oofem::DofManager
std::vector< Dof * >::iterator begin ()
std::vector< Dof * >::iterator end ()
std::vector< Dof * >::const_iterator begin () const
std::vector< Dof * >::const_iterator end () const
 DofManager (int n, Domain *aDomain)
virtual ~DofManager ()
 Destructor.
DofgiveDofWithID (int dofID) const
int giveNumberOfDofs () const
void askNewEquationNumbers (TimeStep *tStep)
 Renumbers all contained DOFs.
int giveNumberOfPrimaryMasterDofs (const IntArray &dofIDArray) const
void giveLocationArray (const IntArray &dofIDArry, IntArray &locationArray, const UnknownNumberingScheme &s) const
void giveMasterDofIDArray (const IntArray &dofIDArry, IntArray &masterDofIDs) const
void giveCompleteLocationArray (IntArray &locationArray, const UnknownNumberingScheme &s) const
void giveCompleteMasterDofIDArray (IntArray &dofIDArray) const
std::vector< Dof * >::const_iterator findDofWithDofId (DofIDItem dofID) const
void giveUnknownVector (FloatArray &answer, const IntArray &dofMask, ValueModeType mode, TimeStep *tStep, bool padding=false)
void giveUnknownVector (FloatArray &answer, const IntArray &dofMask, PrimaryField &field, ValueModeType mode, TimeStep *tStep, bool padding=false)
void giveCompleteUnknownVector (FloatArray &answer, ValueModeType mode, TimeStep *tStep)
void giveUnknownVectorOfType (FloatArray &answer, UnknownType ut, ValueModeType mode, TimeStep *tStep)
virtual void givePrescribedUnknownVector (FloatArray &answer, const IntArray &dofMask, ValueModeType mode, TimeStep *tStep)
bool computeM2GTransformation (FloatMatrix &answer, const IntArray &dofIDArry)
virtual bool computeM2LTransformation (FloatMatrix &answer, const IntArray &dofIDArry)
IntArraygiveLoadArray ()
void setLoadArray (IntArray &load)
double giveCoordinate (int i) const
const FloatArraygiveCoordinates () const
void setCoordinates (const FloatArray &coords)
 Set coordinates.
const IntArraygiveForcedDofIDs ()
std ::map< int, int > * giveDofTypeMap ()
std ::map< int, int > * giveMasterMap ()
std ::map< int, int > * giveBcMap ()
std ::map< int, int > * giveIcMap ()
void printOutputAt (FILE *file, TimeStep *tStep) override
bool isBoundary ()
void setBoundaryFlag (bool isBoundary)
virtual bool hasAnySlaveDofs ()
virtual bool giveMasterDofMans (IntArray &masters)
void setNumberOfDofs (int _ndofs)
void appendDof (Dof *dof)
void removeDof (DofIDItem id)
bool hasDofID (DofIDItem id) const
int giveGlobalNumber () const
int giveLabel () const
void setGlobalNumber (int newNumber)
dofManagerParallelMode giveParallelMode () const
void setParallelMode (dofManagerParallelMode _mode)
const IntArraygivePartitionList ()
void setPartitionList (const IntArray *_p)
void removePartitionFromList (int _part)
 Removes given partition from receiver list.
void mergePartitionList (IntArray &_p)
 Merges receiver partition list with given lists.
int givePartitionsConnectivitySize ()
bool isLocal ()
 Returns true if receiver is locally maintained.
bool isShared ()
 Returns true if receiver is shared.
bool isNull ()
 Returns true if receiver is shared.
Public Member Functions inherited from oofem::FEMComponent
 FEMComponent (int n, Domain *d)
virtual ~FEMComponent ()=default
 Virtual destructor.
DomaingiveDomain () const
virtual void setDomain (Domain *d)
int giveNumber () const
void setNumber (int num)
virtual InterfacegiveInterface (InterfaceType t)
std::string errorInfo (const char *func) const
 Returns string for prepending output (used by error reporting macros).

Protected Attributes

IntArray masterMask
int masterDofMngr
 Number of master DofManager (Node).
NodemasterNode
 Pointer to master Node.
Protected Attributes inherited from oofem::Node
std::unique_ptr< FloatMatrixlocalCoordinateSystem
Protected Attributes inherited from oofem::DofManager
FloatArray coordinates
 Array storing nodal coordinates.
std::vector< Dof * > dofArray
 Array of DOFs.
IntArray loadArray
 List of applied loads.
bool isBoundaryFlag
bool hasSlaveDofs
 Flag indicating whether receiver has slave DOFs.
int globalNumber
dofManagerParallelMode parallel_mode
IntArray partitions
IntArray dofidmask
 List of additional dof ids to include.
std ::map< int, int > dofTypemap
 Map from DofIDItem to dofType.
std ::map< int, int > dofMastermap
 Map from DofIDItem to master node.
std ::map< int, int > dofBCmap
 Map from DofIDItem to bc (to be removed).
std ::map< int, int > dofICmap
 Map from DofIDItem to ic (to be removed).
IntArray mBC
Protected Attributes inherited from oofem::FEMComponent
int number
 Component number.
Domaindomain
 Link to domain object, useful for communicating with other FEM components.

Static Protected Attributes

static ParamKey IPK_RigidArmNode_master
static ParamKey IPK_RigidArmNode_mastermask
Static Protected Attributes inherited from oofem::Node
static ParamKey IPK_Node_lcs
static ParamKey IPK_Node_coords

Private Member Functions

void allocAuxArrays ()
void deallocAuxArrays ()

Additional Inherited Members

Static Public Attributes inherited from oofem::DofManager
static ParamKey IPK_DofManager_dofidmask
static ParamKey IPK_DofManager_load
static ParamKey IPK_DofManager_bc
static ParamKey IPK_DofManager_ic
static ParamKey IPK_DofManager_mastermask
static ParamKey IPK_DofManager_doftypemask
static ParamKey IPK_DofManager_boundaryflag
static ParamKey IPK_DofManager_globnum
static ParamKey IPK_DofManager_partitions
static ParamKey IPK_DofManager_sharedflag
static ParamKey IPK_DofManager_remoteflag
static ParamKey IPK_DofManager_nullflag

Detailed Description

Class implementing node connected to other node (master) using rigid arm in finite element mesh. The Rigid arm node supports not only slave dofs mapped to master throug rigid arm connection but also some dofs can be primary dofs (specified by masterDofMask attribute) The primary DOFs can have their own BCs, ICs.

The introduction of rigid arm connected nodes allows to avoid very stiff elements used for modeling the rigid-arm connection. The rigid arm node maps its dofs to master dofs using simple transformations (small rotations are assumed). Therefore, the contribution to rigid arm node are localized directly to master related equations. The rigid arm node can not have its own boundary or initial conditions on linked DOFs, they are determined completely from master dof conditions.

Updated by bp: The local coordinate system in slave is supported in current implementation, the coordinate system in master and slave can be different. If no lcs is set, global one is assumed.the global cs applies.

On the other hand, rigid arm node can be loaded independently of master. The transformation for DOFs and load is not orthogonal - the inverse transformation can not be constructed by transposition. Because of time consuming inversion, methods can generally compute both transformations for dofs as well as loads.

Definition at line 72 of file rigidarmnode.h.

Constructor & Destructor Documentation

◆ RigidArmNode()

oofem::RigidArmNode::RigidArmNode ( int n,
Domain * aDomain )

Constructor. Creates a rigid-arm node with number n, belonging to aDomain.

Parameters
nNode number in domain aDomain.
aDomainDomain to which node belongs.

Definition at line 53 of file rigidarmnode.C.

References oofem::Node::Node().

Referenced by deallocAuxArrays().

◆ ~RigidArmNode()

virtual oofem::RigidArmNode::~RigidArmNode ( void )
inlinevirtual

Destructor.

Definition at line 97 of file rigidarmnode.h.

Member Function Documentation

◆ allocAuxArrays()

void oofem::RigidArmNode::allocAuxArrays ( )
private

◆ checkConsistency()

int oofem::RigidArmNode::checkConsistency ( void )
overridevirtual

Allows programmer to test some internal data, before computation begins. For example, one may use this function, to ensure that element has material with required capabilities is assigned to element. This must be done after all mesh components are instanciated.

Returns
Nonzero if receiver is consistent.

Reimplemented from oofem::Node.

Definition at line 121 of file rigidarmnode.C.

References oofem::DofManager::giveNumberOfDofs(), masterMask, and OOFEM_ERROR.

◆ computeMasterContribution()

◆ deallocAuxArrays()

void oofem::RigidArmNode::deallocAuxArrays ( )
private

References RigidArmNode().

◆ giveClassName()

const char * oofem::RigidArmNode::giveClassName ( ) const
inlineoverridevirtual
Returns
Class name of the receiver.

Reimplemented from oofem::Node.

Definition at line 109 of file rigidarmnode.h.

◆ giveInputRecordName()

const char * oofem::RigidArmNode::giveInputRecordName ( ) const
inlineoverridevirtual
Returns
Input record name of the receiver.

Reimplemented from oofem::Node.

Definition at line 110 of file rigidarmnode.h.

References _IFT_RigidArmNode_Name.

◆ initializeFrom()

void oofem::RigidArmNode::initializeFrom ( InputRecord & ir,
int priority )
overridevirtual

◆ isDofTypeCompatible()

bool oofem::RigidArmNode::isDofTypeCompatible ( dofType type) const
inlineoverridevirtual

Returns true if dof of given type is allowed to be associated to receiver.

Reimplemented from oofem::Node.

Definition at line 111 of file rigidarmnode.h.

◆ postInitialize()

◆ updateLocalNumbering()

void oofem::RigidArmNode::updateLocalNumbering ( EntityRenumberingFunctor & f)
overridevirtual

Local renumbering support. For some tasks (parallel load balancing, for example) it is necessary to renumber the entities. The various FEM components (such as nodes or elements) typically contain links to other entities in terms of their local numbers, etc. This service allows to update these relations to reflect updated numbering. The renumbering function is passed, which is supposed to return an updated number of specified entity type based on old number.

Reimplemented from oofem::DofManager.

Definition at line 286 of file rigidarmnode.C.

References oofem::ERS_DofManager, masterDofMngr, and oofem::DofManager::updateLocalNumbering().

Member Data Documentation

◆ IPK_RigidArmNode_master

ParamKey oofem::RigidArmNode::IPK_RigidArmNode_master
staticprotected

Definition at line 82 of file rigidarmnode.h.

Referenced by initializeFrom(), and postInitialize().

◆ IPK_RigidArmNode_mastermask

ParamKey oofem::RigidArmNode::IPK_RigidArmNode_mastermask
staticprotected

Definition at line 83 of file rigidarmnode.h.

Referenced by initializeFrom(), and postInitialize().

◆ masterDofMngr

int oofem::RigidArmNode::masterDofMngr
protected

Number of master DofManager (Node).

Definition at line 78 of file rigidarmnode.h.

Referenced by initializeFrom(), postInitialize(), and updateLocalNumbering().

◆ masterMask

IntArray oofem::RigidArmNode::masterMask
protected

◆ masterNode

Node* oofem::RigidArmNode::masterNode
protected

Pointer to master Node.

Definition at line 80 of file rigidarmnode.h.

Referenced by computeMasterContribution(), and postInitialize().


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

This page is part of the OOFEM-3.0 documentation. Copyright Copyright (C) 1994-2025 Borek Patzak Bořek Patzák
Project e-mail: oofem@fsv.cvut.cz
Generated at for OOFEM by doxygen 1.15.0 written by Dimitri van Heesch, © 1997-2011