Skip to main content

Python reader for data generated by FDS.

Project description

FDSReader

Fast and easy-to-use Python reader for FDS data

PyPI version

Installation

The package is available on PyPI and can be installed using pip:

pip install fdsreader

FDS Version 6.7.5 and above are fully supported. Versions below 6.7.5 might work, but are not guaranteed to work.

Usage example

import fdsreader as fds

# Creates an instance of a simulation master-class which manages all data for a given simulation
sim = fds.Simulation("./sample_data")

# Examples of data that can be easily accessed
print(sim.meshes, sim.surfaces, sim.slices, sim.data_3d, sim.smoke_3d, sim.isosurfaces, sim.particles, sim.obstructions)

More advanced examples can be found in the respective data type directories inside of the examples directory.

Configuration

The package provides a few configuration options that can be set using the settings module.

fds.settings.KEY = VALUE

# Example
fds.settings.DEBUG = True
KEY VALUE Default Description
LAZY_LOAD boolean True Load all data when initially loading the simulation (False) or only when specific data is needed (True).
ENABLE_CACHING boolean True Cache the loaded simulation to reduce startup times when loading the same simulation again.
DEBUG boolean False Crash on non-critical errors with an exception (True) or output non-critical errors as warnings (False).
IGNORE_ERRORS boolean False Ignore any non-critical errors completely.

Data structure

Data structure

Beware that not all attributes and methods are covered in this diagram. For a complete
documentation of all classes check the API Documentation below.

API Documentation

https://firedynamics.github.io/fdsreader/

Deployment now follows the Python Packaging User Guide's recommendation.

With this setup, deployments to both TestPyPI and PyPI are automated. Every push to GitHub triggers a deployment to TestPyPI, simplifying the testing of new changes and validating the CI pipeline. Therefore, it is necessary to set the package version to .dev to avoid blocking version numbers.

Deploying an Untested/Unstable Version:

  1. Execute: python3 -m incremental.update fdsreader --dev
  2. Push changes to GitHub.

If you are sure your changes are stable push a GitHub Tag to perform deployment to PyPI and to pack a GitHub Release Deploying a tested/stable version:

  1. set the new version with python3 -m incremental.update fdsreader --newversion=<version>
  2. Push changes to GitHub
  3. Create tag git tag -a v<version> -m "Version <version>"
  4. Push Tag to GitHub with git push origin tag <version>

Manual deployment

It is also possible to deploy to PyPI and Github pages manually using the following steps:

  1. python setup.py sdist bdist_wheel
  2. twine upload dist/*
  3. sphinx-build -b html docs docs/build
  4. cd .. && mkdir gh-pages && cd gh-pages
  5. git init && git remote add origin git@github.com:FireDynamics/fdsreader.git
  6. git fetch origin gh-pages:gh-pages
  7. git checkout gh-pages
  8. cp -r ../fdsreader/docs/build/* .
  9. git add . && git commit -m "..." && git push origin HEAD:gh-pages

Meta

Distributed under the LGPLv3 (GNU Lesser General Public License v3) license. See LICENSE for more information.

https://github.com/FireDynamics/fdsreader

Contributing

  1. Fork it (https://github.com/FireDynamics/fdsreader/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

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

fdsreader-1.11.7.tar.gz (104.6 kB view details)

Uploaded Source

Built Distribution

fdsreader-1.11.7-py3-none-any.whl (109.8 kB view details)

Uploaded Python 3

File details

Details for the file fdsreader-1.11.7.tar.gz.

File metadata

  • Download URL: fdsreader-1.11.7.tar.gz
  • Upload date:
  • Size: 104.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fdsreader-1.11.7.tar.gz
Algorithm Hash digest
SHA256 69afa4ac1bf151f26bddd356d62496b81c5de537b67c3568afc52fe97237134f
MD5 2b738c2a6f1c5373bb94112615b52fb2
BLAKE2b-256 232ccca153de81c4842989cf36dcf32f07120432276f898f8f075e17f1aac0dd

See more details on using hashes here.

Provenance

The following attestation bundles were made for fdsreader-1.11.7.tar.gz:

Publisher: publish_n_pack.yml on FireDynamics/fdsreader

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

File details

Details for the file fdsreader-1.11.7-py3-none-any.whl.

File metadata

  • Download URL: fdsreader-1.11.7-py3-none-any.whl
  • Upload date:
  • Size: 109.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fdsreader-1.11.7-py3-none-any.whl
Algorithm Hash digest
SHA256 7893e73ba5481826e0939b231b3810fa524c70581ecce656e7c46b5665066434
MD5 99f269333eeb82d88730d3139d798ed1
BLAKE2b-256 bdeda36beef46a359509ed188edf2e0d9524a13de2b9a5b9f25dacc0288650ce

See more details on using hashes here.

Provenance

The following attestation bundles were made for fdsreader-1.11.7-py3-none-any.whl:

Publisher: publish_n_pack.yml on FireDynamics/fdsreader

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 Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page