domainiac 0.1.0__py3-none-any.whl → 0.1.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- domainiac/__init__.py +1 -1
- domainiac/managers/__init__.py +1 -0
- domainiac/managers/masterdata_manager.py +16 -9
- domainiac/managers/plant_manager.py +22 -0
- domainiac/managers/resource_manager.py +65 -0
- {domainiac-0.1.0.dist-info → domainiac-0.1.2.dist-info}/METADATA +1 -1
- domainiac-0.1.2.dist-info/RECORD +10 -0
- domainiac-0.1.0.dist-info/RECORD +0 -9
- {domainiac-0.1.0.dist-info → domainiac-0.1.2.dist-info}/WHEEL +0 -0
domainiac/__init__.py
CHANGED
@@ -1 +1 @@
|
|
1
|
-
from .managers import MeteringManager, PlantManager, UnitManager
|
1
|
+
from .managers import MeteringManager, PlantManager, ResourceManager, UnitManager
|
domainiac/managers/__init__.py
CHANGED
@@ -19,23 +19,30 @@ class MasterdataManager:
|
|
19
19
|
self.resolution = resolution
|
20
20
|
|
21
21
|
@typechecked
|
22
|
-
def
|
22
|
+
def get_operational_entities(
|
23
23
|
self,
|
24
24
|
table: str,
|
25
25
|
filters: dict = {},
|
26
|
-
columns: list = [],
|
27
26
|
) -> pd.DataFrame:
|
28
|
-
"""Gets the
|
29
|
-
Filters for units valid at the end of time interval.
|
30
|
-
Filters by default for units in operation.
|
31
|
-
"""
|
27
|
+
"""Gets the operational data for a given table."""
|
32
28
|
|
33
29
|
filters["standing_entity_state"] = "InOperation"
|
34
30
|
df = self.db.query(table, filters=filters)
|
35
31
|
|
36
|
-
|
37
|
-
|
38
|
-
|
32
|
+
return df
|
33
|
+
|
34
|
+
@typechecked
|
35
|
+
def get_data(
|
36
|
+
self,
|
37
|
+
table: str,
|
38
|
+
filters: dict = {},
|
39
|
+
columns: list = [],
|
40
|
+
) -> pd.DataFrame:
|
41
|
+
"""Gets the data for a given table.
|
42
|
+
Filters for rows valid at the end of time interval.
|
43
|
+
"""
|
44
|
+
df = self.get_operational_entities(table, filters)
|
45
|
+
|
39
46
|
for column in columns:
|
40
47
|
if column not in df.columns:
|
41
48
|
raise KeyError(f"Column {column} not found in {table}")
|
@@ -37,3 +37,25 @@ class PlantManager(MasterdataManager):
|
|
37
37
|
Filters by default for plants in operation.
|
38
38
|
"""
|
39
39
|
return self.get_data("masterdataPlant", filters=filters, columns=columns)
|
40
|
+
|
41
|
+
def get_installed_power_timeseries(self, gsrn: str) -> pd.DataFrame:
|
42
|
+
"""Gets the installed power timeseries for a plant."""
|
43
|
+
|
44
|
+
df_times = self.time_interval.to_range(self.resolution).to_frame(
|
45
|
+
index=False, name="time_utc"
|
46
|
+
)
|
47
|
+
|
48
|
+
# explode plant to time series
|
49
|
+
df_plant = self.get_operational_entities("masterdataPlant")
|
50
|
+
df_plant = df_plant.query(f"masterdata_gsrn == '{gsrn}'")
|
51
|
+
|
52
|
+
df_plant = pdz.merge(
|
53
|
+
df_times,
|
54
|
+
df_plant,
|
55
|
+
left_time="time_utc",
|
56
|
+
right_period=("valid_from_date_utc", "valid_to_date_utc"),
|
57
|
+
)
|
58
|
+
|
59
|
+
return df_plant.filter(["time_utc", "installed_power_MW"]).reset_index(
|
60
|
+
drop=True
|
61
|
+
)
|
@@ -0,0 +1,65 @@
|
|
1
|
+
import datamazing.pandas as pdz
|
2
|
+
import pandas as pd
|
3
|
+
from typeguard import typechecked
|
4
|
+
|
5
|
+
|
6
|
+
class ResourceManager:
|
7
|
+
"""
|
8
|
+
Manager which simplifies the process of handling resource schedules.
|
9
|
+
"""
|
10
|
+
|
11
|
+
def __init__(
|
12
|
+
self,
|
13
|
+
db: pdz.Database,
|
14
|
+
time_interval: pdz.TimeInterval,
|
15
|
+
) -> None:
|
16
|
+
self.db = db
|
17
|
+
self.time_interval = time_interval
|
18
|
+
|
19
|
+
@typechecked
|
20
|
+
def get_resource_schedules(
|
21
|
+
self,
|
22
|
+
resource_gsrns: list,
|
23
|
+
) -> pd.DataFrame:
|
24
|
+
"""Gets resource schedules for a given list of resource gsrns."""
|
25
|
+
df_resource_schedules = self.db.query(
|
26
|
+
table_name="resourceSchedule",
|
27
|
+
time_interval=self.time_interval,
|
28
|
+
filters={"resource_gsrn": resource_gsrns},
|
29
|
+
)
|
30
|
+
df_resource_schedules = df_resource_schedules.filter(
|
31
|
+
[
|
32
|
+
"market_participant",
|
33
|
+
"created_time_utc",
|
34
|
+
"price_area",
|
35
|
+
"resource_gsrn",
|
36
|
+
"main_fuel_type",
|
37
|
+
"is_sum_plan",
|
38
|
+
"time_utc",
|
39
|
+
"schedule_power_MW",
|
40
|
+
"schedule_capacity_min_MW",
|
41
|
+
"schedule_capacity_max_MW",
|
42
|
+
]
|
43
|
+
)
|
44
|
+
return df_resource_schedules
|
45
|
+
|
46
|
+
@typechecked
|
47
|
+
def get_latest_resource_plan(
|
48
|
+
self,
|
49
|
+
resource_gsrns: list,
|
50
|
+
) -> pd.DataFrame:
|
51
|
+
"""Gets the lastest resource schedules for a given list of resource gsrns."""
|
52
|
+
|
53
|
+
df_resource_schedules = self.get_resource_schedules(
|
54
|
+
resource_gsrns=resource_gsrns
|
55
|
+
)
|
56
|
+
|
57
|
+
df_latest_created_time = pdz.group(
|
58
|
+
df=df_resource_schedules, by=["resource_gsrn", "time_utc"]
|
59
|
+
).agg({"created_time_utc": max})
|
60
|
+
|
61
|
+
df_resource_latest = df_latest_created_time.merge(
|
62
|
+
df_resource_schedules, on=list(df_latest_created_time.columns)
|
63
|
+
)
|
64
|
+
|
65
|
+
return df_resource_latest
|
@@ -0,0 +1,10 @@
|
|
1
|
+
domainiac/__init__.py,sha256=7-KoUot9OZgzMoOLhuHInlvyt9EfL5QjuZagTbAJksU,82
|
2
|
+
domainiac/managers/__init__.py,sha256=QzkZNv8_3G0TPcfQia45RWBnASYR6WIuY6jlFBeley0,220
|
3
|
+
domainiac/managers/masterdata_manager.py,sha256=QPybE3QTAmGFX0WhyKpg1ybqbxuY4ufZ0D3r7wS4dQs,1463
|
4
|
+
domainiac/managers/metering_manager.py,sha256=NXGHuNjWiAUE08fGIPAfvwbzlKESbKaO5uyxLNyZKC0,995
|
5
|
+
domainiac/managers/plant_manager.py,sha256=IUPmTgE99Y7tGASOgXRIeCQmqGe4J2V6yBOlkvcphKA,1823
|
6
|
+
domainiac/managers/resource_manager.py,sha256=LJvAI6y1RcUgNrMS5iGMqV1Y4X2Pe_ocT_qgffh7HPU,1919
|
7
|
+
domainiac/managers/unit_manager.py,sha256=PjtLag75PRDlX57lxbYo6hundkQy37jC170R4YKJw7U,1085
|
8
|
+
domainiac-0.1.2.dist-info/METADATA,sha256=jo1JyI-of5vSawtuQUrZnxtr6Q0ozDrb6jlmEDUjQHw,465
|
9
|
+
domainiac-0.1.2.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
|
10
|
+
domainiac-0.1.2.dist-info/RECORD,,
|
domainiac-0.1.0.dist-info/RECORD
DELETED
@@ -1,9 +0,0 @@
|
|
1
|
-
domainiac/__init__.py,sha256=ezC_vpooWhMA-M0M2GxZiF0DFc-KoCeVaNhlR4Ysnfg,65
|
2
|
-
domainiac/managers/__init__.py,sha256=ZwpdZMaQ7JxVWOlH2wKAxezy_JNni8qaGzfVFtMkIVo,174
|
3
|
-
domainiac/managers/masterdata_manager.py,sha256=h_KRtXLRAniPDy94EkWGC5cB93RYXQe3Zt_r_p4mWe0,1388
|
4
|
-
domainiac/managers/metering_manager.py,sha256=NXGHuNjWiAUE08fGIPAfvwbzlKESbKaO5uyxLNyZKC0,995
|
5
|
-
domainiac/managers/plant_manager.py,sha256=LW9S_HECpR-lljkopY1IcYpU9XgPDqhQxFH-wPAvQIU,1083
|
6
|
-
domainiac/managers/unit_manager.py,sha256=PjtLag75PRDlX57lxbYo6hundkQy37jC170R4YKJw7U,1085
|
7
|
-
domainiac-0.1.0.dist-info/METADATA,sha256=qmiB4NB9x1CY9zJMnYiNTPbdPXUVa0HWpX2NvJPpMXM,465
|
8
|
-
domainiac-0.1.0.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
|
9
|
-
domainiac-0.1.0.dist-info/RECORD,,
|
File without changes
|