tasks.task_n_to_1_with_covariates_and_dataframe

tasks.task_n_to_1_with_covariates_and_dataframe

N-to-1 Forecasting with Exogenous Covariates and Prediction Aggregation.

This module implements a complete end-to-end pipeline for multi-step time series forecasting with exogenous variables (weather, holidays, calendar features), followed by prediction aggregation using configurable weights.

The pipeline

  1. Performs multi-output recursive forecasting with exogenous covariates
  2. Aggregates predictions using weighted combinations
  3. Supports flexible model selection (string or object-based)
  4. Allows customization via kwargs for all underlying functions

Key Features

  • Automatic weather, holiday, and calendar feature generation
  • Cyclical and polynomial feature engineering
  • Configurable recursive forecaster with LGBMRegressor default
  • Weighted prediction aggregation
  • Comprehensive parameter flexibility via **kwargs
  • Detailed logging and progress tracking

Examples

Basic usage with default parameters:

>>> from spotforecast2.scripts.n_to_1_with_covariates import main
>>> main()

With custom forecast horizon and weights:

>>> predictions = main(
...     forecast_horizon=48,
...     weights=[1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, 1.0, 1.0, -1.0, 1.0]
... )

With custom location (latitude, longitude):

>>> predictions = main(
...     forecast_horizon=24,
...     latitude=48.1351,
...     longitude=11.5820,
...     verbose=True
... )

With feature engineering options:

>>> predictions = main(
...     forecast_horizon=24,
...     include_weather_windows=True,
...     include_holiday_features=True,
...     include_poly_features=True,
... )

Passing custom estimator object:

>>> from lightgbm import LGBMRegressor
>>> estimator = LGBMRegressor(n_estimators=200, learning_rate=0.01)
>>> predictions = main(forecast_horizon=24, estimator=estimator)

Available Parameters:

Forecasting Parameters

forecast_horizon (int): Number of steps ahead to forecast. Default: 24. contamination (float): Outlier detection threshold [0, 1]. Default: 0.01. window_size (int): Rolling window size for feature engineering. Default: 72. lags (int): Number of lag features to create. Default: 24. train_ratio (float): Train-test split ratio [0, 1]. Default: 0.8. verbose (bool): Enable detailed progress logging. Default: True.

Location & Time Parameters: latitude (float): Location latitude for sun features. Default: 51.5136 (Dortmund). longitude (float): Location longitude for sun features. Default: 7.4653 (Dortmund). timezone (str): Timezone for data processing. Default: “UTC”. country_code (str): Country code for holidays (ISO 3166-1 alpha-2). Default: “DE”. state (str): State/region code for holidays (depends on country). Default: “NW”.

Feature Engineering Parameters

include_weather_windows (bool): Include rolling weather statistics. Default: False. include_holiday_features (bool): Include holiday indicator features. Default: False. include_poly_features (bool): Include polynomial interaction features. Default: False.

Model Parameters

estimator (Optional[Union[str, object]]): Forecaster estimator. Can be: - None: Uses default LGBMRegressor(n_estimators=100) - “ForecasterRecursive”: String reference (uses default) - LGBMRegressor(…): Custom estimator object Default: None.

Aggregation Parameters

weights (Optional[Union[Dict[str, float], List[float], np.ndarray]]): Weights for prediction aggregation. Can be: - None: Defaults to uniform weights (1.0 for each column) - Dict: Column name -> weight mapping - List/Array: Weights in column order Default: [1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, 1.0, 1.0, -1.0, 1.0].

Functions

Name Description
main Execute the complete N-to-1 forecasting pipeline with default parameters.
n_to_1_with_covariates Execute N-to-1 forecasting pipeline with exogenous covariates.

main

tasks.task_n_to_1_with_covariates_and_dataframe.main()

Execute the complete N-to-1 forecasting pipeline with default parameters.

This is the entry point when running the script directly. It executes the full forecasting pipeline with default settings and prints comprehensive results.

The default configuration: - Forecasts 24 steps ahead - Uses Dortmund, Germany coordinates - Applies default contamination and window parameters - Aggregates with predefined weights - Provides verbose output

Returns

Name Type Description
None None. Results are printed to stdout.

Examples

Run the script directly:

>>> python n_to_1_with_covariates.py

Or call main() programmatically:

>>> from spotforecast2.scripts.n_to_1_with_covariates import main
>>> main()

n_to_1_with_covariates

tasks.task_n_to_1_with_covariates_and_dataframe.n_to_1_with_covariates(
    data=None,
    forecast_horizon=24,
    contamination=0.01,
    window_size=72,
    lags=24,
    train_ratio=0.8,
    latitude=51.5136,
    longitude=7.4653,
    timezone='UTC',
    country_code='DE',
    state='NW',
    estimator=None,
    include_weather_windows=False,
    include_holiday_features=False,
    include_poly_features=False,
    weights=None,
    verbose=True,
    show_progress=True,
    **kwargs,
)

Execute N-to-1 forecasting pipeline with exogenous covariates.

This function performs a complete time series forecasting workflow: 1. Fetches and preprocesses data 2. Engineers features (calendar, weather, holidays, cyclical, polynomial) 3. Trains recursive forecaster on multiple targets 4. Aggregates predictions using weighted combination

Parameters

Name Type Description Default
data Optional[pd.DataFrame] Optional DataFrame with target time series data. If None, fetches data automatically. Default: None. None
forecast_horizon int Number of forecast steps ahead. Determines how many time steps to predict into the future. Typical values: 24 (1 day), 48 (2 days), 168 (1 week). Default: 24. 24
contamination float Outlier contamination level for anomaly detection. Expected proportion of outliers in the training data [0, 1]. Higher values detect fewer outliers. Default: 0.01 (1%). 0.01
window_size int Rolling window size for feature engineering (hours). Size of the rolling window for computing statistics. Must be > lags. Typical range: 24-168. Default: 72. 72
lags int Number of lagged features to create. Creates AR(p) features with p=lags. Typical values: 12, 24, 48. Default: 24. 24
train_ratio float Proportion of data for training [0, 1]. Remaining data (1 - train_ratio) used for validation/testing. Typical values: 0.7-0.9. Default: 0.8. 0.8
latitude float Geographic latitude for solar features. Used to compute sunrise/sunset times for day/night features. Default: 51.5136 (Dortmund, Germany). 51.5136
longitude float Geographic longitude for solar features. Used to compute sunrise/sunset times for day/night features. Default: 7.4653 (Dortmund, Germany). 7.4653
timezone str Timezone for time-based features. Any timezone recognized by pytz. Default: “UTC”. 'UTC'
country_code str ISO 3166-1 alpha-2 country code for holidays. Examples: “DE” (Germany), “US” (USA), “GB” (UK). Default: “DE”. 'DE'
state str State/region code for holidays. Country-dependent. For Germany: “BW”, “BY”, “NW”, etc. Default: “NW” (Nordrhein-Westfalen). 'NW'
estimator Optional[Union[str, object]] Forecaster model. Can be: - None: Uses LGBMRegressor(n_estimators=100, verbose=-1). - “ForecasterRecursive”: References default estimator (same as None). - LGBMRegressor(…): Custom pre-configured estimator. - Any sklearn-compatible regressor. Default: None. None
include_weather_windows bool Add rolling weather statistics. Creates moving averages, min, max of weather features over multiple windows (1D, 7D). Increases feature count significantly. Default: False. False
include_holiday_features bool Add holiday binary indicators. Creates features indicating holidays and special dates. Useful for capturing demand patterns around holidays. Default: False. False
include_poly_features bool Add polynomial interactions. Creates 2nd-order interaction terms between selected features. Useful for capturing non-linear relationships. Default: False. False
weights Optional[Union[Dict[str, float], List[float], np.ndarray]] Weights for combining multi-output predictions. Can be: - None: Default weights [1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, 1.0, 1.0, -1.0, 1.0] - Dict: {“col_name”: weight, …} for specific columns - List: [w1, w2, …] in column order - np.ndarray: Same as list Default: None (uses default weights). None
verbose bool Enable progress logging. Prints intermediate results and timestamps. Default: True. True
show_progress bool Show a progress bar for major pipeline steps. Default: True. True
**kwargs Any Additional parameters for underlying functions. These are passed to n2n_predict_with_covariates(). Examples: - freq: Frequency for data resampling. Default: “h” (hourly). - columns: Specific columns to forecast. Default: None (all). Any parameter accepted by n2n_predict_with_covariates(). {}

Returns

Name Type Description
Tuple[pd.DataFrame, pd.Series, Dict, Dict] Tuple[pd.DataFrame, pd.Series, Dict, Dict]: A tuple containing: - predictions (pd.DataFrame): Multi-output forecasts from recursive model. Each column represents a target variable. Index is datetime matching the forecast period. - combined_prediction (pd.Series): Aggregated forecast from weighted combination. Single column combining all output predictions. Index is datetime matching the forecast period. - model_metrics (Dict): Performance metrics from recursive forecaster. Keys may include: ‘mae’, ‘rmse’, ‘mape’, etc. - feature_info (Dict): Information about engineered features. Contains feature counts, types, and engineering details.

Raises

Name Type Description
ValueError If forecast_horizon <= 0 or invalid parameter combinations.
FileNotFoundError If data source files cannot be accessed.
RuntimeError If model training fails or data processing errors occur.

Examples

Basic usage (uses all defaults):

>>> predictions, combined, metrics, features = n_to_1_with_covariates()
>>> print(f"Predictions shape: {predictions.shape}")
>>> print(f"Combined forecast head:\n{combined.head()}")

Custom location and forecast horizon:

>>> predictions, combined, metrics, features = n_to_1_with_covariates(
...     forecast_horizon=48,
...     latitude=48.1351,
...     longitude=11.5820,
...     country_code="DE",
...     state="BY",
...     verbose=True
... )

With feature engineering enabled:

>>> predictions, combined, metrics, features = n_to_1_with_covariates(
...     forecast_horizon=24,
...     include_weather_windows=True,
...     include_holiday_features=True,
...     include_poly_features=True,
...     verbose=True
... )

Custom estimator and weights:

>>> from lightgbm import LGBMRegressor
>>> custom_estimator = LGBMRegressor(
...     n_estimators=200,
...     learning_rate=0.01,
...     max_depth=7
... )
>>> custom_weights = [1.0, 1.0, -0.5, -0.5]
>>> predictions, combined, metrics, features = n_to_1_with_covariates(
...     forecast_horizon=24,
...     estimator=custom_estimator,
...     weights=custom_weights,
...     verbose=True
... )

With all advanced options:

>>> predictions, combined, metrics, features = n_to_1_with_covariates(
...     forecast_horizon=72,
...     contamination=0.02,
...     window_size=168,
...     lags=48,
...     train_ratio=0.75,
...     latitude=50.1109,
...     longitude=8.6821,
...     timezone="Europe/Berlin",
...     country_code="DE",
...     state="HE",
...     include_weather_windows=True,
...     include_holiday_features=True,
...     include_poly_features=True,
...     weights={"power": 1.0, "demand": 0.8},
...     verbose=True,
...     freq="h",
... )
>>> print(f"Model Metrics: {metrics}")
>>> print(f"Feature Info: {features}")