Introduction¶
A short video explaining the logic of PyPSA-Eur which is similar to PyPSA-Earth:
For more details on PyPSA-Earth read the below milestone paper. For citations, please use the following BibTeX:
@misc{PyPSAEarth,
author = {Parzen, Maximilian and Abdel-Khalek, Hazem and Fedorova, Ekaterina and Mahmood, Matin and Frysztacki, Martha Maria and Hampp, Johannes and Franken, Lukas and Schumm, Leon and Neumann, Fabian and Poli, Davide and Kiprakis, Aristides and Fioriti, Davide},
title = {PyPSA-Earth. A new global open energy system optimization model demonstrated in Africa},
publisher = {Applied Energy},
year = {2023},
url = {https://www.sciencedirect.com/science/article/pii/S030626192300460},
doi = {https://doi.org/10.1016/j.apenergy.2023.121096},
}
Workflow¶
The generation of the model is controlled by the workflow management system Snakemake. In a nutshell, the Snakefile declares for each python script in the scripts directory a rule which describes which files the scripts consume and produce (their corresponding input and output files). The snakemake tool then runs the scripts in the correct order according to the rules' input/output dependencies. Moreover, it is able to track what parts of the workflow have to be regenerated when a data file or a script is modified/updated. For example, by executing the following snakemake routine:
the following workflow is automatically executed.

The blocks represent the individual rules which are required to create the file networks/elec_s_128.nc. Each rule requires scripts (e.g. Python) to convert inputs to outputs. The arrows indicate the outputs from preceding rules which a particular rule takes as input data.
Data Management System¶
PyPSA-Earth has a comprehensive set of pre-compiled datasets which provides all the inputs needed to build and run an energy system model for any country of the world. A specification of modelling-ready databundles is available in configs/bundle_config.yaml.
The datasets are available for various spatial scales, from global to national ones and can be extracted at an initial stage of running the model as described in Installation section. A data management system retrieve_databundle_light selects the databundles which matches best settings defined in the configuration file and extracts them automatically.
Folder structure¶
The content in this package is organized in folders as described below; for more details, please see the documentation.
data: Includes input data that is not produced by anysnakemakerule.scripts: Includes all the Python scripts executed by thesnakemakerules.resources: Stores intermediate results of the workflow which can be picked up again by subsequent rules.networks: Stores intermediate, unsolved stages of the PyPSA network that describes the energy system model.results: Stores the solved PyPSA network data, summary files and plots.benchmarks: Storessnakemakebenchmarks.logs: Stores log files about solving, including the solver output, console output and the output of a memory logger.envs: Stores the conda environment files to successfully run the workflow.
License¶
PyPSA-Earth work is released under multiple licenses:
- All original source code is licensed as free software under AGPL-3.0 License.
- The documentation is licensed under CC-BY-4.0.
- Configuration files are mostly licensed under CC0-1.0.
- Data files are licensed under different licenses as noted below.
Individual files contain license information in the header or in the dep5. Additional licenses and urls of the data used in PyPSA-Earth:
| Files | Licence | BY | NC | SA | Mark Changes | Detail |
|---|---|---|---|---|---|---|
| data/raw/copernicus/* | Custom | x | nan | nan | x | https://cds.climate.copernicus.eu/cdsapp/#!/terms/licence-to-use-copernicus-products |
| data/raw/eez/* | CC4.0 | x | x | x | nan | http://www.marineregions.org/disclaimer.php |
| data/raw/landcover/* | Custom | x | x | nan | nan | https://www.protectedplanet.net/en/legal |
| data/raw/gadm/* | CC4.0 | x | x | nan | x | https://gadm.org/data.html |
| data/raw/gebco/* | nan | x | nan | nan | nan | https://www.gebco.net/data_and_products/gridded_bathymetry_data/arctic_ocean/#terms |
| data/hydro_capacities.csv | nan | x | nan | nan | nan | nan |
| data/raw/hydrobasins/* | Custom | x | x | nan | nan | https://www.hydrosheds.org/page/license |
| data/raw/WorldPop/* | CC | x | nan | nan | nan | https://www.worldpop.org/ |
| data/raw/GDP/* | CC1.0 | nan | nan | nan | nan | https://datadryad.org/stash/dataset/doi:10.5061/dryad.dk1j0 |
| data/osm/* | ODbL | nan | nan | nan | nan | https://www.openstreetmap.org/copyright |
| data/demand/unsd/* | Custom | x | nan | nan | nan | https://unstats.un.org/unsd/energystats/data/ |
| data/industrial_database.csv | CC | x | nan | nan | nan | https://globalenergymonitor.org/projects/global-steel-plant-tracker/download-data/ |
| data/industrial_database.csv | CC4.0 | x | nan | nan | nan | https://www.cgfi.ac.uk/spatial-finance-initiative/geoasset-project/cement/ |
| data/industrial_database.csv | CC4.0 | x | nan | nan | nan | https://www.cgfi.ac.uk/spatial-finance-initiative/geoasset-project/pulp-and-paper-mill-database-for-latin-america/ |
| data/airports.csv | Public Domain | nan | nan | nan | nan | https://ourairports.com/data/ |
Legend:
- BY: Attribute Source
- NC: Non-Commercial Use Only
- SA: Share Alike