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

Fix Mongolia parser, add thermal + battery support [Mostly complete, needs some work so if someone else wants to complete this please do] #7444

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions config/zones/MN.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,9 @@ emissionFactors:
datetime: '2020-01-01'
source: IEA 2020; assumes 92.85% coal, 5.78%% oil, 1.37% hydro in unknown
value: 729.1
- datetime: '2024-11-25'
source: IEA 2020; assumes 94.14% coal, 5.86% oil in unknown
value: 739
lifecycle:
battery discharge:
- datetime: '2023-01-01'
Expand All @@ -46,6 +49,9 @@ emissionFactors:
datetime: '2020-01-01'
source: IEA 2020; assumes 92.85% coal, 5.78%% oil, 1.37% hydro in unknown
value: 799.2
- datetime: '2024-11-25'
source: IEA 2020; assumes 94.14% coal, 5.86% oil in unknown
Copy link
Contributor Author

Choose a reason for hiding this comment

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

This source also says IEA 2020 but has different values from two lines up, is that correct?

Copy link
Member

Choose a reason for hiding this comment

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

Yes, basically I used the same source but simply removed hydro since that will now be reported on it's own.

value: 810
fallbackZoneMixes:
powerOriginRatios:
- _source: Electricity Maps, 2023 average
Expand All @@ -68,11 +74,15 @@ isLowCarbon:
- _url: https://www.iea.org/fuels-and-technologies/electricity
datetime: '2020-01-01'
value: 0.0137
- datetime: '2024-11-25'
value: 0
isRenewable:
unknown:
- _url: https://www.iea.org/fuels-and-technologies/electricity
datetime: '2020-01-01'
value: 0.0137
- datetime: '2024-11-25'
value: 0
parsers:
consumption: MN.fetch_consumption
production: MN.fetch_production
Expand Down
15 changes: 11 additions & 4 deletions parsers/MN.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,18 +22,20 @@
JSON_QUERY_TO_SRC = {
"time": "date",
"consumptionMW": "syssum",
"thermalMW": "dts",
"solarMW": "sumnar",
"windMW": "sums",
"windMW": "sumsalhit",
"importMW": "energyimport", # positive = import
"temperatureC": "t", # current temperature
"batteryMW": "Songino"
}


def parse_json(web_json: dict, logger: Logger, zone_key: ZoneKey) -> dict[str, Any]:
"""
Parse the fetched JSON data to our query format according to JSON_QUERY_TO_SRC.
Example of expected JSON format present at URL:
{"date":"2023-06-27 18:00:00","syssum":"869.37","sumnar":42.34,"sums":119.79,"energyimport":"49.58"}
{"date":"2024-11-23 06:00:00","syssum":"1133.6","dts":987.4,"sumnar":-0.2,"sumsalhit":17.2,"energyimport":"129.4","t":"-14.5","Songino":"0.0"}
"""

# Validate first if keys in fetched dict match expected keys
Expand Down Expand Up @@ -99,6 +101,7 @@ def fetch_production(
# 'unknown' consists of 92.8% coal, 5.8% oil and 1.4% hydro as per 2020; sources: IEA and IRENA statistics.
query_data["leftoverMW"] = round(
query_data["consumptionMW"]
- query_data["thermalMW"]
- query_data["importMW"]
- query_data["solarMW"]
- query_data["windMW"],
Copy link
Contributor

Choose a reason for hiding this comment

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

LGTM!
Just a quick question, should any usage/withdrawings from battery storage be included here?

Expand All @@ -108,16 +111,20 @@ def fetch_production(
prod_mix = ProductionMix()
prod_mix.add_value("solar", query_data["solarMW"])
prod_mix.add_value("wind", query_data["windMW"])
prod_mix.add_value("unknown", query_data["leftoverMW"])
prod_mix.add_value("unknown", query_data["thermalMW"]) # Coal + oil according to https://www.iea.org/countries/mongolia/electricity
prod_mix.add_value("hydro", query_data["leftoverMW"]) # Only generation type not accounted for https://www.iea.org/countries/mongolia/electricity

storage_mix = StorageMix(battery=batteryMW * -1, hydro=None) # Based on how imports are displayed, I assume positive = providing to grid, negative = withdrawing from grid applies to battery as well.

prod_breakdown_list = ProductionBreakdownList(logger)
prod_breakdown_list.append(
datetime=query_data["time"],
zoneKey=zone_key,
source="https://ndc.energy.mn/",
storage=storage_mix,
production=prod_mix,
)

return prod_breakdown_list.to_list()


Expand Down
Loading