# Contextual Bandit Simple Regret

This repository contains implementations of algorithms in the submitted paper

## Overview

The codebase implements several contextual bandit environments and algorithms:

## Experiments
### run_exp_stage.py
To run the comparison on SimpleLinTS, Uniform Exploration, and CumuLinTS on the environment provided in the linear case of the experiment section for a fixed number of rounds, use 
`python run_exp_stage.py` where one can change the parameters in the first two lines of main function. This script is for running the experiment on multiple $K$'s, one can set the list which contains the number of arms to contain only $1$ element (line 156) to run the experiment on a specific $K$.

### run_state_to_precision.py
To run experiment on SimpleLinTS, Uniform Exploration, and CumuLinTS on the environment provided in the linear case of the experiment section for an error level, use `python run_state_to_precision.py`. Specify the parameters in line 156-162. Use `python linloglogplot.py` to plot.

### log_run_exp_unnorm.py
To run the comparison on SimpleLinTS+MLE, THaTS on the environment provided in the logistic case of the experiment section for a fixed number of rounds, use 
`python log_run_exp_unnorm.py` where one can change the parameters in the first few lines of main function.

### log_run_to_precision.py
To run the comparison on SimpleLinTS+MLE, THaTS on the environment provided in the logistic case of the experiment section for an error level, use `python log_run_to_precision.py`. Specify the parameters in line 228-241. Use `python logplot.py` to plot.