Clone the repository including its submodules:
git clone --recurse-submodules https://github.com/open-energy-transition/efuels-supply-potentials.git
Install the necessary dependencies using conda
or mamba
:
mamba env create -f submodules/pypsa-earth/envs/environment.yaml
Activate pypsa-earth
environment:
conda activate pypsa-earth
This project utilizes snakemake
to automate the execution of scripts, ensuring efficient and reproducible workflows. Configuration settings for snakemake are available in the configs/config.main.yaml
file.
To run country-level validation of the U.S. for the base scenario, navigate to the working directory (.../efuels-supply-potentials/
) and use the following command:
snakemake -call validate_all --configfile configs/calibration/config.base.yaml
or base scenario with alternative clustering option (AC):
snakemake -call validate_all --configfile configs/calibration/config.base_AC.yaml
- Note: Ensure that
planning_horizon
inconfigs/config.main.yaml
corresponds to a horizon of the base scenario. By default,planning_horizon
is set to 2020, which means that results are benchmarked agains 2020's historical data.
It is possible to run validation by specifying the output file with wildcards:
snakemake -call plots/results/US_2021/demand_validation_s_10_ec_lcopt_Co2L-24H.png --configfile configs/calibration/config.base.yaml
Validation results are stored in plots/results/
directory under scenario run name (e.g. US_2021
).
To run state-wise validation, run:
snakemake -call statewise_validate_all --configfile configs/calibration/config.base_AC.yaml
Rule name | Config file | Description |
---|---|---|
validate_all |
config.base.yaml , config.base_AC.yaml |
Performs country-level validation comparing with EIA and Ember data |
statewise_validate_all |
config.base_AC.yaml |
Performs statewise validation comparing with EIA data |
get_capacity_factors |
Any base or scenario config file | Estimates capacity factors for renewables |
process_airport_data |
- | Performs analysis on passengers and jet fuel consumption data per state and generates plots and table |
test_modify_prenetwork |
Any base or scenario config file | Example rule that performs modiification of pre-network |
Rule name | Config file | Description |
---|---|---|
retrieve_cutouts |
Any base or scenario config file | Retrieves US cutouts from google drive |
retrieve_osm_raw |
Any base or scenario config file | Retrieves resources/{RDIR}/osm/raw/ data from google drive and bypasses download_osm_data rule |
retrieve_osm_clean |
Any base or scenario config file | Retrieves resources/{RDIR}/osm/clean/ data from google drive and bypasses clean_osm_data rule |
retrieve_shapes |
Any base or scenario config file | Retrieves resources/{RDIR}/shapes/ data from google drive and bypasses build_shapes rule |
retrieve_osm_network |
Any base or scenario config file | Retrieves resources/{RDIR}/base_network/ data from google drive and bypasses build_osm_network rule |
retrieve_base_network |
Any base or scenario config file | Retrieves base.nc data from google drive and bypasses base_network rule |
retrieve_renewable_profiles |
Any base or scenario config file | Retrieves resources/{RDIR}/renewable_profiles/ data from google drive and bypasses build_renewable_profiles rule |
retrieve_custom_powerplants |
Any base or scenario config file | Copies data/custom_powerplants.csv to submodules/pypsa-earth/data/ folder |
retrieve_ssp2 |
Any base or scenario config file | Copies data/NorthAmerica.csv to submodules/pypsa-earth/data/ssp2-2.6/. directory |
RDIR
- scenario folder