Skip to main content

Quantitative analysis for power markets

Project description

octoanalytics logo

License

octoanalytics 📊⚡

Energy consumption forecasting & risk premium analysis for the French electricity market


Description

octoanalytics is a Python toolkit for:

  • Retrieving and smoothing weather data via Open-Meteo API.
  • Training and evaluating load forecasting models (MW) using Random Forest.
  • Generating interactive visualizations comparing actual vs. forecasted values.
  • Accessing spot and forward price data (annual, monthly, PFC) from Databricks SQL.
  • Computing volume and shape risk premiums, key for energy portfolio management.

Installation

pip install octoanalytics

⚠️ You need a valid Databricks access token to retrieve market data.


Dependencies

  • pandas
  • numpy
  • scikit-learn
  • plotly
  • matplotlib
  • tqdm
  • requests
  • tentaclio
  • yaspin
  • holidays
  • dotenv
  • databricks-sql-connector

Main Features

🔁 Weather data retrieval and smoothing

from octoanalytics import get_temp_smoothed_fr

temp_df = get_temp_smoothed_fr(start_date="2024-01-01", end_date="2024-12-31")

⚡ Load forecasting

from octoanalytics import eval_forecast

forecast_df = eval_forecast(df=load_df(), temp_df=temp_df, cal_year=2024)

💰 Risk premium calculation

Volume Risk

from octoanalytics import calculate_prem_risk_vol

premium = calculate_prem_risk_vol(forecast_df, spot_df, forward_df)

Shape Risk

from octoanalytics import calculate_prem_risk_shape

shape_risk = calculate_prem_risk_shape(forecast_df, pfc_df, spot_df)

🔌 Databricks SQL connections

from octoanalytics import get_spot_price_fr, get_forward_price_fr_annual

spot_df = get_spot_price_fr(token=DB_TOKEN, start_date="2024-01-01", end_date="2024-12-31")
forward_df = get_forward_price_fr_annual(token=DB_TOKEN, cal_year=2025)

Package Structure

octoanalytics/
│
├── __init__.py
├── core.py              # Main logic
├── ...

Authors

Jean Bertin
📧 jean.bertin@octopusenergy.fr

Thomas Maaza
📧 thomas.maaza@octoenergy.com


License

MIT – free to use, modify, and distribute.


Roadmap

  • Add XGBoost model
  • Load anomaly detection
  • Flask REST API deployment
  • Automatic PDF report generation

Full Demo

To be included in examples/forecast_demo.ipynb.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

octoanalytics-0.3.0.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

octoanalytics-0.3.0-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file octoanalytics-0.3.0.tar.gz.

File metadata

  • Download URL: octoanalytics-0.3.0.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.6

File hashes

Hashes for octoanalytics-0.3.0.tar.gz
Algorithm Hash digest
SHA256 f2e8763332f089e1861d9b643d2f67cc536214051e247e161809b0717c16f69d
MD5 0678a8a973f87b5977ec5f352a3116f0
BLAKE2b-256 c118d56a8a15db2691d05378ffcdcece4b3b619365bb2fa612042d1256e314f8

See more details on using hashes here.

File details

Details for the file octoanalytics-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: octoanalytics-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.6

File hashes

Hashes for octoanalytics-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d7a64d5ff2254fbc22f86d1b9daea8731d069ebbd265ada54f480f0e9b1064d
MD5 4457f7e7a158f1071f2c4f2e11fbedd6
BLAKE2b-256 e554a1ada2f12ec3bb4bce8e0fe7bdef5025e697fdd58e29a43b26607fd9e589

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page