Skip to main content

Live forecast for the OCF nowcasting project

Project description

Nowcasting Forecast

codecov

Making live forecasts for the nowcasting project. The aim is to produce Grid Supply Point (GSP) Solar generation Forecasts. This is done by loading live PV results, Numerical Weather Predictions (NWPs) and Satellite images, and running this data through various different ML models.

You can run the application locally by:

python nowcasting_forecast/app.py --db-url='sqlite:///test.db'

Installation with conda

mamba env create -f environment.yml
conda activate nowcasting_forecast

# Installing fastai inside environment.yml is currently broken. So install separately:
mamba install -c fastchan fastai

# You need to manually install nowcasting_dataset, nowcasting_datamodel,
# nowcasting_dataloader, and power_perceiver. This can be done via pypi (for all except
# power_perceiver) or by git cloning the repo and using:
pip install -e <path_to_directory>

# Install nowcasting_forecast
pip install -e .

# You may also want to install dev tools:
mamba install pytest flake8 black pre-commit pydocstyle isort mypy
pre-commit install

Directories and files

The following shows the main files

+-- nowcasting_forecast
|   +-- config
|       +-- mvp_v0.yaml
|       +-- mvp_v1.yaml
|   +-- models
|       +-- nwp_solar_simple.py
|       +-- nwp_solar_simple_trained
|           +-- model.py
|       +-- cnn
|           +-- cnn.py
|           +-- dataloader.py
|           +-- model.py
|   +-- app.py
|   +-- batch.py
|   +-- dataloader.py
+-- scripts
+-- tests

☀️ nowcasting_forecast

app.py is the main entry point for running the forecast module. It contains the following arguments:

  • --db-url: the database url that the forecasts will be saved too
  • --fake: Create fake forecast, mainly used for testing

The app has three main steps

  1. Make batched data
  2. Run forecasting model to make forecasts
  3. Save forecasts to the database

batch.py is used to load the data and create batches of data. This uses mainly used ManagerLive

dataloader.py is used to load the batched data in an efficient way. This is current a stripped down version of this dataloader.

The config directory contains configurations that are used to load different data sources. The configuration is used by batch.py to convert large amounts of data into batched data, which is then ready for ML models.

The database directory contains database models and functions to interact with the database. See below for more information

The model directory contains ml models to make forecasts. See below for more information

Models

NWP Simple

This takes the average 'dswrf' for each example and then divides this by 10 to give a rough model for MW per GSP

configuration: mvp_v0.yaml

NWP Simple trained

CNN model of 'dswrf' channel in NWP. 6 CNN layers then 4 fully connected layers.

Diagram

Training run: https://app.neptune.ai/o/OpenClimateFix/org/predict-pv-yield/e/PRED-951/charts

configuration: mvp_v1.yaml

CNN

This model takes both satellite and NWP video data and puts them through separate 3D convolutional neural networks. These are then connected with a few fully connected layers, joined with some simple input data like historic PV data.

🩺 Testing

Tests are run with pytest

These sets up postgres in a docker container. This slightly more complicated testing framework is needed (compared to running pytest) as some queries can not be fully tested on a sqlite database

🛠️ infrastructure

.github/workflows contains a number of CI actions

  1. linters.yaml: Runs linting checks on the code
  2. release.yaml: Make and pushes docker files on a new code release
  3. test-docker.yaml': Runs tests on every push

The docker file is in the folder infrastructure/docker/

The version is bumped automatically for any push to main.

Environmental Variables

  • DB_URL: The database url which the forecasts will be saved too
  • DB_URL_PV: The database url for the PV data
  • NWP_ZARR_PATH: Override NWP data path. This is useful when running this locally, and shows to get data from the cloud.
  • SATELLITE_ZARR_PATH: Override Satellite data path. This is useful when running this locally, and shows to get data from the cloud.
  • FAKE: Option to make fake/dummy forecasts
  • MODEL_NAME: Optional of 'nwp_simple' or 'nwp_simple_trained'

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

nowcasting_forecast-1.3.26.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

nowcasting_forecast-1.3.26-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

Details for the file nowcasting_forecast-1.3.26.tar.gz.

File metadata

  • Download URL: nowcasting_forecast-1.3.26.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for nowcasting_forecast-1.3.26.tar.gz
Algorithm Hash digest
SHA256 22373ebe9f31c5d7d9f49c4a8afdfccf7b823b99cc4225610038c27addc26a86
MD5 22d7438268e46f100dea5421703ead3a
BLAKE2b-256 f90207fb8691875ccc50156a5ed27e66c787a1af005877418c7a58c5d8728cc0

See more details on using hashes here.

File details

Details for the file nowcasting_forecast-1.3.26-py3-none-any.whl.

File metadata

File hashes

Hashes for nowcasting_forecast-1.3.26-py3-none-any.whl
Algorithm Hash digest
SHA256 8f750d869d8c45db77f8e508a464a21a5cd5ab9865aa573a3483f8ce66bf0bad
MD5 c0bda47a375bb0fcd3f413cb550116f2
BLAKE2b-256 8de4454cf831fd44576c661099194ffb4b22a484df4e4fc47d35c3a191d93b55

See more details on using hashes here.

Supported by

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