Skip to main content

Tools to support forecasting education in Python

Project description

forecast-tools: fundamental tools to support the forecasting process in python.

DOI ORCID: Monks PyPI version fury.io License: MIT Binder Python Read the Docs

forecast-tools has been developed to support forecasting education and applied forecasting research. It is MIT licensed and freely available to practitioners, students and researchers via PyPi. There is a long term plan to make forecast-tools available via conda-forge.

Vision for forecast-tools

  1. Deliver high quality reliable code for forecasting education and practice with full documentation and unit testing.
  2. Provide a simple to use pythonic interface that users of statsmodels and sklearn will recognise.
  3. To improve the quality of Machine Learning time series forecasting and encourage the use of best practice.

Features:

  1. Implementation of classic naive forecast benchmarks such as Naive Forecast 1 along with prediction intervals
  2. Implementation of scale-dependent, relative and scaled forecast errors.
  3. Implementation of scale-dependent and relative metrics to evaluate forecast prediction intervals
  4. Rolling forecast origin and sliding window for time series cross validation
  5. Built in daily level datasets
  6. An interactive plotting tool to visualise train test splits and forecasts.

Ways to explore forecast-tools

  1. pip install forecast-tools
  2. Click on the launch-binder at the top of this readme. This will open example Jupyter notebooks in the cloud via Binder.
  3. Read our documentation on GitHub pages

Citation

If you use forecast-tools for research, a practical report, education or any reason please include the following citation.

Monks, Thomas. (2020). forecast-tools: fundamental tools to support the forecasting process in python. Zenodo. http://doi.org/10.5281/zenodo.3759863

@software{forecast_tools,
  author       = {Monks, Thomas},
  title        = {forecast-tools},
  month        = dec,
  year         = 2023,
  publisher    = {Zenodo},
  doi          = {10.5281/zenodo.3759863},
  url          = {https://zenodo.org/doi/10.5281/zenodo.3759863}
}

Contributing to forecast-tools

Please fork Dev, make your modifications, run the unit tests and submit a pull request for review.

We provide a conda environment for development of forecast-tools. We recommend use of mamba as opposed to conda (although conda will work) as it is FOSS and faster. Install from mini-forge

Development environment:

mamba env create -f binder/environment.yml
mamba activate forecast_tools

Unit tests are provided and can be run via hatch and its coverage extension. Run the following in the terminal.

To run tests in multiple Python environments (3.9-3.12)

hatch test --all

To obtain a coverage report run

hatch test --cover

All contributions are welcome and must include unit tests!

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

forecast_tools-0.4.1.tar.gz (24.5 kB view details)

Uploaded Source

Built Distribution

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

forecast_tools-0.4.1-py3-none-any.whl (26.4 kB view details)

Uploaded Python 3

File details

Details for the file forecast_tools-0.4.1.tar.gz.

File metadata

  • Download URL: forecast_tools-0.4.1.tar.gz
  • Upload date:
  • Size: 24.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for forecast_tools-0.4.1.tar.gz
Algorithm Hash digest
SHA256 47fc3b3402d68577ae7f5cfb2744452b146fabb3fd4779f33190f21c16cbaae6
MD5 2aa6708f54fa7958c4901d21618392aa
BLAKE2b-256 0e73ffe91da4b582160160bd8c5501832773fc3d49345c8569bb2f96fe24bc2b

See more details on using hashes here.

File details

Details for the file forecast_tools-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: forecast_tools-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 26.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for forecast_tools-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7bf3bab8c04b4db3d062c121d649fcd9d425e1c2989117c28247423919d67c50
MD5 ff16710ee5e8221c26565775f5ee91ae
BLAKE2b-256 c865d2fd80fb15346e14586399488468a2ae670a91a1fedd950a08938f15b080

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