![eCalc Logo](https://raw.githubusercontent.com/equinor/ecalc/main/docs/static/img/logo.svg)
[![CI Build](https://github.com/equinor/ecalc/actions/workflows/on-push-main-branch.yml/badge.svg)](https://github.com/equinor/ecalc/actions/workflows/on-push-main-branch.yml)
![License](https://img.shields.io/github/license/equinor/ecalc)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/libecalc)
![PyPI - Wheel](https://img.shields.io/pypi/wheel/libecalc)
![PyPI - Implementation](https://img.shields.io/pypi/implementation/libecalc)
![Pre-commit - Enabled](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)
# eCalc™
eCalc™ is a software tool for calculation of energy demand and greenhouse gas (GHG) emissions from oil and gas production and processing.
> **Note**
>
> eCalc™ is a work in progress and is by no means considered a finished and final product. We currently recommend to use the YAML API when using eCalc, and only
> fallback to the Python API when it is strictly needed.
> **Warning**
>
> The quality of the results produced by eCalc™ is highly dependent on the quality of the input data. Further, we do not make any guarantees and are not liable for the quality of results when using eCalc™.
---
![eCalc Illustration](https://raw.githubusercontent.com/equinor/ecalc/main/docs/docs/about/ecalc_illustration.svg)
---
## Reference Links
* [**Documentation**](/docs/docs/about/)
* [**Contribution**](CONTRIBUTING.md)
* [**Security**](SECURITY.md)
* [**Code of Conduct**](CODE_OF_CONDUCT.md)
* [**Source Code**](https://github.com/equinor/ecalc)
---
## Introduction
eCalc™ is a software tool for calculation of energy demand and GHG emissions from oil and gas production and processing. It enables the cross-disciplinary collaboration required to achieve high-quality and transparent energy and GHG emission prognosis and decision support.
eCalc™ performs energy and emission calculations by integrating data, knowledge and future plans from different disciplines. This could be production and injection profiles from the reservoir engineer, characteristics of energy consuming equipment units such as gas turbines, compressors and pumps from the facility engineer, and emission factors for different fuels from the sustainability engineer. The main idea is using physical or data-driven models to relate production rates and pressures to the required processing energy and resulting emissions. Integrated bookkeeping for all emission sources is offered.
eCalc™ uses a bottom-up approach to give high-quality installation and portfolio level forecasts at the same time as detailed insights about the energy drivers and processing capacities for the individual installation.
## Getting started
eCalc™ is both a Python library and has a command line interface (CLI) to use with eCalc YAML Models. We currently recommend using eCalc™ from the command line with eCalc YAML Models, since the Python API is about to change soon, but the YAML will
be more or less stable and backwards compatible.
To get started, please refer to the [eCalc™ Docs - Getting Started](/docs/docs/about/getting_started/),
or follow the quick guide below:
### Prerequisites
* [Python](https://www.python.org/), version 3.11 or higher
* Java, version 8 or higher
* [Docker](https://www.docker.com/) (Optional), Linux or MacOS
eCalc™ only supports Python 3, and will follow [Komodo](https://github.com/equinor/komodo) wrt. minimum requirement for Python, which currently is 3.11.
### Installation
```bash
pip install libecalc
ecalc --version
ecalc selftest
```
**Alternative using Docker**:
```bash
docker build --target build -t ecalc .
docker run -it ecalc /bin/bash
```
Inside the docker container, run:
```bash
ecalc --version
ecalc selftest
```
Please refer to [Docker Docs](https://docs.docker.com/) for details on how to use Docker.
**Alternative using devcontainer**:
In vscode:
- Install extension "Dev Containers" and open command palette (ctrl+p or cmd+p or F1) and click "reopen in container" then click the alternative "eCalc Python Dev Environment".
In github codespaces:
- In the repo click the "<> Code" button -> codespaces -> in the codespaces section click the ellipsis menu (three dots) -> click "New with options.." -> under "Dev container configuration" click and choose "eCalc Python Dev Environment" -> then click button "Create Codespace".
![ecalc-selftest](docs/gifs/selftest.gif)
### Create and run your first model
Please refer to the https://equinor.github.io/ecalc/docs/about/modelling/setup/ on how to set up your own model
with the YAML API and https://equinor.github.io/ecalc/docs/about/getting_started/cli/ on how to run it.
See [Examples](#examples) below to use one of our predefined examples.
## Development and Contribution
We welcome all kinds of contributions, including code, bug reports, issues, feature requests, and documentation.
The preferred way of submitting a contribution is to either make an issue on GitHub or by forking the project on GitHub
and making a pull request.
See [Contribution Document](CONTRIBUTING.md) on how to contribute.
See the [Developer Guide](/docs/docs/contribute/get_started.md) for details.
### Running tests
We use pytest for our tests, to run all tests
```shell
poetry run pytest
```
To update inline snapshots
```shell
poetry run pytest -m "inlinesnapshot" --inline-snapshot=fix
```
## Examples
Jupyter Notebook examples can be found in /examples. In order to run these examples, you need to install the optional
dependencies.
### Using pip
```bash
pip install libecalc[notebooks]
```
In the examples you will find examples using both the YAML specifications and Python models. See /examples
Run jupyter:
```bash
jupyter notebook examples
```
### Using poetry
```shell
poetry install --extras notebooks
poetry run jupyter notebook examples
```
## Documentation
The documentation can be found at https://equinor.github.io/ecalc
Raw data
{
"_id": null,
"home_page": "https://github.com/equinor/ecalc",
"name": "libecalc",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.14,>=3.11",
"maintainer_email": null,
"keywords": "energy, emission, scientific, engineering",
"author": "eCalc Team",
"author_email": "fg_ecalc@equinor.com",
"download_url": "https://files.pythonhosted.org/packages/2b/4c/dd0b315a609f022ab8fbbe24dcf884109ce2474d7a66bc42352eca4a94cc/libecalc-9.7.0.tar.gz",
"platform": null,
"description": "![eCalc Logo](https://raw.githubusercontent.com/equinor/ecalc/main/docs/static/img/logo.svg)\n\n[![CI Build](https://github.com/equinor/ecalc/actions/workflows/on-push-main-branch.yml/badge.svg)](https://github.com/equinor/ecalc/actions/workflows/on-push-main-branch.yml)\n![License](https://img.shields.io/github/license/equinor/ecalc)\n[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n![PyPI - Python Version](https://img.shields.io/pypi/pyversions/libecalc)\n![PyPI - Wheel](https://img.shields.io/pypi/wheel/libecalc)\n![PyPI - Implementation](https://img.shields.io/pypi/implementation/libecalc)\n![Pre-commit - Enabled](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white) \n\n# eCalc\u2122\neCalc\u2122 is a software tool for calculation of energy demand and greenhouse gas (GHG) emissions from oil and gas production and processing.\n\n> **Note**\n>\n> eCalc\u2122 is a work in progress and is by no means considered a finished and final product. We currently recommend to use the YAML API when using eCalc, and only\n> fallback to the Python API when it is strictly needed.\n\n> **Warning**\n>\n> The quality of the results produced by eCalc\u2122 is highly dependent on the quality of the input data. Further, we do not make any guarantees and are not liable for the quality of results when using eCalc\u2122.\n\n---\n\n![eCalc Illustration](https://raw.githubusercontent.com/equinor/ecalc/main/docs/docs/about/ecalc_illustration.svg)\n\n\n---\n## Reference Links\n\n* [**Documentation**](/docs/docs/about/)\n* [**Contribution**](CONTRIBUTING.md)\n* [**Security**](SECURITY.md)\n* [**Code of Conduct**](CODE_OF_CONDUCT.md)\n* [**Source Code**](https://github.com/equinor/ecalc)\n\n---\n\n## Introduction\n\neCalc\u2122 is a software tool for calculation of energy demand and GHG emissions from oil and gas production and processing. It enables the cross-disciplinary collaboration required to achieve high-quality and transparent energy and GHG emission prognosis and decision support.\n\neCalc\u2122 performs energy and emission calculations by integrating data, knowledge and future plans from different disciplines. This could be production and injection profiles from the reservoir engineer, characteristics of energy consuming equipment units such as gas turbines, compressors and pumps from the facility engineer, and emission factors for different fuels from the sustainability engineer. The main idea is using physical or data-driven models to relate production rates and pressures to the required processing energy and resulting emissions. Integrated bookkeeping for all emission sources is offered.\n\neCalc\u2122 uses a bottom-up approach to give high-quality installation and portfolio level forecasts at the same time as detailed insights about the energy drivers and processing capacities for the individual installation.\n\n## Getting started\n\neCalc\u2122 is both a Python library and has a command line interface (CLI) to use with eCalc YAML Models. We currently recommend using eCalc\u2122 from the command line with eCalc YAML Models, since the Python API is about to change soon, but the YAML will\nbe more or less stable and backwards compatible.\n\nTo get started, please refer to the [eCalc\u2122 Docs - Getting Started](/docs/docs/about/getting_started/),\nor follow the quick guide below:\n\n### Prerequisites\n\n* [Python](https://www.python.org/), version 3.11 or higher\n* Java, version 8 or higher\n* [Docker](https://www.docker.com/) (Optional), Linux or MacOS\n\neCalc\u2122 only supports Python 3, and will follow [Komodo](https://github.com/equinor/komodo) wrt. minimum requirement for Python, which currently is 3.11.\n\n### Installation\n\n```bash\npip install libecalc\necalc --version\necalc selftest\n```\n\n**Alternative using Docker**:\n\n```bash\ndocker build --target build -t ecalc .\ndocker run -it ecalc /bin/bash\n```\n\nInside the docker container, run:\n\n```bash\necalc --version\necalc selftest\n```\n\nPlease refer to [Docker Docs](https://docs.docker.com/) for details on how to use Docker.\n\n**Alternative using devcontainer**:\n\nIn vscode:\n- Install extension \"Dev Containers\" and open command palette (ctrl+p or cmd+p or F1) and click \"reopen in container\" then click the alternative \"eCalc Python Dev Environment\".\n\nIn github codespaces:\n- In the repo click the \"<> Code\" button -> codespaces -> in the codespaces section click the ellipsis menu (three dots) -> click \"New with options..\" -> under \"Dev container configuration\" click and choose \"eCalc Python Dev Environment\" -> then click button \"Create Codespace\".\n\n\n![ecalc-selftest](docs/gifs/selftest.gif)\n\n### Create and run your first model\n\nPlease refer to the https://equinor.github.io/ecalc/docs/about/modelling/setup/ on how to set up your own model\nwith the YAML API and https://equinor.github.io/ecalc/docs/about/getting_started/cli/ on how to run it.\n\nSee [Examples](#examples) below to use one of our predefined examples.\n\n## Development and Contribution\n\nWe welcome all kinds of contributions, including code, bug reports, issues, feature requests, and documentation.\nThe preferred way of submitting a contribution is to either make an issue on GitHub or by forking the project on GitHub\nand making a pull request.\n\nSee [Contribution Document](CONTRIBUTING.md) on how to contribute.\n\nSee the [Developer Guide](/docs/docs/contribute/get_started.md) for details.\n\n### Running tests\n\nWe use pytest for our tests, to run all tests\n```shell\npoetry run pytest\n```\n\nTo update inline snapshots\n```shell\npoetry run pytest -m \"inlinesnapshot\" --inline-snapshot=fix\n```\n\n## Examples\nJupyter Notebook examples can be found in /examples. In order to run these examples, you need to install the optional\ndependencies.\n\n### Using pip\n```bash\npip install libecalc[notebooks]\n``` \n\nIn the examples you will find examples using both the YAML specifications and Python models. See /examples\n\nRun jupyter:\n\n```bash\njupyter notebook examples\n```\n\n### Using poetry\n\n```shell\npoetry install --extras notebooks\npoetry run jupyter notebook examples\n```\n\n## Documentation\n\nThe documentation can be found at https://equinor.github.io/ecalc\n",
"bugtrack_url": null,
"license": "LGPL-3.0-only",
"summary": "eCalc\u2122 is a software tool for calculation of energy demand and greenhouse gas (GHG) emissions from oil and gas production and processing.",
"version": "9.7.0",
"project_urls": {
"Homepage": "https://github.com/equinor/ecalc",
"Repository": "https://github.com/equinor/ecalc"
},
"split_keywords": [
"energy",
" emission",
" scientific",
" engineering"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "94391800a88f344d4249d1885d6514bd2b081800a0c574c6392d4f2d56c75c0b",
"md5": "7d85e227ffb762f3bc6ccf677eed1167",
"sha256": "26253cff6389d82bd28c07acbfd013f38e1e48f60223cfd57e80230ff1a12883"
},
"downloads": -1,
"filename": "libecalc-9.7.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "7d85e227ffb762f3bc6ccf677eed1167",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.14,>=3.11",
"size": 28974085,
"upload_time": "2025-01-15T12:34:30",
"upload_time_iso_8601": "2025-01-15T12:34:30.669365Z",
"url": "https://files.pythonhosted.org/packages/94/39/1800a88f344d4249d1885d6514bd2b081800a0c574c6392d4f2d56c75c0b/libecalc-9.7.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2b4cdd0b315a609f022ab8fbbe24dcf884109ce2474d7a66bc42352eca4a94cc",
"md5": "330d882710ec994200801c65e3b08aee",
"sha256": "2d30452d61e2fc8ddbea52d5e95c0071e99beeebaba715aebcbab1676402938b"
},
"downloads": -1,
"filename": "libecalc-9.7.0.tar.gz",
"has_sig": false,
"md5_digest": "330d882710ec994200801c65e3b08aee",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<3.14,>=3.11",
"size": 28806450,
"upload_time": "2025-01-15T12:34:36",
"upload_time_iso_8601": "2025-01-15T12:34:36.169417Z",
"url": "https://files.pythonhosted.org/packages/2b/4c/dd0b315a609f022ab8fbbe24dcf884109ce2474d7a66bc42352eca4a94cc/libecalc-9.7.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-15 12:34:36",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "equinor",
"github_project": "ecalc",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "libecalc"
}