# Residual Chronos

A time series forecasting package that combines traditional forecasting models with covariate regression.

## Installation

```bash
cd hopformer

# Install in development mode
pip install -e .
```

## Basic Tutorial

Here's a simple example showing how to use Residual Chronos for time series forecasting:

```python
from autogluon.timeseries import TimeSeriesDataFrame
from residual_chronos.Predictor import Predictor

# Set random seed for reproducibility
RANDOM_SEED = 100

# Load your time series data
data = TimeSeriesDataFrame.from_path("your_data.csv")

# Split data for training and testing
prediction_length = 24
context_length = 512
train_data, test_data = data.train_test_split(prediction_length=prediction_length)

# Prepare context and known covariates
context = test_data.slice_by_timestep(-(context_length + prediction_length), -prediction_length)
known_covariates = test_data.slice_by_timestep(-prediction_length, None)

# Initialize the model
model = Predictor(
    prediction_length=prediction_length,
    target="target",
    known_covariates_real=["promotion", "temperature", "price"],
    eval_metric="MAE",
    regressor_types=["LR", "XGB", "GBM", "CAT"],
    aggregation_strategy=("SPA", {}),
    bolt_model_path="bolt_small",
    random_seed=RANDOM_SEED
)

# Train the model
model.fit(
    train_data=train_data,
    time_limit=120,
    enable_ensemble=False,
    fine_tune=False
)

# Generate forecasts
forecasts = model.predict(data=context, known_covariates=known_covariates)
```

## Example Run

To run a complete example with real data:

```bash
python tests/hopformer/train_model.py
```

This script demonstrates the full pipeline using store sales data, including data loading, model training, and generating forecasts.

## Synthetic Data Generation

You can generate synthetic data for testing and experimentation using our provided scripts:

```bash
# Generate different types of synthetic data
python src/data/generate_data1.py  # Linear combination scenario
python src/data/generate_data2.py  # Non-linear combination scenario
python src/data/generate_data3.py  # Complex temporal patterns
```

Each script generates data with different characteristics:
- `generate_data1.py`: Creates synthetic time series with linear relationships between features
- `generate_data2.py`: Generates data with non-linear feature interactions
- `generate_data3.py`: Produces complex temporal patterns with seasonal components

The generated data will be saved in CSV format and can be used directly with the tutorial below.