The easiest way to run and scale time-series machine learning in the Cloud.
Project description
functime is a powerful Python library for production-ready global forecasting and time-series feature engineering.
functime also comes with time-series preprocessing (box-cox, differencing etc), cross-validation splitters (expanding and sliding window), and forecast metrics (MASE, SMAPE etc). All optimized as lazy Polars transforms.
Want to use functime for seamless time-series predictive analytics across your data team?
Looking for production-grade time-series machine learning in a serverless Cloud deployment?
Contact us via Calendly to learn more about functime
Cloud.
Highlights
- Fast: Forecast 100,000 time series in seconds on your laptop
- Efficient: Embarrassingly parallel feature engineering for time-series using
Polars
- Battle-tested: Machine learning algorithms that deliver real business impact and win competitions
- Exogenous features: supported by every forecaster
- Backtesting with expanding window and sliding window splitters
- Automated lags and hyperparameter tuning using
FLAML
- Censored forecaster: for zero-inflated and thresholding forecasts
Getting Started
Install functime
via the pip package manager.
pip install functime
Forecasting
import polars as pl
from functime.cross_validation import train_test_split
from functime.feature_extraction import add_fourier_terms
from functime.forecasting import linear_model
from functime.preprocessing import scale
from functime.metrics import mase
# Load commodities price data
y = pl.read_parquet("https://github.com/descendant-ai/functime/raw/main/data/commodities.parquet")
entity_col, time_col = y.columns[:2]
# Time series split
y_train, y_test = y.pipe(train_test_split(test_size=3))
# Fit-predict
forecaster = linear_model(freq="1mo", lags=24)
forecaster.fit(y=y_train)
y_pred = forecaster.predict(fh=3)
# functime ❤️ functional design
# fit-predict in a single line
y_pred = linear_model(freq="1mo", lags=24)(y=y_train, fh=3)
# Score forecasts in parallel
scores = mase(y_true=y_test, y_pred=y_pred, y_train=y_train)
# Forecast with target transforms and feature transforms
forecaster = linear_model(
freq="1mo",
lags=24,
target_transform=scale(),
feature_transform=add_fourier_terms(sp=12, K=6)
)
View the full walkthrough on forecasting with functime
.
Serverless Deployment
Currently in closed-beta for functime
Cloud.
Contact us for a demo via Calendly.
Deploy and train forecasters the moment you call any .fit
method.
Run the functime list
CLI command to list all deployed models.
Finally, track data and forecasts usage using functime usage
CLI command.
You can reuse a deployed model for predictions anywhere using the stub_id
variable.
Note: the .from_deployed
model class must be the same as during .fit
.
forecaster = LightGBM.from_deployed(stub_id)
y_pred = forecaster.predict(fh=3)
License
functime
is distributed under Apache-2.0.
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
Built Distribution
File details
Details for the file functime-0.6.0.tar.gz
.
File metadata
- Download URL: functime-0.6.0.tar.gz
- Upload date:
- Size: 59.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 56eeadb268865006a55d596f7b2633b77f7dba1182e1b428acf337e62fd24349 |
|
MD5 | 9fa915ac839b4942f7623b17ebac9afb |
|
BLAKE2b-256 | b85f0508adc0265b4ad785f5a01ba7529dbef8313ca719be631a5abbecd72820 |
File details
Details for the file functime-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: functime-0.6.0-py3-none-any.whl
- Upload date:
- Size: 66.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 586e7f3e1be2b8634319a299f2a2e2cf4e5768e38a4443a35fa7511f21a9e4f3 |
|
MD5 | 1a324e5b4ed57169a45cebcee24d2459 |
|
BLAKE2b-256 | 3b74926cfdd145653502363085500d7e5d84ff2737f4b710d84a78bacecdc897 |