# Contextual Recommendation System Experiments

## Output Files
Before running, ensure the following output directories (they will be auto-created on first run):
- Experiment results:
  - `artifacts/output_data/` (synthetic data)
  - `artifacts/output_data_real/` (real data)
- Visualization artifacts:
  - `OffClusBandit/analysis/plot_data/` (intermediate data)
  - `OffClusBandit/analysis/plot_figs/` (final figures)

## Implemented Algorithms
This codebase implements the following algorithms:
- CLUB
- Off-CLUB
- Off-NCLUB
- Off-NCLUB with gamma estimation (Pessimistic/Optimistic)
- DBSCAN
- XMeans
- Base (including Baseline, LinUCB_ind, LinUCB, LinUCB_Neighbor)
- SCLUB
- Baseline

## Dependencies
Main dependencies: `numpy`, `networkx`, `matplotlib`, `scipy`. For XMeans methods, additionally install `pyclustering`.

## Configuration

### Parameter Settings
Parameters and method configurations: `OffClusBandit/configs/default.py`

### Offline Learning Methods
Offline learning methods are configured in `OffClusBandit/configs/default.py`, supporting `random` and `LinUCB_ind`.

## Usage

### Running Experiments
In the project root:
```
python scripts\main_Baseline.py
python scripts\main_synthetic.py
python scripts\main_synthetic_with_best_gamma.py
```
### Running ARMUL Experiments
```
python ARMUL_experiments\run_experiment.py
```

### Generating Figures
```
python OffClusBandit\analysis\plot_regret_vs_D_combine.py
python OffClusBandit\analysis\plot_regret_table.py
python OffClusBandit\analysis\plot_gamma.py
```

