domainiac 0.1.0__tar.gz → 0.1.2__tar.gz

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.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: domainiac
3
- Version: 0.1.0
3
+ Version: 0.1.2
4
4
  Summary: Package for working with Energinet data, but with specialized functions used for Enigma.
5
5
  Author: Team Enigma
6
6
  Author-email: gridop-enigma@energinet.dk
@@ -0,0 +1 @@
1
+ from .managers import MeteringManager, PlantManager, ResourceManager, UnitManager
@@ -1,4 +1,5 @@
1
1
  from .masterdata_manager import MasterdataManager
2
2
  from .metering_manager import MeteringManager
3
3
  from .plant_manager import PlantManager
4
+ from .resource_manager import ResourceManager
4
5
  from .unit_manager import UnitManager
@@ -19,23 +19,30 @@ class MasterdataManager:
19
19
  self.resolution = resolution
20
20
 
21
21
  @typechecked
22
- def get_data(
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 units for a given unit type.
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
- for key in filters.keys():
37
- if key not in df.columns:
38
- raise KeyError(f"Column {key} not found in {table}")
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
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "domainiac"
3
- version = "0.1.0"
3
+ version = "0.1.2"
4
4
  description = "Package for working with Energinet data, but with specialized functions used for Enigma."
5
5
  authors = ["Team Enigma <gridop-enigma@energinet.dk>"]
6
6
  packages = [
@@ -1 +0,0 @@
1
- from .managers import MeteringManager, PlantManager, UnitManager