Skip to main content

A light-weight FEM beam analyzer.

Project description

PlaneSections

A lightweight finite element beam bending library built on libraries like PyNite and OpenSeesPy. The goal of PlaneSections is to make easy-to-use beam anayses, which can be used to quickly document structural calculations.

NOTE: Units for force and length must be applied to the beam in a consistent unit base for FEM. PlaneSections has been set up with Metric units in mind in terms of scaling diagrams. For those using imperial units, results will work with a consitent unit basis, but the scale of the digrams may be off.

PlaneSections is a FEM solver! Results are only stored at nodes specified by the user - all intermediate values in plots are linearly interpolated.

Contents

Installation

The default package is installable through pip.

pip install planesections

The package with the optional OpenSeesPy dependancy is installable with

pip install planesections[opensees]

Features:

2D and 3D beams can be anayzed under the following force types:

  • Point loads
  • Point Moments
  • Line Element loads
  • Linearly varying element loads (2D only).

Diagrams can also be made of 2D beams, but the support types that can be plotted are limited.

Documentation

All major functions and classes are documented on read-the-docs: https://planesections.readthedocs.io/en/latest/

Demo

The PlaneSections can analyze and document beam plots for calcualtions. Below we make a beam, create a diagram of it, then get the output bending moment and shear force diagrams. It's also possible to get rotation, and deflection diagrams but these are not shown here.

import planesections as ps

# Define node locations, and support conditions
L = 5
beam = ps.newEulerBeam(L)

# Define beam and fixities
pinned = [1,1,0]
beam.setFixity(L*0.1, pinned, label = '1')
beam.setFixity(L*0.9, pinned)

# Define loads
Pz = -1
beam.addVerticalLoad(0, Pz, label = 'A')
beam.addVerticalLoad(L*0.5, 2*Pz, label = 'B')
beam.addVerticalLoad(L, Pz, label = 'C')
beam.addDistLoadVertical(0, L, Pz)
beam.addDistLoadVertical(1, L*0.3, 5*Pz)

# Plot the beam diagram
ps.plotBeamDiagram(beam)

# Run the analysis
analysis = ps.PyNiteAnalyzer2D(beam)
analysis.runAnalysis()

# Plot the SFD and BMD
ps.plotShear(beam)
ps.plotMoment(beam)

Coordinates

The coordinant system used for beams is as follows:

Further Examples

See the examples folder for more examples!

Solvers

The opensees solver is included as an optional dependancy. It is significantly faster than the PyNite solver (~100x), but the license is more limited in use. OpenSees allows commercial use of the package, but does not allow resale without permission, so use at your own risk! OpenSees License.

Some restrictions exist for OpenSees license, so this library has been added as an optional dependancy

Status

PlaneSections is almost "feature complete" in terms of it's analysis functionality. The only additional analysis features I might include are:

  • Spring supports
  • Internal hinges
  • Better cross section support These are not slated to be in the next release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

planesections-1.4.2.tar.gz (52.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

planesections-1.4.2-py3-none-any.whl (54.3 kB view details)

Uploaded Python 3

File details

Details for the file planesections-1.4.2.tar.gz.

File metadata

  • Download URL: planesections-1.4.2.tar.gz
  • Upload date:
  • Size: 52.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for planesections-1.4.2.tar.gz
Algorithm Hash digest
SHA256 c19c9a2f4338f4055839ff9ebe23e8c25ce2f0e519b571064e5312f413b89046
MD5 538facfd41537739cd8cef6cca190471
BLAKE2b-256 b6c13417b3f021c0a24e3d1c6335c212bb0595e9072762409ad7ad0f2bfac1f1

See more details on using hashes here.

File details

Details for the file planesections-1.4.2-py3-none-any.whl.

File metadata

  • Download URL: planesections-1.4.2-py3-none-any.whl
  • Upload date:
  • Size: 54.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for planesections-1.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8660f3f952b5c1a3887cc5f4ca584dcdae368378bad4275c6dde1c128ee7267a
MD5 18365a1e7dbfc801130d342e1387690a
BLAKE2b-256 b7fec3b9d823a8749911f2257462f8f0083553b208f6020c3ffaa5ad3d049618

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page