Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement sklearn linear model fro ENR prediction
Browse files Browse the repository at this point in the history
antoinetavant committed Aug 12, 2024
1 parent d1c8516 commit 180f3d0
Showing 5 changed files with 99 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
@@ -97,4 +97,4 @@ exclude_lines = [
]

[tool.ruff]
extend-include = ["*.ipynb"]
extend-include = ["*.ipynb"]
15 changes: 15 additions & 0 deletions src/energy_forecast/constants.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@

region_names = ["Île-de-France",
"Centre-Val de Loire",
"Bourgogne-Franche-Comté",
"Normandie",
"Hauts-de-France",
"Grand Est",
"Pays de la Loire",
"Bretagne",
"Nouvelle-Aquitaine",
"Occitanie",
"Auvergne-Rhône-Alpes",
"Provence-Alpes-Côte d'Azur",
"Corse"
]
3 changes: 3 additions & 0 deletions src/energy_forecast/eco2mix.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
"""Access the RTE eco2mix via ODRE API to get real-time data on the French electricity grid.
Needed mostly for the regional data, as the national data is available on the RTE API.
"""
import logging

import numpy as np
77 changes: 77 additions & 0 deletions src/energy_forecast/enr_production_model.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
from pathlib import Path
import pandas as pd
from sklearn import pipeline, linear_model
from energy_forecast import ROOT_DIR
from joblib import dump, load

class ENRProductionModel:
"""Model to predict the production of renewable energy sources.
Implements a pair of linear regression models to predict the production of solar and wind energy
from France regions weather data.
Parameters
----------
model_wind : sklearn.pipeline.Pipeline | None
Model to predict the wind energy production.
model_sun : sklearn.pipeline.Pipeline | None
Model to predict the solar energy production.
Examples
--------
>>> model = ENRProductionModel()
>>> model.fit(sun_flux, wind_speed, energy_data)
>>> predictions = model.predict(sun_flux, wind_speed)
>>> model.save("path/to/save")
"""

def __init__(self, model_wind=None, model_sun=None) -> None:
self.model_wind = model_wind or pipeline.Pipeline([
("model", linear_model.LinearRegression(positive=True, fit_intercept=False))
])
self.model_sun = model_sun or pipeline.Pipeline([
("model", linear_model.LinearRegression(positive=True, fit_intercept=False))
])

@staticmethod
def pre_process_sun_flux(sun_flux:pd.DataFrame) -> pd.DataFrame:
return sun_flux

@staticmethod
def pre_process_wind_speed(wind_speed:pd.DataFrame) -> pd.DataFrame:
X_squared = wind_speed ** 2
X_squared.columns = [f"{col}_squared" for col in X_squared.columns]
X_cubed = wind_speed ** 3
X_cubed.columns = [f"{col}_cubed" for col in X_cubed.columns]

wind_speed = pd.concat([wind_speed, X_squared, X_cubed], axis=1)

return wind_speed

def fit(self, sun_flux:pd.DataFrame, wind_speed:pd.DataFrame, productions:pd.DataFrame) -> None:
wind_speed_preprocessed = self.pre_process_wind_speed(wind_speed)
self.model_wind.fit(wind_speed_preprocessed, productions["wind"])
sun_flux_preprocessed = self.pre_process_sun_flux(sun_flux)
self.model_sun.fit(sun_flux_preprocessed, productions["sun"])

def predict(self, sun_flux:pd.DataFrame, wind_speed:pd.DataFrame) -> pd.DataFrame:
self.predictions = pd.DataFrame()
wind_speed_preprocessed = self.pre_process_wind_speed(wind_speed)
self.predictions["wind"] = self.model_wind.predict(wind_speed_preprocessed)
sun_flux_preprocessed = self.pre_process_sun_flux(sun_flux)
self.predictions["sun"] = self.model_sun.predict(sun_flux_preprocessed)
return self.predictions

def save(self, path:str | Path | None=None) -> None:
path = path or ROOT_DIR / "data" / "production_prediction"
path = Path(path)
path.mkdir(parents=True, exist_ok=True)
dump(self, path / "model.pkl")

@classmethod
def load(cls, path:str | Path | None=None) -> "ENRProductionModel":
path = path or ROOT_DIR / "data" / "production_prediction"
path = Path(path)
instance = load(path / "model.pkl")
return instance

4 changes: 3 additions & 1 deletion src/energy_forecast/meteo.py
Original file line number Diff line number Diff line change
@@ -377,6 +377,8 @@ def warm_cache(logger, date=None, max_counter=30, sleep_duration=600):
if counter > max_counter:
raise TimeoutError("Max counter reached")



if __name__ == "__main__":
logger.info("Fetching data for today")
warm_cache(logger)
warm_cache(logger)

0 comments on commit 180f3d0

Please sign in to comment.