Python Thermodynamic Calculation Engine powered by PyThermoDB.
Project description
PyThermoCalcDB
PyThermoCalcDB — Python Thermodynamic Calculation Engine powered by PyThermoDB
PyThermoCalcDB is a companion package to PyThermoDB, designed to provide a robust set of thermodynamic calculations, utilities, and workflows — using thermodynamic properties, constants, and equations built with PyThermoDB.
🚀 Why PyThermoCalcDB?
- Seamless integration with PyThermoDB: use the database of thermodynamic data (pure component properties, correlations, etc.) as the foundation.
- Reusable calculation tools: functions for various calculations.
- Consistent with your thermodynamic ecosystem: fits with existing packages like PyThermoModels, PyPhaseEQ, PyThermoFlash — offering a central “calculation engine” layer.
- Minimal dependencies: lean design, using PyThermoDB as core data source; optionally depend on well-known numerical libraries (e.g. NumPy, SciPy) if needed for complex calculations.
- Flexible use-cases: from quick property lookups to advanced process calculations, or integration in larger workflows or multi-agent systems.
📦 Installation
pip install pyThermoCalcDB
🚀 Usage
PyThermoCalcDB provides high-level thermodynamic routines built on PyThermoDB. It is optimized for scripts, notebooks, and pipelines ? the examples/ directory contains runnable workflows.
1) Build a ModelSource
- Collect ThermoDB pickle paths for your components and load them with
pyThermoLinkDB.load_and_build_model_source.
import os
import pyThermoLinkDB as ptdblink
from pythermodb_settings.models import Component, ComponentRule, ComponentThermoDBSource, Temperature, Pressure
CO2 = Component(name="carbon dioxide", formula="CO2", state="g")
thermodb_dir = "/path/to/thermodb"
CO2_src = ComponentThermoDBSource(
component=CO2,
source=os.path.join(thermodb_dir, "carbon dioxide-g.pkl"),
)
model_source = ptdblink.load_and_build_model_source(
thermodb_sources=[CO2_src],
original_equation_label=False
)
2) Call helper modules
- Thermodynamic properties (
pyThermoCalcDB.docs.thermo):calc_En,calc_GiFrEn,calc_En_range,calc_GiFrEn_range,calc_dEn(Delta H between temperatures),calc_dEnt(Delta S with pressures and phase),calc_En_mix(mixture enthalpy with optional departure/excess terms andoutput_unit). - Saturation & phase change (
pyThermoCalcDB.docs.sat):calc_VaPr,calc_VaPr_range,calc_EnVap,calc_EnVap_range,calc_T_sat,calc_VaPr_sensitivity,calc_VaPr_sensitivity_range. - Reactions (
pyThermoCalcDB.reactions.reactions):dEn_rxn_STDanddGiFrEn_rxn_STDfor standard reaction energetics.
Example:
from pyThermoCalcDB.docs import thermo, sat
from pythermodb_settings.models import Temperature, Pressure
T = Temperature(value=300.0, unit="K")
P = Pressure(value=1.5e6, unit="Pa")
enthalpy = thermo.calc_En(component=CO2, model_source=model_source, temperature=T)
gibbs = thermo.calc_GiFrEn(component=CO2, model_source=model_source, temperature=T, phase="IG")
VaPr = sat.calc_VaPr(component=CO2, model_source=model_source, temperature=T)
Tsat = sat.calc_T_sat(
component=CO2,
model_source=model_source,
pressure=P,
temperature_guess=T,
method="least_squares",
)
Notes:
- All helpers expect typed
Component,Temperature, andPressureinputs plus amodel_sourcefrom PyThermoLinkDB. - The optional
modekwarg acceptssilent,log, orattachto control logging and timing.
🤝 Contributing
Contributions are highly welcome — bug fixes, new calculation routines, mixture models, extended unit tests, documentation, etc.
📝 License
This project is distributed under the Apache License, Version 2.0, which grants you broad freedom to use, modify, and integrate the software into your own applications or projects, provided that you comply with the conditions outlined in the license. Although Apache 2.0 does not require users to retain explicit author credit beyond standard copyright and license notices, I kindly request that if you incorporate this work into your own software, you acknowledge Sina Gilassi as the original author. Referencing the original repository or documentation is appreciated, as it helps recognize the effort invested in developing and maintaining this project.
❓ FAQ
For any question, contact me on LinkedIn
👨💻 Authors
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pythermocalcdb-0.7.4.tar.gz.
File metadata
- Download URL: pythermocalcdb-0.7.4.tar.gz
- Upload date:
- Size: 58.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7f1555d5e897a9a1a12e7c4d863fa880c6246383a37ad18a071ea3037d6b680
|
|
| MD5 |
f4c7912332824be1ff9afd5d0ba2e1fa
|
|
| BLAKE2b-256 |
abb89d41b46041cf8351c75ff1375b69b6e1137e71fc334182b51445d99ed7b3
|
File details
Details for the file pythermocalcdb-0.7.4-py3-none-any.whl.
File metadata
- Download URL: pythermocalcdb-0.7.4-py3-none-any.whl
- Upload date:
- Size: 74.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf1d019cd9d57394e9f22204372b4223561050c9ee247af1f7cf83b76901addf
|
|
| MD5 |
2947f29d49fe097a8dd835d0ec6a844f
|
|
| BLAKE2b-256 |
87263757d092a3ac3aff1c310d0af493013ea39e739f635b7646d5188b7edf6f
|