
# Overview

The notebook named "experiment.ipynb" is designed for experiments and validation of the online gradient descent algorithm with various learning rates for non-stationary online structured prediction problems. See our paper "Non-Stationary Online Structured Prediction with Surrogate Losses" for details.

## Main Contents

- **Data Generation**: Implements the `generate_dataset` function to generate samples and labels (with noise and nonstationarity) on the unit sphere.
- **Loss Functions & Decoding**: Implements logistic loss, gappletron-style decoder, and other functions required for online learning.
- **OGD (Online Gradient Descent) Algorithm**: Implements OGD with various step size options (constant, AdaGrad, Polyak-style).
- **Multiple Trials & Visualization**: Aggregates cumulative losses over multiple configurations and trials, and plots mean and confidence intervals.

## Example Experiments

- Compares OGD performance with different step sizes for several cases of label flip counts (nonstationarity): 1, 10, and 100 times.
- Results are saved as PDF files.

## Dependencies

- numpy
- matplotlib

## How to Run

1. Install the required libraries.
2. Run the notebook.
