Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Transition from stores to storage units for LTES, introducing energy-to-power ratio #1444

Merged
merged 18 commits into from
Jan 27, 2025

Conversation

TomKae00
Copy link
Contributor

@TomKae00 TomKae00 commented Dec 5, 2024

Changes proposed in this Pull Request

updated 08.01.2025

This pull request introduces the following adjustments to the prepare_sector_network script:

  • Added PTES.
  • Transitioned stores to storage units for ltes, enabling the implementation of an energy-to-power ratio for these components.

The following config data has been used:

scenario:
clusters:
- 6

planning_horizons:
- 2030

foresight: overnight
countries: ['DE', 'DK']

clustering:
temporal:
resolution_sector: 12h

costs:
version: master

max_hours control:

The following figure illustrates the ratio of the state of charge compared to charging and discharging for the exemplary "DE0 0 urban central water pits". Additionally, the maximum hours are shown in relation to the ratio of the maximum state of charge to charging/discharging, demonstrating that the energy-to-power ratio is followed.

storage_unit_analysis

Effect of Changes: Results Analysis

  1. Storage Sizing: stores vs. storage units

The transition from stores to storage units results in larger storage sizing:

energy_supply_comparison

  1. Charging and Discharging Dynamics

The implementation of the energy-to-power ratio limits the charging and discharging rates relative to storage size. This is illustrated in the following plots:

Urban Central Water Tanks:

charging_discharging_urban_central_water_tanks

Urban Central Water Pits:

charging_discharging_urban_central_water_pits

  1. Energy Balances

The changes in charging and discharging dynamics influence the energy balance, as shown for urban central and urban decentral systems in the plots below:

Urban Central Heat:

energy_balance_comparison_urban_central_heat

Urban Decentral Heat:

energy_balance_comparison_urban_decentral_heat

  1. Impact on Total System Costs

The shift from stores to storage units impacts the total system costs slightly, resulting in a small decrease in costs for the storage units compared to stores:

total_cost_comparison

Checklist

  • [✓] I tested my contribution locally and it works as intended.
  • [✓] Code and workflow changes are sufficiently documented.
  • [✓] Changed dependencies are added to envs/environment.yaml.
  • [✓] Changes in configuration options are added in config/config.default.yaml.
  • [✓] Changes in configuration options are documented in doc/configtables/*.csv.
  • [✓] Sources of newly added data are documented in doc/data_sources.rst.
  • [✓] A release note doc/release_notes.rst is added.

@cpschau cpschau self-requested a review December 5, 2024 12:16
Comment on lines 2275 to 2296
"StorageUnit",
nodes + f" {heat_system} water tanks",
bus=nodes + f" {heat_system} water tanks",
e_cyclic=True,
e_nom_extendable=True,
bus=nodes + f" {heat_system} heat",
carrier=f"{heat_system} water tanks",
efficiency_store=costs.at["water tank charger", "efficiency"],
max_hours=costs.at[
"central water tank storage", "energy to power ratio"
],
efficiency_dispatch=costs.at["water tank discharger", "efficiency"],
p_nom_extendable=True,
standing_loss=1 - np.exp(-1 / 24 / tes_time_constant_days),
capital_cost=costs.at[
heat_system.central_or_decentral + " water tank storage", "fixed"
],
lifetime=costs.at[
heat_system.central_or_decentral + " water tank storage", "lifetime"
],
e_nom_extendable=True,
e_cyclic=True,
)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We might need another case distinction for different sizes of water tanks (DEA's "large hot water tank" for urban central heat and "small scale hot water tank" for urban decentral and rural heat), as the DEA provides different energy-to-power-ratio and costs. This would require additional changes in technology-data.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I was thinking that as well. Assuming a single E2P ratio might be very restrictive.

Copy link
Contributor

@cpschau cpschau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @TomKae00,
the implementation looks fine to me. However, the data behind it seems to contain some wrong assumptions that probably sneaked in with the recent changes in the technology-data repository, namely #144 and #152. In my opinion, we should assume (dis-)charger efficiencies of 1, as they are stated in the DEA catalogue. The indicated round-trip-efficiency-losses are probably chosen to give a proxy for the average standing losses. The standing losses, however, are already represented in our model by the configurable parameter tes_tau. Therefore, we would withdraw them twice according to the current implementation. These losses are probably also the reason, why PTES expansion decreases so heavily in your comparison between former "Store" and "StorageUnit" implementation and the total system costs change so much. To fix this issue, I would suggest to

  1. submit a new PR in technology-data that refers the right charger- and discharger efficiencies for tanks and pits (maybe keep the round-trip efficiency as extra-row for people using technology-data without modelling standing losses separately),
  2. ask @lkstrp to bump a new technology-data release, as soon as it is merged,
  3. and finally reference the newly release version in the config.default.yaml.

As mentioned in the in-line review, it could also make sense to add the small scale hot water tanks to the technology-data to serve as decentral heat storage option, unless there are arguments against it @amos-schledorn

EDIT: decentral water tank storage are already part of the costs tables, taken from the PyPSA cost assumptions, so no need to add them.

@amos-schledorn
Copy link
Contributor

amos-schledorn commented Dec 18, 2024

Hi @TomKae00, the implementation looks fine to me. However, the data behind it seems to contain some wrong assumptions that probably sneaked in with the recent changes in the technology-data repository, namely #144 and #152. In my opinion, we should assume (dis-)charger efficiencies of 1, as they are stated in the DEA catalogue. The indicated round-trip-efficiency-losses are probably chosen to give a proxy for the average standing losses. The standing losses, however, are already represented in our model by the configurable parameter tes_tau. Therefore, we would withdraw them twice according to the current implementation. These losses are probably also the reason, why PTES expansion decreases so heavily in your comparison between former "Store" and "StorageUnit" implementation and the total system costs change so much. To fix this issue, I would suggest to

1. submit a new PR in technology-data that refers the right charger- and discharger efficiencies for tanks and pits (maybe keep the round-trip efficiency as extra-row for people using technology-data without modelling standing losses separately),

2. ask @lkstrp to bump a new technology-data release, as soon as it is merged,

3. and finally reference the newly release version in the `config.default.yaml`.

As mentioned in the in-line review, it could also make sense to add the small scale hot water tanks to the technology-data to serve as decentral heat storage option, unless there are arguments against it @amos-schledorn

EDIT: decentral water tank storage are already part of the costs tables, taken from the PyPSA cost assumptions, so no need to add them.

Agreed, well done @TomKae00! I've opened an issue for the standing losses: #1459, so we can tackle that separately. This is good-to-go from my side as soon as the requested changes by @cpschau are addressed.

@lkstrp any chance we could we get that technology-data release?

Copy link
Contributor

@cpschau cpschau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I noticed one more thing that needs to be adjusted.

scripts/prepare_sector_network.py Show resolved Hide resolved
scripts/prepare_sector_network.py Outdated Show resolved Hide resolved
@fneum fneum self-requested a review December 19, 2024 16:37
@fneum
Copy link
Member

fneum commented Jan 2, 2025

The argument for this change is that the E2P ratio cannot be freely optimized, implying that extremely high/low ratios would not be technically feasible, right?

This should make the total system costs slightly higher if all unit/efficiency/cost calculations are done correctly. I was first a bit surprised by the lower cost with StorageUnit solution.

As @cpschau pointed out, giving the model only one E2P option might be very restrictive. One could add multiple (e.g. three E2P options as separate StorageUnits). An alternative -- which I am not sure I would recommend -- would be to keep Store/Link combination and allow ranges of E2P ratios.

@TomKae00 TomKae00 force-pushed the ltes_storage_units branch 2 times, most recently from 9d3cce4 to 76641b2 Compare January 8, 2025 14:42
@amos-schledorn
Copy link
Contributor

@TomKae00 I've just made a new technology-data release, so you can bump up the version in config.default.yaml to v0.10.1. Then, I'll rerun the CI.

@TomKae00
Copy link
Contributor Author

@amos-schledorn

  • Checked the charging and discharging efficiencies of the three storage types (PTES, large water tanks, and small water tanks) against the current DEA Technology Catalogue for energy storage. The dis-/charging efficiency for all three types is listed as 1.0.
  • Validated the outputs for efficiency_store and efficiency_dispatch during the model run, and the dis-/charging efficiencies are applied correctly for all three storage types.
  • Thanks for the updated technology-data release! The config.default.yaml now points to v0.10.1.

@fneum
Yes, that's correct! Using the max_hours attribute in the storage units component implements an energy-to-power ratio, ensuring technically feasible charging and discharging while preventing oversized capacities.

We now added an energy-to-power ratio for the small water tank to distinguish between central and decentralized heat storage options. This change makes the model less restrictive.

Adjusting the storage unit capital costs to depend on power capacity rather than energy capacity (#1444 (comment)) resulted in a slight increase in total system costs. The costs now closely match those of the prior store implementation.

The total costs of the storage units do not exceed those of the stores due to corrections in the handling of charging efficiencies:

  • For example, previously (in the store implementation), the dis-/charging efficiency for PTES stores was set at 0.8367, which already included standing losses. However, standing losses were also added separately, leading to double counting.
  • In the storage units, this issue has been resolved. Charging and discharging efficiencies are now directly taken from the DEA Technology Catalogue, with standing losses handled separately.

As a result, the costs of the storage units are now nearly the same as those of the stores.

@amos-schledorn amos-schledorn merged commit 0e6a8f8 into PyPSA:master Jan 27, 2025
1 of 2 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants