Skip to main content

This projects provides as slim Python wrapper to access the 'technology-data' data set / snakemake workflow, maintained by the PyPSA team.

Project description

Energy Modeling Technology Data

This tool provides a slim Python wrapper to access the "technology-data" data set / Snakemake workflow, maintained by the PyPSA team.

🚨 🚨 Please check the license of the technology-data repo, especially regarding the applicable licences of various input (and therefore output) data files. Additional info can be found starting at 74 and 87. Be aware that this wrapper can in no way guarantee that the data being pulled from the repository, or the way that is being processed, or the code retrieved from the repository, or any related information is in accordance with applicable licenses.

Getting Started

In an existing environment

Use the tool of your choice, for example uv, to add emtd to your environment:

uv add emtd

In a new environment

The following example assumes that you are using uv. Other ways should work in a similar fashion.

First setup a new environment:

uv venv

Then activate it:

Windows:

.venv\Scripts\activate

Linux:

source .venv/bin/activate

And finally add emtd to your environment:

uv add emtd

Basic usage

Now you can run the following examplatory code:

from emtd import EMTD

# Use `./tmpdir` to store intermediate results.
data = EMTD(target_dir="tmpdir")

# Get all available technologies in 2030.
data.technologies(2030)

# Get all available parameters for the technology "solar" in 2030.
data.parameters(2030, "solar")

# Get the "lifetime" of "solar" in 2030.
res = data.get(2030, "solar", "lifetime")

# Try out:
res["value"]
res["unit"]
res["source"]

Reproducibility

To make sure everyone using your code will get the same results from emtd, it is advised to fix the data set to a specific version. Consult the release page for available versions, then make sure to initialize using (e.g.):

data = EMTD(target_dir="tmpdir", version="v0.6.2")

Make sure to include the v in the version string. Passing "latest" will put you on the current latest version of the technology data repository. Be aware that this can change anytime, and the next time you initialize emtd, it will try to update.

Logging

To get more information about what is happening, you can change the default logging level, by adding the following code:

import logging

logging.basicConfig(level=logging.INFO)

Configuring the Snakemake workflow

To change parameters in the Snakemake workflow, pass a dict to EMTD:

data = EMTD(target_dir="tmpdir", params={"rate_inflation": 0.03})

This overwrites the defaults set by "technology-data", or adds to it if the respective setting is not specified there. Consult technology-data/config.yaml for the current settings or hints at what can be changed. Also, consult their documentation.

Common Errors

The current project's supported Python range (>=3.9,<4.0) is not compatible with some of the required packages Python requirement:
  - scipy requires Python <3.13,>=3.9, so it will not be satisfied for Python >=3.13,<4.0

This, or similar errors, can occur if the pyproject.toml (or similar) specifies a too broad range of Python versions, like:

[tool.poetry.dependencies]
python = "^3.9"

Changing that based on the proposed range (here <3.13,>=3.9 from scipy) to:

[tool.poetry.dependencies]
python = ">=3.9,<3.13"

will fix that.


subprocess.CalledProcessError: Command '['git', '-C', PosixPath('tmpdir'), 'pull']' returned non-zero exit status 1.

This error indicates an error during executing git pull. If you've previously used a target_dir = "tmpdir and pulled, e.g., version="v0.6.1", and are now using EMTD(target_dir="tmpdir") (without version), the pull will fail; make sure to stick to one version, or use a different target_dir for managing different versions.

Developing emtd

This is a rough outline of how to get started with developing emtd:

  1. Clone this repository: git clone https://github.com/sstroemer/emtd.git.
  2. Create a new environment: uv venv.
  3. Activate the environment: source .venv/bin/activate.
  4. Install the dependencies: uv sync.
  5. If you are using VSCode, PyCharm, etc., select .venv/bin/python as the interpreter.

Depending on how you work with it, consider using uv pip install -e ..

Updating packages

Currently the proposed way is:

uv lock --upgrade
uv sync

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

emtd-0.3.1.tar.gz (7.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

emtd-0.3.1-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file emtd-0.3.1.tar.gz.

File metadata

  • Download URL: emtd-0.3.1.tar.gz
  • Upload date:
  • Size: 7.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for emtd-0.3.1.tar.gz
Algorithm Hash digest
SHA256 39ad09b8ae1918f863bef1b49a78e61a20d971edf40e53ce8eaef7c097d9b077
MD5 b1ed52b69a5f970c4d5978356433a758
BLAKE2b-256 125437159370a5fdceed6d13812d28cc777454d57901dd84601c8e4a9aa64418

See more details on using hashes here.

Provenance

The following attestation bundles were made for emtd-0.3.1.tar.gz:

Publisher: pypi_publish.yml on sstroemer/emtd

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

File details

Details for the file emtd-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: emtd-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for emtd-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d3ce7380a6dfacddec84103f5bd6595987dc2ec880ac9f511f564c67951d16de
MD5 9bca199a05e4c4cadd329b583ab96c16
BLAKE2b-256 e89f6ab4335c4ce6ad71575a946804750f71c912655a242040850c7d098a6850

See more details on using hashes here.

Provenance

The following attestation bundles were made for emtd-0.3.1-py3-none-any.whl:

Publisher: pypi_publish.yml on sstroemer/emtd

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