Skip to main content

3pc Python Package for Anisotropic Laminate Failure Analysis

Project description

3pc-lamfail

3pc-lamfail is a Python library used for ply-wise stress and strain analysis of shear deformable anisotropic laminates under hygrothermal and mechanical loads. It provides a Lamfail class to calculate stresses, strains, and various margins of safety (MS) based on classical and first-order shear deformation theories.

Installation

Use the package manager pip to install 3pc-lamfail. Since the package and its dependencies are available on PyPI, you can install them directly:

pip install 3pc-lamfail

API Reference

Lamfail Class

The primary component of this package is the Lamfail class, which takes a panel and a load case to compute detailed failure metrics.

from lamfail.lamfail import Lamfail

Required Parameters

When initializing Lamfail, the following parameters are required:

  • panel (Panel): An instance of the Panel class (from 3pc-panel) containing the laminate definition and geometry.
  • loads (Loads): An instance of the Loads class (from 3pc-loads) containing the load case and environmental conditions.

Calculated Properties

The class automatically calculates the following properties lazily:

  • NT, MT: Thermal in-plane loads and moments.
  • NC, MC: Hygral in-plane loads and moments.
  • ek0: Mid-plane strains and curvatures [ex0, ey0, gxy0, kx0, ky0, kxy0].
  • gT0: Mid-plane transverse strains [gyz0, gxz0].
  • tauyz, tauxz: Transverse shear stresses for each ply.
  • stress: Total stress in reference coordinate axes (x-y-z) for each ply (bottom, mid, top).
  • stressM, stressT, stressH: Mechanical, thermal, and hygral components of stress in reference axes.
  • stress1, stressM1, stressT1, stressH1: Stresses transformed to material coordinate axes (1-2-3).
  • strain, strainM, strainT, strainH: Strains in reference coordinate axes.
  • strain1, strainM1, strainT1, strainH1: Strains in material coordinate axes.

Margins of Safety (MS)

The following failure theories are implemented:

  • stress1MS: Max Stress theory using total stress.
  • stressM1MS: Max Stress theory using mechanical stress.
  • strain1MS: Max Strain theory using total strain.
  • strainM1MS: Max Strain theory using mechanical strain.
  • tsaiHill1MS, tsaiHillM1MS: Tsai-Hill failure theory (Total/Mechanical).
  • tsaiWu1MS, tsaiWuM1MS: Tsai-Wu failure theory (Total/Mechanical).

Methods

Lamfail.fromDict(**kwargs)

Initializes a Lamfail instance using a dictionary of keyword arguments.


Usage Examples

Basic Initialization

Below is an example of performing a failure analysis on a panel under a specific load case.

from panel.panel import Panel
from loads.loads import Loads
from lamfail.lamfail import Lamfail

# Assuming pnl (Panel) and ld (Loads) are already defined
lf = Lamfail(panel=pnl, loads=ld)

# Access Margins of Safety for Ply 1 (bottom ply)
print("Max Stress MS (Material Axes):", lf.stress1MS["1"]["mid"])
print("Tsai-Wu MS:", lf.tsaiWu1MS["1"]["mid"])

# Access stresses
print("Total Stress (x-y-z):", lf.stress["1"]["top"])

Commands

The package provides a command-line interface entry point. After installing, you can run the application using:

lamfail input.cfg

(This entry point is defined in lamfail.__main__:main)

Options

  • config (positional): Specify the configuration file (.cfg) to run the analysis.
  • -h, --help: Show the help message and exit.
  • -v, --version: Show the version number.
  • -s, --sample: Copy example files (materials, plies, laminates, etc.) to the current directory.

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

3pc_lamfail-1.0.0.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

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

3pc_lamfail-1.0.0-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file 3pc_lamfail-1.0.0.tar.gz.

File metadata

  • Download URL: 3pc_lamfail-1.0.0.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for 3pc_lamfail-1.0.0.tar.gz
Algorithm Hash digest
SHA256 dc3f751fdf3c2a8811b7be7be46894101ad0e44f3642b0a0de4f7769b32cb136
MD5 26081b647a218ba2a87e2a5439aa3217
BLAKE2b-256 9baa5a79e59222f96700d1100c347b6599d0e83ba162feb3ea8170a1ba0ec318

See more details on using hashes here.

File details

Details for the file 3pc_lamfail-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: 3pc_lamfail-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for 3pc_lamfail-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2a062335e66770d2949e89028a84c29500726d748c9ce545072099a2a9d10e4b
MD5 cb1dca3b517566b4fba46f2d81a5d19f
BLAKE2b-256 b606735276e86dc784cbdacebdfdf12853ab7218721065680f7b4e2d056e14a4

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