Element classes
This class represents no particular element but rather defines common functionality for all elements.
Note
Every element in FEM.edu is derived from this class.
The Element
class inherits methods from DrawElement
, which provides default plotting functionality
for common element types.
Note
Every element needs to declare its generic type through self.element_type
in its constructor
for the default plotting mechanism to work. The default constructor defines self.element_type = self.UNKNOWN
,
which means that this element will not be plotted.
See Inherited methods for more detail on the DrawElement
class.
The Element base class
- class femedu.elements.Element.Element(nodes, material, label=None)
abstract class: representing a single generic element
- addTransformation(T, local_nodes=[])
Attach a transformation to any node of the element.
If no local_nodes list is given or an empty list is handed to the function, the transformation, T, will be applied to all nodes in the element.
A non-empty local_nodes list will apply the transformation to those local nodes listed in that list. Local nodes start at 0 and go to N-1, where N is the number of elements in this element.
A transformation can be removed from a node by assigning
T=None
as the transformation.
- getDisp(node, **kwargs)
Use this function to get nodal displacements from inside your element implementation.
This is a wrapper around the
Node.getDisp(caller)()
method that adds the caller information for the node.- Parameters:
node – local node number for which displacements are requested.
- getDofs()
returns the dof-codes for this element in a list
- getForce()
Request the internal force vector (stress driven force only; no applied element loads)
- Returns:
- getLoad(apply_load_factor=False)
Requesting nodal forces generated by element loads, like
line loads on beams of frames
surface loads on plates or solids
body forces on solids.
- Parameters:
apply_load_factor – shall the global load factor be applied by the element.
- Returns:
element load vector
- getPos(node, **kwargs)
Use this function to get nodal displacements from inside your element implementation.
This is a wrapper around the
Node.getPos(caller)()
method that adds the caller information for the node.- Parameters:
node – local node number for which displacements are requested.
- getStiffness()
- Returns:
the current tangent stiffness matrix
- initialize(type=0, dofs=[])
- Parameters:
type – define DrawElement.TYPE for plotting. See
femedu.elements.DrawElement()
under Inherited methods for available options.dofs – list of dofs used by this element. Example: [“ux”,”uy”] for 2d-displacements.
- mapGaussPoints(var)
Initiate mapping of Gauss-point values to nodes. This method is an internal method and should not be called by the user. Calling that method explicitly will cause faulty nodal values.
- Parameters:
var – variable code for a variable to be mapped from Gauss-points to nodes
- on_converged()
This method is called by the solver if convergence has been achieved.
The element shall perform all necessary state updates, especially inform it’s material instances about the necessary updates.
- recordThisStep(load_level)
record current state of the system
- resetLoads()
default implementation for resetting element loads.
- reset_matrices()
(re-)initializes element stiffness matrix and element force
- revert()
This method is called by the solver if the current load step failed to converge and the system shall be returned to the last converged state.
The element shall perform all necessary state updates, especially inform it’s material instances about the necessary updates.
- setLoadFactor(lam)
Set the target load factor to lam
Warning
This method should not be called by the user. USE
System.setLoadFactor(lam)
instead!The entered load pattern is considered a reference load, to be multiplied by a scalar load factor, \(\lambda\).
If no load factor is set explicitly, a factor of 1.0 is assumed, i.e., the entire entered load is applied in full.
- setSurfaceLoad(face_idx, pn, ps=0)
Warning
This method needs to be implemented by every element that shall accept a surface load.
- Parameters:
face_ix – face index for the loaded face (integer starting at 0)
pn – magnitude of distributed normal load per unit length. Tension on a surface is positive.
ps – magnitude of distributed shear load per unit length. Positive shear rotates the element counter-clockwise.
- updateState()
Inherited methods
- class femedu.elements.DrawElement.DrawElement
class for drawing any element
element types are:
UNKNOWN
LINE
truss, simple frame
CURVE
beam, nice frame
TRIANGLE
plates, shells
TETRAHEDRON
plates, shells
QUAD
plates, shells
BRICK
continuum
- draw(factor=0.0, modeshape=False, **kwargs)
Returns a series of coordinate vectors representing the _x_, _y_, and _z_ values of points for plotting the deformed shape the current element (
self
). For the undeformed element, setfactor=0.0
.- Parameters:
factor – magnification factor for deformation
- Returns:
a tuple (list) of coordinate vectors
- drawBrick(factor, **kwargs)
implementation of a generic
BRICK
type
- drawCurve(factor, **kwargs)
implementation of a generic
CURVE
type
- drawLine(factor, **kwargs)
implementation of a generic
LINE
type
- drawQuad(factor, **kwargs)
implementation of a generic
QUAD
type
- drawTetrahedron(factor, **kwargs)
implementation of a generic
TETRAHEDRON
type
- drawTriangle(factor, **kwargs)
implementation of a generic
TRIANGLE
type