Python interface for building, running, and analyzing CFAST fire simulation models
Project description
PyCFAST
PyCFAST is a Python interface for the Consolidated Fire and Smoke Transport (CFAST) fire simulation software. Its primary goal is to automate CFAST calculations at scale, run parametric studies, sensitivity analyses, data generation, or optimization loops that would be impractical through the graphical interface (CEdit). It also provides a convenient way to create CFAST input files, execute simulations, and analyze results using the versatility and extensive ecosystem of Python.
From CEdit GUI to Python
PyCFAST can be seen as an alternative to the CFAST graphical interface, CEdit. It exposes Python objects that integrate naturally into your Python workflow. Instead of relying on modifying input files through the GUI, you define and manipulate CFAST models programmatically.
| CEdit (GUI) | PyCFAST (Python) |
from pycfast import Compartment
room = Compartment(
id="Comp 1",
width=10.0,
depth=10.0,
height=10.0,
ceiling_mat_id="Gypboard",
wall_mat_id="Gypboard",
floor_mat_id="Gypboard",
)
|
Example Usage
This minimal model runs with just a title and one compartment with default values:
from pycfast import CFASTModel, Compartment, SimulationEnvironment
model = CFASTModel(
simulation_environment=SimulationEnvironment(title="My Simulation"),
compartments=[Compartment()],
# you can also add: fires, wall_vents, ceiling_floor_vents, mechanical_vents, ...
file_name="my_simulation.in",
)
model.summary()
model.save()
For a full model with all components:
from pycfast import (
CeilingFloorVent,
CFASTModel,
Compartment,
Fire,
Material,
MechanicalVent,
SimulationEnvironment,
WallVent,
)
model = CFASTModel(
simulation_environment=SimulationEnvironment(...),
material_properties=[Material(...)],
compartments=[Compartment(...)],
wall_vents=[WallVent(...)],
ceiling_floor_vents=[CeilingFloorVent(...)],
mechanical_vents=[MechanicalVent(...)],
fires=[Fire(...)],
file_name="test_simulation.in",
)
Or you can import your existing model from a CFAST input file:
from pycfast.parsers import parse_cfast_file
model = parse_cfast_file("existing_model.in")
Then you can run the model and obtain results as pandas DataFrames:
results = model.run()
# results is a dict of pandas DataFrames
# Available keys: compartments, devices, masses, vents, walls, zones
results["compartments"].head()
# Time ULT_1 LLT_1 HGT_1 VOL_1 PRS_1 ...
# 0 0.0 20.00 20.00 5.00 0.01 0.0 ...
# 1 1.0 20.83 20.00 5.00 0.10 0.0 ...
results["devices"].head()
# Time TRGGAST_1 TRGSURT_1 TRGINT_1 TRGFLXI_1 ...
# 0 0.0 20.0 20.0 20.0 0.0 ...
# 1 1.0 20.0 20.0 20.0 0.38 ...
Note: When importing an existing model, ensure that all component names (such as TITLE, MATERIAL, ID, etc.) use only alphanumeric characters. Avoid special characters like quotes and slashes, as these may cause parsing issues and will be automatically sanitized where possible.
You can also inspect the model interactively on Jupyter or VS Code, or use text-based methods:
model # interactive HTML card in Jupyter/VS Code
model.summary() # text summary to stdout
model.save() # writes the CFAST input file to disk
model.view_cfast_input_file() # view the generated input file
With this library you can easily obtain a similar data generation workflow as below:
https://github.com/user-attachments/assets/359045a2-4645-4e95-a788-55bb6aff4b6c
Check out the examples for more usage scenarios.
Installation
PyCFAST requires Python 3.10 or later. It is fully tested on verification input file from CFAST version 7.7.0 to version 7.7.5.
Pip or Conda
PyCFAST can be installed from PyPI or conda-forge:
pip install pycfast
conda install -c conda-forge pycfast
Source
To install PyCFAST from source, clone the repository and install the required dependencies:
git clone https://github.com/bewygs/pycfast.git
cd pycfast
python -m pip install .
CFAST Installation
Download and install CFAST from the NIST CFAST website or the CFAST GitHub repository. Follow the installation instructions for your operating system and ensure cfast is available in your PATH. If CFAST is installed in a non-standard location, you can manually specify the path with these methods :
-
From an environment variable
CFAST:export CFAST="/path/to/your/cfast/executable" # Linux/MacOS set CFAST="C:\path\to\your\cfast\executable" # Windows (cmd) $env:CFAST="C:\path\to\your\cfast\executable" # Windows (PowerShell)
-
From Python code when defining the
CFASTModel:import pycfast # set custom CFAST executable path via environment variable import os os.environ['CFAST'] = "/path/to/your/cfast/executable" # Or directly when defining CFASTModel model = pycfast.CFASTModel(cfast_path="/path/to/your/cfast/executable")
Documentation
Full documentation, including the API reference and examples, is available online: PyCFAST Documentation
Contributing
We welcome contributions! Please see our Contributing Guide for more information.
References
If you use PyCFAST in your projects, please consider citing the following:
@software{wygas_2026_pycfast,
author = {Wygas, Benoît},
title = {PyCFAST},
year = {2026},
publisher = {Zenodo},
doi = {10.5281/zenodo.18703351},
url = {https://doi.org/10.5281/zenodo.18703351}
}
Acknowledgments
This Python package was developed with the support of Orano.
PyCFAST is built on top of the work of the CFAST development team at the National Institute of Standards and Technology (NIST). We acknowledge their ongoing efforts in maintaining and improving the CFAST fire modeling software.
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
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 pycfast-0.1.4.tar.gz.
File metadata
- Download URL: pycfast-0.1.4.tar.gz
- Upload date:
- Size: 178.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
23648a167ab105dd1b8a7688385d7eceb26dab215c5787afcc7c4bf871290f31
|
|
| MD5 |
25072eb81e87cc5d09fd0acc8f083ca2
|
|
| BLAKE2b-256 |
1e55771ab460ddaf64fff54eda589b3a6f080718edd0c6763d286755ac8caf81
|
Provenance
The following attestation bundles were made for pycfast-0.1.4.tar.gz:
Publisher:
python-publish.yml on bewygs/pycfast
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pycfast-0.1.4.tar.gz -
Subject digest:
23648a167ab105dd1b8a7688385d7eceb26dab215c5787afcc7c4bf871290f31 - Sigstore transparency entry: 1330032838
- Sigstore integration time:
-
Permalink:
bewygs/pycfast@9a1febdf66fb9cd7c13165ed76ade822b730124e -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/bewygs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@9a1febdf66fb9cd7c13165ed76ade822b730124e -
Trigger Event:
release
-
Statement type:
File details
Details for the file pycfast-0.1.4-py3-none-any.whl.
File metadata
- Download URL: pycfast-0.1.4-py3-none-any.whl
- Upload date:
- Size: 182.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9e82d9230c790f662ff62ac063bc1f3fe42e179f15c9b2c9259f1ccf6c8b4850
|
|
| MD5 |
f1ad00aaeb3c322ec8b3891d39a3ffba
|
|
| BLAKE2b-256 |
21ec7dcb1bd2c400242ffc2f4c328777fd87184ad6d462e2a42b6dd243689a40
|
Provenance
The following attestation bundles were made for pycfast-0.1.4-py3-none-any.whl:
Publisher:
python-publish.yml on bewygs/pycfast
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pycfast-0.1.4-py3-none-any.whl -
Subject digest:
9e82d9230c790f662ff62ac063bc1f3fe42e179f15c9b2c9259f1ccf6c8b4850 - Sigstore transparency entry: 1330032926
- Sigstore integration time:
-
Permalink:
bewygs/pycfast@9a1febdf66fb9cd7c13165ed76ade822b730124e -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/bewygs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@9a1febdf66fb9cd7c13165ed76ade822b730124e -
Trigger Event:
release
-
Statement type: