pypsa-eur/scripts/build_sequestration_potentials.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

55 lines
1.7 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
2023-03-06 17:49:23 +00:00
# SPDX-FileCopyrightText: : 2023 The PyPSA-Eur Authors
#
# SPDX-License-Identifier: MIT
2023-01-24 17:44:39 +00:00
import geopandas as gpd
import pandas as pd
2023-01-24 17:44:39 +00:00
def area(gdf):
"""
Returns area of GeoDataFrame geometries in square kilometers.
"""
return gdf.to_crs(epsg=3035).area.div(1e6)
def allocate_sequestration_potential(
gdf, regions, attr="conservative estimate Mt", threshold=3
):
gdf = gdf.loc[gdf[attr] > threshold, [attr, "geometry"]]
gdf["area_sqkm"] = area(gdf)
overlay = gpd.overlay(regions, gdf, keep_geom_type=True)
overlay["share"] = area(overlay) / overlay["area_sqkm"]
adjust_cols = overlay.columns.difference({"name", "area_sqkm", "geometry", "share"})
overlay[adjust_cols] = overlay[adjust_cols].multiply(overlay["share"], axis=0)
gdf_regions = overlay.groupby("name").sum()
gdf_regions.drop(["area_sqkm", "share"], axis=1, inplace=True)
return gdf_regions.squeeze()
if __name__ == "__main__":
if "snakemake" not in globals():
from helper import mock_snakemake
2023-01-24 17:44:39 +00:00
snakemake = mock_snakemake(
"build_sequestration_potentials", simpl="", clusters="181"
)
cf = snakemake.config["sector"]["regional_co2_sequestration_potential"]
2023-01-24 17:44:39 +00:00
gdf = gpd.read_file(snakemake.input.sequestration_potential[0])
2023-01-24 17:44:39 +00:00
regions = gpd.read_file(snakemake.input.regions_offshore)
if cf["include_onshore"]:
2023-01-24 17:44:39 +00:00
onregions = gpd.read_file(snakemake.input.regions_onshore)
regions = pd.concat([regions, onregions]).dissolve(by="name").reset_index()
s = allocate_sequestration_potential(
gdf, regions, attr=cf["attribute"], threshold=cf["min_size"]
)
2023-01-24 17:44:39 +00:00
s = s.where(s > cf["min_size"]).dropna()
2023-01-24 17:44:39 +00:00
s.to_csv(snakemake.output.sequestration_potential)