Skip to main content

An advanced pinch analysis and total site integration toolkit

Project description

OpenPinch

OpenPinch is an open-source toolkit for advanced Pinch Analysis and Total Site Integration. It supports direct and indirect heat integration targeting, multi-utility studies, graph generation, Excel-based workflows, and programmatic analysis in Python.

Install

Install the published package from PyPI for core CLI and Python usage:

python -m pip install openpinch

If you plan to run the packaged Jupyter notebooks, graph rendering, or Excel I/O, install the notebook extra:

python -m pip install "openpinch[notebook]"

If you plan to launch the Streamlit dashboard, install the dashboard extra:

python -m pip install "openpinch[dashboard]"

If you need TESPy-backed Brayton-cycle tooling, install the Brayton-cycle extra:

python -m pip install "openpinch[brayton_cycle]"

If you want the full optional surface in one install:

python -m pip install "openpinch[full]"

OpenPinch currently requires Python >=3.14.

Notebook Workflow

OpenPinch ships with a notebook series for distinct outputs and workflows. Copy them into your working directory with:

openpinch notebook -o notebooks

To run the packaged notebooks in Jupyter, install the notebook extra first with python -m pip install "openpinch[notebook]".

The packaged notebook series currently includes:

  • 01_basic_pinch_and_dtcont_sensitivity.ipynb
  • 02_total_site_targets_and_sugcc.ipynb
  • 03_carnot_hpr_comparison.ipynb

These notebooks are intended to be the main learning path for new users.

Python Workflow

For script and notebook usage, the main single-case front door is PinchProblem.

from OpenPinch import PinchProblem

problem = PinchProblem("basic_pinch.json", project_name="basic_pinch")
problem.target()

summary = problem.summary_frame()
print(summary)

selected_state = problem.target.direct_heat_integration(state_id="peak")
state_summary = problem.summary_frame()
print(state_summary[["Target", "State ID", "Hot Utility Target", "Cold Utility Target"]])

problem.export_excel("results")
problem.plot.export("graphs", graph_type="gcc")

When the PinchProblem data contains stateful values, the named problem.target.* entry points also accept state_id=... so one cached solve can be refreshed for a selected operating state without flattening the in-memory model first.

For named study cases and bundle save/load, use PinchWorkspace:

from OpenPinch import PinchWorkspace

workspace = PinchWorkspace(
    source="crude_preheat_train.json",
    project_name="crude_preheat_train",
)
workspace.copy_case("baseline", "wide_dt", activate=False)
workspace.set_dt_cont_multiplier(0.5, case_name="wide_dt")
comparison = workspace.compare_cases("baseline", "wide_dt")

You can also build a payload directly from the validated schema models:

from OpenPinch import pinch_analysis_service
from OpenPinch.lib.enums import StreamType
from OpenPinch.lib.schemas.io import StreamSchema, TargetInput, UtilitySchema

streams = [
    StreamSchema(
        zone="Process Unit",
        name="Reboiler Vapor",
        t_supply=200.0,
        t_target=120.0,
        heat_flow=8000.0,
        dt_cont=10.0,
        htc=1.5,
    ),
    StreamSchema(
        zone="Process Unit",
        name="Feed Preheat",
        t_supply=40.0,
        t_target=160.0,
        heat_flow=6000.0,
        dt_cont=10.0,
        htc=1.2,
    ),
]

utilities = [
    UtilitySchema(
        name="Cooling Water",
        type=StreamType.Cold,
        t_supply=25.0,
        t_target=35.0,
        heat_flow=120000.0,
        dt_cont=5.0,
        htc=0.8,
        price=12.0,
    )
]

payload = TargetInput(streams=streams, utilities=utilities)
result = pinch_analysis_service(payload, project_name="Example")

Graphing and Dashboard

With the notebook or dashboard extra installed, graph generation in Python looks like:

figure = problem.plot.grand_composite_curve()
figure.show()

To launch the Streamlit dashboard after solving, install openpinch[dashboard] and call:

problem.show_dashboard()

Highlights

  • Multi-scale targeting for unit operation, process, site, community, and regional studies
  • Direct heat integration and indirect integration through utility systems
  • Multiple utility targeting, including non-isothermal utilities
  • Composite Curve and Grand Composite Curve graph generation
  • Excel workbook import and Excel summary export
  • Packaged sample cases and notebook workflows
  • Pydantic schema models for validated programmatic usage

Documentation

Full documentation is available at:

https://openpinch.readthedocs.io/en/latest/

The documentation is organized around install, sample workflows, notebooks, graphing, and the public API.

History

OpenPinch started in 2011 as an Excel workbook with macros. Since then it has expanded into Total Site Heat Integration, multiple utility targeting, retrofit targeting, cogeneration targeting, and related workflows. The Python implementation began in 2021 to bring those capabilities into a scriptable and testable package interface.

Citation

In publications and forks, please cite and link the foundational article and this repository.

Timothy Gordon Walmsley, 2026. OpenPinch: An Open-Source Python Library for Advanced Pinch Analysis and Total Site Integration. Process Integration and Optimization for Sustainability. https://doi.org/10.1007/s41660-026-00729-6

Testing

To run the test suite locally:

python -m pip install -e . pytest build "hatchling>=1.26"
pytest

Contributors

Founder: Tim Walmsley, University of Waikato

Stephen Burroughs, Benjamin Lincoln, Alex Geary, Harrison Whiting, Khang Tran, Roger Padullés, Jasper Walden

Contributing

Issues and pull requests are welcome. When submitting code, aim for:

  • typed interfaces and clear docstrings
  • small methods with singular purpose
  • pytest coverage for new user-facing behaviour
  • updated docs and notebooks where relevant

License

OpenPinch is released under the MIT License. See LICENSE for details.

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

openpinch-0.2.1.tar.gz (198.7 kB view details)

Uploaded Source

Built Distribution

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

openpinch-0.2.1-py3-none-any.whl (259.9 kB view details)

Uploaded Python 3

File details

Details for the file openpinch-0.2.1.tar.gz.

File metadata

  • Download URL: openpinch-0.2.1.tar.gz
  • Upload date:
  • Size: 198.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openpinch-0.2.1.tar.gz
Algorithm Hash digest
SHA256 fc660353cc3c77ad2788053d483f3848260a89be9e76ec0e6ec755c831ade08d
MD5 56b857124d907bee3d25f3207e58b678
BLAKE2b-256 b4a4bf83fd1ed4ea90b0e513dd5e89cf6dd4e985c3cdb8d581575e6ccecf21be

See more details on using hashes here.

Provenance

The following attestation bundles were made for openpinch-0.2.1.tar.gz:

Publisher: ci-publish.yml on waikato-ahuora-smart-energy-systems/OpenPinch

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

File details

Details for the file openpinch-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: openpinch-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 259.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openpinch-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 99a7a94323730d4907349d1f8d72177701ebf39e04b504755e764dce6dfab4be
MD5 8c31921347e1d7e71f3db857fbcb18c8
BLAKE2b-256 26a6f64bccde12b72bb0f54017fa3d4a4e50bb1dcfbeae284888a15f66d8ac44

See more details on using hashes here.

Provenance

The following attestation bundles were made for openpinch-0.2.1-py3-none-any.whl:

Publisher: ci-publish.yml on waikato-ahuora-smart-energy-systems/OpenPinch

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