Skip to main content

This library provides a layer above brightway2 for defining parametric models and running super fast LCA for monte carlo analysis.

Project description

Introduction

This library is a small layer above brightway2, designed for the definition of parametric inventories with fast computation of LCA impacts, suitable for monte-carlo analyis.

lca-algebraic provides a set of helper functions for :

  • compact & human readable definition of activites :
    • search background (tech and biosphere) activities
    • create new foreground activites with parametrized amounts
    • parametrize / update existing background activities (extending the class Activity)
  • Definition of parameters
  • Fast computation of LCAs
  • Computation of monte carlo method and global sensivity analysis (Sobol indices)

Installation

If you already have Anaconda & Jupyter installed, you can install the library with either pip or conda :

Conda

conda install -c oie-minesparistech lca_algebraic

PIP

pip install lca_algebraic

Pre-packaged installer for Windows

Alternatively, you can download and execute this installer. It will setup a full anaconda environment with Jupyter, Brightway2 and LCA Algebraic.

Usage & documentation

Please refer to the sample notebook (Markdown) (or here as ipynb).

The full API is documented here.

Licence & Copyright

This library has been developed by OIE - MinesParistech, for the project INCER-ACV, lead by ADEME.

It is distributed under the BSD licence.

Principles

The main idea of this libray is to move from procedural definition of models (slow and prone to errors) to a declarative / purely functionnal definition of parametric models (models as pure functions).

This enables fast computation of LCA impacts. We leverage the power of symbolic calculus provided by the great libary SymPy.

We define our model in a separate DB, as a nested combination of :

  • other foreground activities
  • background activities :
    • Technical, refering ecoinvent DB
    • Biopshere, refering brightway2 biosphere activities

The amounts in exchanges are expressed either as static amounts, or symbolic expressions of pre-defined parameters.

Each activity of our root model is defined as a parametrized combination of the foreground activities, which can themselves be expressed by the background activities.

When computing LCA for foreground models, the library develops the model as a combination of only background activities. It computes once for all the impact of background activities and compiles a fast numpy (vectorial) function for each impact, replacing each background activity by the static value of the corresponding impact.

By providing large vectors of parameter values to those numpy functions, we can compute LCA for thousands of values at a time.

Compatibility with brightway2

Under the hood, the activities we define with lca-algebraic are standard brightway2 activities. The amounts of exchanges are stored as float values or serialized as string in the property formula.

Parameters are also stored in the brightay2 projets, making it fully compatible with brightway.

Thus, a model defined with lca-algebraic is stored as a regular bw2 projet. We can use bw2 native support for parametrized dataset for computing LCAs, even if much more slower than the method explain here.

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

lca_algebraic_dev-1.0.5.1681181.dev0.tar.gz (845.3 kB view details)

Uploaded Source

Built Distribution

lca_algebraic_dev-1.0.5.1681181.dev0-py2.py3-none-any.whl (56.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file lca_algebraic_dev-1.0.5.1681181.dev0.tar.gz.

File metadata

File hashes

Hashes for lca_algebraic_dev-1.0.5.1681181.dev0.tar.gz
Algorithm Hash digest
SHA256 192a388cbf899e58d3a4688504a4a0454da486381f957ae17615407e03d19613
MD5 72d5137edc99a237b20259b5b6d1425e
BLAKE2b-256 d0622caa7ae9b5702181b5777b7c3cd995d30d5b060b6dd280b3f9814e64b0af

See more details on using hashes here.

File details

Details for the file lca_algebraic_dev-1.0.5.1681181.dev0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for lca_algebraic_dev-1.0.5.1681181.dev0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 bc3c8cb2e5d99f7d3b6cdf16793792d5b58e950efde7b1b32f90d721aaaad9a9
MD5 c851ff0ca06f9b886940a62eb2c0f586
BLAKE2b-256 5d79fc8f0a52f7c3dba9479f7a1536f8932e15fcdaad7eb29b73f9c83d121d86

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page