Skip to main content

IS 456 RC Beam Design Library (flexure, shear, ductile detailing, DXF export for RC beams)

Project description

structural-lib-is456

IS 456 RC Beam Design Library (Python package).

Version: 0.21.0 (development preview) Status: Python tests

⚠️ Development Preview: APIs may change until v1.0. For reproducible results, pin to a release tag.

For full project overview and usage examples, see the repository root README.md.

Install

# Recommended (pinned to release tag)
pip install "structural-lib-is456 @ git+https://github.com/Pravin-surawase/structural_engineering_lib.git@v0.21.0#subdirectory=Python"

# With DXF support (pinned)
pip install "structural-lib-is456[dxf] @ git+https://github.com/Pravin-surawase/structural_engineering_lib.git@v0.21.0#subdirectory=Python"

# PyPI (latest — may differ from pinned tag)
pip install structural-lib-is456

# PyPI with DXF support
pip install "structural-lib-is456[dxf]"

Extras

  • dxf: DXF export support (ezdxf)
  • render: planned DXF render to PNG/PDF (matplotlib) — not implemented yet
  • dev: tooling for tests/formatting/linting

Quick Start: CLI Usage

The library provides a unified command-line interface:

# Run beam design from CSV input
python -m structural_lib design input.csv -o results.json

# Generate bar bending schedule
python -m structural_lib bbs results.json -o bbs.csv

# Generate DXF drawings (requires ezdxf)
python -m structural_lib dxf results.json -o drawings.dxf

# Run complete job from specification
python -m structural_lib job job.json -o output/

# Critical set + report from job outputs
python -m structural_lib critical output/ --top 10 --format=csv -o critical.csv
python -m structural_lib report output/ --format=html -o report.html

The HTML report includes a cross-section SVG, input sanity heatmap, stability scorecard, and units sentinel.

You can also generate reports directly from design_results.json:

python -m structural_lib report results.json --format=html -o report/ --batch-threshold 80

Run python -m structural_lib --help for more options.

Insights export (v0.13.0+)

python -m structural_lib design input.csv -o results.json --insights
# Writes: results.json + <output_stem>_insights.json

Note: CLI insights currently export precheck + sensitivity + robustness; constructability may be null until CLI integration is completed.

Quick Start: Python API

from structural_lib import flexure, shear, api

# Single beam design
result = flexure.design_singly_reinforced(
    b=230, d=450, d_total=500, mu_knm=100, fck=25, fy=500
)
print(f"Ast required: {result.ast_required:.0f} mm²")

# Multi-case compliance check
report = api.check_beam_is456(
    units="IS456",
    b_mm=230, D_mm=500, d_mm=450,
    fck_nmm2=25, fy_nmm2=500,
    cases=[{"case_id": "ULS-1", "mu_knm": 100, "vu_kn": 80}]
)
print(f"Governing case: {report.governing_case_id}")

New in v0.21.0

  • NSGA-II Multi-Objective Pareto Optimization: optimize_pareto_front() for multi-objective beam optimization with IS 456 clause references.
  • API Contract Testing: check_api.py --signatures for preventing API mismatches.
  • Enhanced Cost Optimizer UI: Interactive Pareto visualization with WHY explanations.

New in v0.21.0

  • Library-first API wrappers: validate_*, compute_detailing, compute_bbs, export_bbs, compute_dxf, compute_report, compute_critical.
  • New CLI helpers: validate for schema checks and detail for detailing JSON export.
  • DXF/BBS quality gates: mark consistency checks + DXF content tests + title block context.
  • Batch packaging (V08): report accepts design results JSON and supports folder output with --batch-threshold.
  • Golden fixtures (V09): Deterministic report outputs verified via golden-file tests.

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

structural_lib_is456-0.21.0.tar.gz (654.6 kB view details)

Uploaded Source

Built Distribution

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

structural_lib_is456-0.21.0-py3-none-any.whl (791.7 kB view details)

Uploaded Python 3

File details

Details for the file structural_lib_is456-0.21.0.tar.gz.

File metadata

  • Download URL: structural_lib_is456-0.21.0.tar.gz
  • Upload date:
  • Size: 654.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for structural_lib_is456-0.21.0.tar.gz
Algorithm Hash digest
SHA256 b720dc0e258bf1c27bf477e7f7b59d3199d86740db930ebd9732b27f17616860
MD5 d653a9bb8ad8899a679b24fb69855dd2
BLAKE2b-256 f275956433c50481f9d5399471d14c03b9080640eb3dd7b6585a1cf5d907508f

See more details on using hashes here.

Provenance

The following attestation bundles were made for structural_lib_is456-0.21.0.tar.gz:

Publisher: publish.yml on Pravin-surawase/structural_engineering_lib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file structural_lib_is456-0.21.0-py3-none-any.whl.

File metadata

File hashes

Hashes for structural_lib_is456-0.21.0-py3-none-any.whl
Algorithm Hash digest
SHA256 88be93d65e68eecbc453795d4968cad63a7daf1fad357c91ab7577344b7be610
MD5 e90e6ca1941303bae4f37a16089eef6c
BLAKE2b-256 1836bd7e04ed48bce962c5c342e72457a63b1ea1b2b1dc6e6c53073df66de895

See more details on using hashes here.

Provenance

The following attestation bundles were made for structural_lib_is456-0.21.0-py3-none-any.whl:

Publisher: publish.yml on Pravin-surawase/structural_engineering_lib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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