A Python-based process simulation framework for chemical engineering applications.
Project description
Process Forge
A Python-based process simulation framework for chemical process engineering applications.
Table of Contents
- Features
- Available Unit Operations
- Installation
- Usage
- Flowsheet Configuration
- Quick Start Examples
- Project Structure
- Dependencies
- License
Features
Core Capabilities
- Steady-state EO (equation-oriented) and dynamic process simulations
- Thermodynamic property calculations using CoolProp
- Multiple unit operations for hydraulic and thermal systems
- Flowsheet modeling with automatic recycle stream detection
- Modelica/OMPython bridge: transpile flowsheets to native
.mosource and compile to Model Exchange FMU via OpenModelica
Steady-State EO Solver
- All unit equations assembled into a global
F(x) = 0system and solved simultaneously - Newton-Raphson with Armijo backtracking line search (SciPy backend)
- Pluggable backends: SciPy (built-in), Pyomo + IPOPT (optional), CasADi (optional)
- Recycle loops handled natively — no tear stream initialisation or Wegstein iteration needed
- Recycle streams are auto-detected from the flowsheet graph topology
Dynamic Simulation
- ODE time-marching for Tank-based dynamic flowsheets
- Sequential-modular propagation with Wegstein convergence for recycle loops
- Timeseries results for transient analysis
Results & Visualization
- Export formats: Zarr stores containing both scalar and timeseries results for downstream analysis
- Optional plotting (use
--export-images) for temperature profiles and composition charts - Graphviz flowsheet diagrams (PNG and SVG)
- Timeseries visualization for dynamic simulations
Validation & Quality
- JSON schema validation for flowsheet configurations
- Connectivity checks (inlet sources, unused outlets, unreachable units)
- Comprehensive logging for debugging
Available Unit Operations
| Unit Type | Mode | Description | Key Parameters |
|---|---|---|---|
| Pump | Steady-state (EO) | Adds pressure rise with efficiency losses | deltaP, efficiency |
| Valve | Steady-state (EO) | Isenthalpic pressure reduction | pressure_ratio |
| Strainer | Steady-state (EO) | Fixed pressure drop element | deltaP |
| Pipes | Steady-state (EO) & Dynamic | Laminar flow with friction losses | delta_p, diameter |
| Tank | Dynamic only | Well-mixed molar tank (ODE) | outlet_flow, initial_n, initial_T, P, duty |
| Flash | Steady-state (EO, SciPy backend) | Isothermal flash separator | P |
| Heater | Steady-state (EO, SciPy backend) | Temperature control unit | duty, flowrate |
Note: Flash and Heater use CoolProp internally and are supported on the SciPy backend only. Pump, Valve, Strainer, and Pipes support all three backends (SciPy, Pyomo, CasADi).
Installation
From PyPI
# pip
pip install processforge
# uv
uv add processforge
With EO solver backends (optional)
# Pyomo + IPOPT backend
pip install "processforge[eo]"
uv add "processforge[eo]"
# Pyomo + IPOPT + CasADi backend
pip install "processforge[eo-casadi]"
uv add "processforge[eo-casadi]"
# Modelica transpiler + OMPython bridge (requires OpenModelica installed separately)
pip install "processforge[modelica]"
uv add "processforge[modelica]"
From source (development)
-
Clone the repository:
git clone https://github.com/urjanova/processforge.git cd processforge
-
Install the package:
pip install -e ".[dev]"
Or using uv:
uv sync
Usage
Command Line Interface
ProcessForge provides a CLI with three subcommands:
# Run a simulation (add --export-images to generate PNG plots)
processforge run flowsheets/closed-loop-chain.json [--export-images]
# Validate a flowsheet configuration
processforge validate flowsheets/closed-loop-chain.json
# Generate a flowsheet diagram
processforge diagram flowsheets/closed-loop-chain.json
processforge diagram flowsheets/closed-loop-chain.json --format svg --output-dir diagrams/
# Export flowsheet as Modelica .mo and compile to Model Exchange FMU via OMPython
processforge export-modelica flowsheets/my-flowsheet.json
processforge export-modelica flowsheets/my-flowsheet.json --output-dir modelica/ --no-compile
Running a simulation generates output files in the outputs/ directory:
*_results.zarr- Simulation results stored as a Zarr directory*_validation.xlsx- Validation report derived directly from the Zarr store- PNG plots for temperatures and compositions when
--export-imagesis supplied
As a Python Module
from processforge import EOFlowsheet, validate_flowsheet
# Load and validate a flowsheet
config = validate_flowsheet("flowsheets/my-flowsheet.json")
# Run steady-state EO simulation (default SciPy backend)
fs = EOFlowsheet(config, backend="scipy")
results = fs.run()
# results: {stream_name: {"T": ..., "P": ..., "flowrate": ..., "z": {...}}}
# Use Pyomo + IPOPT backend (requires: pip install "processforge[eo]")
fs = EOFlowsheet(config, backend="pyomo")
results = fs.run()
# Use CasADi backend (requires: pip install "processforge[eo-casadi]")
fs = EOFlowsheet(config, backend="casadi")
results = fs.run()
Flowsheet Configuration
Flowsheets are defined as JSON files. The simulation.mode field controls which solver is used:
mode |
Solver | Use case |
|---|---|---|
"steady" (default) |
EO — global Newton-Raphson | Steady-state without Tank units |
"dynamic" |
SM — ODE time-marching | Flowsheets containing Tank units |
{
"metadata": { "name": "My Flowsheet", "version": "2.0" },
"streams": {
"feed": { "T": 298.15, "P": 101325, "flowrate": 1.0, "z": { "Water": 0.8, "Toluene": 0.2 } }
},
"units": {
"pump_1": { "type": "Pump", "in": "feed", "out": "after_pump", "deltaP": 200000, "efficiency": 0.75 },
"valve_1": { "type": "Valve", "in": "after_pump", "out": "product", "pressure_ratio": 0.5 }
},
"simulation": {
"mode": "steady",
"backend": "scipy"
}
}
The optional backend key selects the EO solver backend ("scipy", "pyomo", or "casadi"). Defaults to "scipy".
Recycle streams
Recycle streams require no special configuration. Any stream produced as the out of one unit can be used as the in of any other unit — including upstream units. The EO solver resolves the full coupled system simultaneously.
"units": {
"tank_1": { "type": "Tank", "in": ["feed", "recycle"], "out": "after_tank", ... },
"pipe_1": { "in": "after_tank", "out": "recycle", ... }
}
Quick Start Examples
Run a steady-state simulation
processforge run flowsheets/hydraulic-chain.json
Run a dynamic simulation
processforge run flowsheets/closed-loop-chain.json
Validate a flowsheet
processforge validate flowsheets/closed-loop-chain.json
Generate a flowsheet diagram
processforge diagram flowsheets/closed-loop-chain.json
Project Structure
processforge/
├── src/processforge/ # Core package
│ ├── __init__.py # Public API
│ ├── flowsheet.py # Sequential-modular solver (dynamic mode)
│ ├── thermo.py # Thermodynamic calculations via CoolProp
│ ├── result.py # Results export (Zarr, Excel, plotting)
│ ├── simulate.py # CLI entry point with subcommands
│ ├── solver.py # ODE solver interface (dynamic)
│ ├── validate.py # Simple schema validation
│ ├── _schema.py # Schema loader (importlib.resources)
│ ├── eo/ # Equation-oriented (EO) steady-state solver
│ │ ├── flowsheet.py # EOFlowsheet — build, warm-start, solve
│ │ ├── solver.py # EOSolver — backend selector
│ │ ├── jacobian.py # GlobalJacobianManager — F(x), J(x)
│ │ ├── stream_var.py # StreamVar — per-stream variable container
│ │ ├── mixin.py # EOUnitModelMixin — unit residual interface
│ │ ├── backends/ # Pluggable solver backends
│ │ │ ├── scipy_backend.py # Newton-Raphson + Armijo (built-in)
│ │ │ ├── pyomo_backend.py # Pyomo ConcreteModel + IPOPT (optional)
│ │ │ └── casadi_backend.py # CasADi SX + rootfinder (optional)
│ │ └── units/ # EO residual equations per unit type
│ │ ├── pump_eo.py
│ │ ├── valve_eo.py
│ │ ├── strainer_eo.py
│ │ ├── pipes_eo.py
│ │ ├── heater_eo.py
│ │ └── flash_eo.py
│ ├── units/ # Unit operation implementations
│ │ ├── pump.py # Pump with efficiency
│ │ ├── valve.py # Pressure-reducing valve
│ │ ├── strainer.py # Pressure drop element
│ │ ├── pipes.py # Pipe with friction losses
│ │ ├── tank.py # Well-mixed tank (dynamic ODE)
│ │ ├── flash.py # Isothermal flash separator
│ │ └── heater.py # Temperature control heater
│ ├── modelica/ # OMPython bridge: .mo transpiler + omc runner
│ │ ├── transpiler.py # transpile() — config → Modelica source
│ │ ├── mo_writer.py # build_model_source() — string builder
│ │ ├── unit_equations.py # Per-unit equation generators
│ │ └── omc_runner.py # compile_modelica() — OMPython validate + FMU
│ ├── utils/ # Utilities
│ │ ├── validate_flowsheet.py # Schema + connectivity validation
│ │ └── flowsheet_diagram.py # Graphviz visualization
│ └── schemas/ # Bundled JSON schemas
│ └── flowsheet_schema.json
├── flowsheets/ # Example flowsheet configurations
│ ├── closed-loop-chain.json # Dynamic recycle example
│ └── archive/ # Additional examples
├── pyproject.toml # Project configuration
└── MANIFEST.in # Source distribution manifest
Dependencies
Core dependencies (always installed):
- numpy - Numerical computing
- scipy - Scientific computing, ODE solvers, sparse linear algebra
- coolprop - Thermodynamic property calculations
- matplotlib - Plotting and visualization
- loguru - Logging
- jsonschema - Configuration validation
- graphviz - Flowsheet diagram generation
- pandas - Data manipulation
- openpyxl - Excel report generation
- zarr - Chunked storage for simulation outputs
Optional EO solver backends:
- pyomo ≥ 6.7 — Pyomo + IPOPT backend (
pip install "processforge[eo]") - casadi ≥ 3.6 — CasADi AD-based backend (
pip install "processforge[eo-casadi]") - OMPython ≥ 1.4 — Python API to OpenModelica compiler (
pip install "processforge[modelica]"). Requires OpenModelica installed on the system.
Logo credit
Google Gemini / Nano Banana
License
This project is licensed under the BSD 3-Clause License. See the LICENSE file for details.
For licensing inquiries, please contact the development team.
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 processforge-0.2.14.tar.gz.
File metadata
- Download URL: processforge-0.2.14.tar.gz
- Upload date:
- Size: 69.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c39dad15f86b9c48a75dde9e54d8fe84c502955a6c5a093e3798a4b9bd8c220c
|
|
| MD5 |
886f451e1dd721175e60e8e85ec9c2c9
|
|
| BLAKE2b-256 |
2be4aba15eecc8e51b50d39cf2d9e8fe25569fabb9e12e906e99e05339d3d2f9
|
File details
Details for the file processforge-0.2.14-py3-none-any.whl.
File metadata
- Download URL: processforge-0.2.14-py3-none-any.whl
- Upload date:
- Size: 84.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
345550cb5648e3ccc7d5d51dbc51bd3c141f591e51c5bcb3440dc3376f4852d1
|
|
| MD5 |
ef4c34dfd0b820771a7fd26a878373b7
|
|
| BLAKE2b-256 |
f0b71179ff3d04f9ad4ccc79047ee17634595c509e32a3ff0f8a9d04d044e804
|