bw-graph-tools


Namebw-graph-tools JSON
Version 0.5 PyPI version JSON
download
home_pageNone
SummaryGraph traversal class and utilities
upload_time2024-09-10 11:03:33
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseNone
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # bw_graph_tools

[![PyPI](https://img.shields.io/pypi/v/bw_graph_tools.svg)][pypi status]
[![Status](https://img.shields.io/pypi/status/bw_graph_tools.svg)][pypi status]
[![Python Version](https://img.shields.io/pypi/pyversions/bw_graph_tools)][pypi status]
[![License](https://img.shields.io/pypi/l/bw_graph_tools)][license]

[![Read the documentation at https://bw_graph_tools.readthedocs.io/](https://img.shields.io/readthedocs/bw_graph_tools/latest.svg?label=Read%20the%20Docs)][read the docs]
[![Tests](https://github.com/brightway-lca/bw_graph_tools/workflows/Tests/badge.svg)][tests]
[![Codecov](https://codecov.io/gh/brightway-lca/bw_graph_tools/branch/main/graph/badge.svg)][codecov]

[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)][pre-commit]
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]

[pypi status]: https://pypi.org/project/bw_graph_tools/
[read the docs]: https://bw_graph_tools.readthedocs.io/
[tests]: https://github.com/brightway-lca/bw_graph_tools/actions?workflow=Tests
[codecov]: https://app.codecov.io/gh/brightway-lca/bw_graph_tools
[pre-commit]: https://github.com/pre-commit/pre-commit
[black]: https://github.com/psf/black

## Installation

You can install _bw_graph_tools_ via [pip] from [PyPI]:

```console
$ pip install bw_graph_tools
```

Packages are also on conda at the [channel cmutel](https://anaconda.org/cmutel/bw_graph_tools).

## Usage

`bw_graph_tools` has three main components: A graph traversal class `NewNodeEachVisitGraphTraversal`; a function to guess production exchanges using only `bw_processing` datapackages `guess_production_exchanges`; and a function to find the path from node `A` to node `B` with the largest amount of the reference product of `A`, `get_path_from_matrix` and it's sister `path_as_brightway_objects`.

### `NewNodeEachVisitGraphTraversal`

Normally we construct matrices and solve the resulting set of linear equations to get a life cycle inventory or impact assessment result. The matrix approach is elegant, in that it simultaneously solves all equations and handles cycles in the graph, and much faster than graph traversal. However, in some cases we want to actually traverse the supply chain graph and calculate the individual impact of visiting nodes at that point in the graph. Graph traversal's use cases include:

* Distinguishing between different paths to the same object

* Convolving temporal distributions

If we add temporal information using `bw_temporalis`, then the same node can occur at different times depending on how the temporal dynamics its preceding path. For example:


## Contributing

Contributions are very welcome.
To learn more, see the [Contributor Guide].

## License

Distributed under the terms of the [BSD 3 Clause license][license],
_bw_graph_tools_ is free and open source software.

## Issues

If you encounter any problems,
please [file an issue] along with a detailed description.

## Documentation

1. Install the conda environment from the file `.docs/environment.yml`
2. Build the documentation locally by running:

```bash
sphinx-autobuild docs _build/html -a -j auto --open-browser
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "bw-graph-tools",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": "Chris Mutel <cmutel@gmail.com>",
    "keywords": null,
    "author": null,
    "author_email": "Chris Mutel <cmutel@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/c9/f8/6bf5a2338a9f9c84573afece4c1ebf5271c4c3c20a155b23a242296550c2/bw_graph_tools-0.5.tar.gz",
    "platform": null,
    "description": "# bw_graph_tools\n\n[![PyPI](https://img.shields.io/pypi/v/bw_graph_tools.svg)][pypi status]\n[![Status](https://img.shields.io/pypi/status/bw_graph_tools.svg)][pypi status]\n[![Python Version](https://img.shields.io/pypi/pyversions/bw_graph_tools)][pypi status]\n[![License](https://img.shields.io/pypi/l/bw_graph_tools)][license]\n\n[![Read the documentation at https://bw_graph_tools.readthedocs.io/](https://img.shields.io/readthedocs/bw_graph_tools/latest.svg?label=Read%20the%20Docs)][read the docs]\n[![Tests](https://github.com/brightway-lca/bw_graph_tools/workflows/Tests/badge.svg)][tests]\n[![Codecov](https://codecov.io/gh/brightway-lca/bw_graph_tools/branch/main/graph/badge.svg)][codecov]\n\n[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)][pre-commit]\n[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]\n\n[pypi status]: https://pypi.org/project/bw_graph_tools/\n[read the docs]: https://bw_graph_tools.readthedocs.io/\n[tests]: https://github.com/brightway-lca/bw_graph_tools/actions?workflow=Tests\n[codecov]: https://app.codecov.io/gh/brightway-lca/bw_graph_tools\n[pre-commit]: https://github.com/pre-commit/pre-commit\n[black]: https://github.com/psf/black\n\n## Installation\n\nYou can install _bw_graph_tools_ via [pip] from [PyPI]:\n\n```console\n$ pip install bw_graph_tools\n```\n\nPackages are also on conda at the [channel cmutel](https://anaconda.org/cmutel/bw_graph_tools).\n\n## Usage\n\n`bw_graph_tools` has three main components: A graph traversal class `NewNodeEachVisitGraphTraversal`; a function to guess production exchanges using only `bw_processing` datapackages `guess_production_exchanges`; and a function to find the path from node `A` to node `B` with the largest amount of the reference product of `A`, `get_path_from_matrix` and it's sister `path_as_brightway_objects`.\n\n### `NewNodeEachVisitGraphTraversal`\n\nNormally we construct matrices and solve the resulting set of linear equations to get a life cycle inventory or impact assessment result. The matrix approach is elegant, in that it simultaneously solves all equations and handles cycles in the graph, and much faster than graph traversal. However, in some cases we want to actually traverse the supply chain graph and calculate the individual impact of visiting nodes at that point in the graph. Graph traversal's use cases include:\n\n* Distinguishing between different paths to the same object\n\n* Convolving temporal distributions\n\nIf we add temporal information using `bw_temporalis`, then the same node can occur at different times depending on how the temporal dynamics its preceding path. For example:\n\n\n## Contributing\n\nContributions are very welcome.\nTo learn more, see the [Contributor Guide].\n\n## License\n\nDistributed under the terms of the [BSD 3 Clause license][license],\n_bw_graph_tools_ is free and open source software.\n\n## Issues\n\nIf you encounter any problems,\nplease [file an issue] along with a detailed description.\n\n## Documentation\n\n1. Install the conda environment from the file `.docs/environment.yml`\n2. Build the documentation locally by running:\n\n```bash\nsphinx-autobuild docs _build/html -a -j auto --open-browser\n```\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Graph traversal class and utilities",
    "version": "0.5",
    "project_urls": {
        "homepage": "https://github.com/brightway-lca/bw_graph_tools",
        "source": "https://github.com/brightway-lca/bw_graph_tools",
        "tracker": "https://github.com/brightway-lca/bw_graph_tools/issues"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "87d4201a3b32b168cc0d6a7ccc6fd7777e9b3324f94a6984d9e6298a485a7502",
                "md5": "ed1cd1dcf91e3169b586e85acb9f42d6",
                "sha256": "f73f3c296be2be87ec3ce2792d63d614a8bb2da409e6a6d4c35fa580f20c4404"
            },
            "downloads": -1,
            "filename": "bw_graph_tools-0.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "ed1cd1dcf91e3169b586e85acb9f42d6",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 29338,
            "upload_time": "2024-09-10T11:03:32",
            "upload_time_iso_8601": "2024-09-10T11:03:32.172911Z",
            "url": "https://files.pythonhosted.org/packages/87/d4/201a3b32b168cc0d6a7ccc6fd7777e9b3324f94a6984d9e6298a485a7502/bw_graph_tools-0.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c9f86bf5a2338a9f9c84573afece4c1ebf5271c4c3c20a155b23a242296550c2",
                "md5": "851442cb5949e1c9f9fd37637b05f33a",
                "sha256": "38c72f050168a968f25349a9c410c17f2135309cc506c51f5a16b0252b8c5f0a"
            },
            "downloads": -1,
            "filename": "bw_graph_tools-0.5.tar.gz",
            "has_sig": false,
            "md5_digest": "851442cb5949e1c9f9fd37637b05f33a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 30590,
            "upload_time": "2024-09-10T11:03:33",
            "upload_time_iso_8601": "2024-09-10T11:03:33.888174Z",
            "url": "https://files.pythonhosted.org/packages/c9/f8/6bf5a2338a9f9c84573afece4c1ebf5271c4c3c20a155b23a242296550c2/bw_graph_tools-0.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-09-10 11:03:33",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "brightway-lca",
    "github_project": "bw_graph_tools",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "bw-graph-tools"
}
        
Elapsed time: 0.30559s