Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

fdsreader

Package Overview
Dependencies
Maintainers
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

fdsreader

Python reader for data generated by FDS.

  • 1.11.6
  • PyPI
  • Socket score

Maintainers
3

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
KEYVALUEDefaultDescription
LAZY_LOADbooleanTrueLoad all data when initially loading the simulation (False) or only when specific data is needed (True).
ENABLE_CACHINGbooleanTrueCache the loaded simulation to reduce startup times when loading the same simulation again.
DEBUGbooleanFalseCrash on non-critical errors with an exception (True) or output non-critical errors as warnings (False).
IGNORE_ERRORSbooleanFalseIgnore 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. Push Tag to GitHub with git push origin tag

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

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc