A finite element stress and buckling analysis package of linearly elastic systems.



This is a WIP application package for stress and buckling analysis relying heavily on JuAFEM.jl.

To Do List

  1. Finding stress tensor in each cell,
  2. Building the element stress stiffness matrices,
  3. Assembling the element stiffness matrices for buckling analysis,
  4. Visualizing the displacement, stress and eigenmodes.


using LinearElasticity

# Define problem, can also be imported from .inp files
nels = (60,20)
sizes = (1.0,1.0)
E = 1.0;
ν = 0.3;
force = -1.0;
problem = PointLoadCantilever(nels, sizes, E, ν, force)

# Build element stiffness matrices and force vectors
einfo = ElementFEAInfo(problem);

# Assemble global stiffness matrix and force vector
ginfo = assemble(problem, einfo);

# Solve for node displacements
u = ginfo.K \ ginfo.f

# Get the stiffness matrices for buckling analysis
K, Kσ = buckling(problem, ginfo, einfo)

using IterativeSolvers

# Find the maximum eigenvalue of system Kσ x = 1/λ K x
r = lobpcg(Kσ.data, K.data, true, 1)

# Minimum eigenvalue of the system K x = λ Kσ x
λ = 1/r.λ[1]

First Commit


Last Touched

9 months ago


16 commits

Used By: