A Python package for interacting with Sulie API
Project description
Sulie - Advanced Time Series Forecasting with Mimosa Foundation Model
The Sulie SDK offers seamless integration with the Sulie platform for advanced time series forecasting powered by Mimosa—a transformer-based foundation model optimized specifically for time series data. Mimosa provides high accuracy for zero-shot forecasting and automatic fine-tuning, enabling tailored forecasts without extensive pre-training.
Getting Started
To begin using the Sulie SDK, you’ll need an API key, which can be generated from the Sulie Dashboard:
- Visit the Sulie Dashboard.
- Sign in to your Sulie account.
- Navigate to the API Keys section.
- Generate a new API key and copy it to use within the SDK.
With your API key ready, you’re set to start forecasting.
Installation
To install the Sulie SDK, simply run:
pip install sulie
Quick Start Example
After installation, initialize the SDK using your API key to start forecasting with Mimosa:
from sulie import Sulie
# Initialize the Sulie client
client = Sulie(api_key="YOUR_API_KEY")
Features
1. Forecasting with Mimosa
Generate accurate time series forecasts using Mimosa’s zero-shot inference capabilities. This approach is ideal when you need fast, reliable predictions without training the model.
import pandas as pd
# Example time series data
df = pd.DataFrame({
'timestamp': pd.date_range(start='2023-01-01', periods=1000, freq='H'),
'demand': [ ... ], # Demand data
'location': ['Plant A', ...] # Data for different locations
})
# Forecast demand for each location over the next 24 hours
forecast = client.forecast(
dataset=df,
target='demand',
group_by='location',
date='timestamp',
frequency='H',
horizon=24, # Predict 24 hours ahead
num_samples=100 # Generate probabilistic forecasts
)
print(forecast)
Forecasting Parameters
| Name | Description | Default |
|---|---|---|
dataset |
A Dataset or pd.DataFrame containing time series data. |
Required |
target |
Column name for the forecast variable. | Required |
group_by |
Column name to group data by (e.g., different locations). | None |
date |
Timestamp column name. | None |
frequency |
Frequency of the time series (e.g., H for hourly). |
None |
horizon |
Time steps to forecast ahead. | 24 |
num_samples |
Number of probabilistic forecast samples. | 100 |
2. Fine-Tuning for Customized Forecasting
With automatic fine-tuning, you can optimize Mimosa for unique datasets and business cases. The fine-tuning process uses Weighted Quantile Loss (WQL) for evaluation, ensuring high accuracy.
# Fine-tune Mimosa on custom dataset
fine_tune_job = client.fine_tune(
dataset=df,
target="demand",
description="Fine-tune for Plant A demand prediction"
)
# Check the fine-tuning job status
print(f"Job status: {fine_tune_job.status}")
Fine-Tuning Parameters
| Name | Description | Default |
|---|---|---|
dataset |
A Dataset or pd.DataFrame with time series data. |
Required |
target |
Target variable for optimization. | Required |
description |
Description of the fine-tuning job. | None |
Once fine-tuning completes, the model is automatically deployed and available for forecasting.
3. Managing Datasets
Sulie’s Dataset API lets you manage and version your datasets, making them accessible for forecasting and fine-tuning across teams.
# Upload a dataset to Sulie
dataset = client.upload_dataset(
name="product-sales-data-v1",
df=df,
mode="append" # Choose 'append' or 'overwrite'
)
# List available datasets
datasets = client.list_datasets()
print(f"Available datasets: {datasets}")
Dataset Management Functions
- Upload: Store and version your data for easy access and updates.
- List: Retrieve a list of uploaded datasets.
- Update: Append or overwrite data for an existing dataset.
4. Forecasting with Custom Models
Fine-tuned models can be selected for new forecasts using list_custom_models or get_model.
# List custom and fine-tuned models
custom_models = client.list_custom_models()
# Select and forecast with a fine-tuned model
model_name = custom_models[0].name
custom_model = client.get_model(model_name)
# Forecast using the selected model
forecast_custom = custom_model.forecast(
dataset=df,
target='demand',
group_by='location',
date='timestamp',
frequency='H',
horizon=24,
num_samples=50
)
print(forecast_custom)
Additional Resources
- API Documentation: Full documentation with detailed usage.
- Forecasting Guide: Detailed parameters for Mimosa forecasting.
- Fine-Tuning Guide: Options and tuning customization.
- Support: Assistance and feedback on the SDK.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sulie-1.0.2.tar.gz.
File metadata
- Download URL: sulie-1.0.2.tar.gz
- Upload date:
- Size: 11.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
07bc5a18dffae2b10840ccbd0c83132060eaedca0df94e7bec9bfdc895ea590d
|
|
| MD5 |
6f317f608fb3f7ce5b4cd44ed3609eec
|
|
| BLAKE2b-256 |
7d38a9cf015c0a8f9a619af12b2a628a7640e985884a979fa3aaabaa92cda1c3
|
File details
Details for the file sulie-1.0.2-py3-none-any.whl.
File metadata
- Download URL: sulie-1.0.2-py3-none-any.whl
- Upload date:
- Size: 9.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
27e67229421a12a0a3d64d58f6a7bf26b0b2c4b3439b312fb656da7ca3a808d3
|
|
| MD5 |
26a699ea9f364aab3d400ef242c90682
|
|
| BLAKE2b-256 |
38cc6ab64937e239c8e0dd1526c12f5268e7f29c0ead94992b1902e693467ffb
|