# OffClusBandit Refactoring and Migration Guide

## New directory layout

```
OffClusBandit/
├── OffClusBandit/                    # Main package
│   ├── core/                         # Core modules
│   │   ├── Base.py                   # Base classes and algorithms
│   │   ├── Environment.py            # Environment
│   │   ├── Tools.py                  # Utilities
│   │   └── utils.py                  # Utilities
│   ├── algorithms/                   # Algorithms
│   │   ├── bandits/                  # Bandit methods
│   │   │   ├── CLUB.py
│   │   │   ├── Off_CLUB.py
│   │   │   ├── Off_SCLUB.py
│   │   │   ├── Off_NCLUB.py
│   │   │   ├── Off_NCLUB_estimate_gamma.py
│   │   │   ├── Off_NCUCB_estimate_gamma.py
│   │   │   └── (extend here)
│   │   └── clustering/               # Clustering methods
│   │       ├── XMeans_improve.py
│   │       └── DBSCAN_improve.py
│   ├── data/                         # Data processing
│   │   ├── datasets/                 # Prepared datasets
│   │   ├── read_movielens.py
│   │   ├── read_yelp.py
│   │   ├── ExtractUserFeatures.py
│   │   └── data_config.py
│   ├── analysis/                     # Analysis & visualization
│   │   ├── plot_gamma.py
│   │   ├── plot_regret_table.py
│   │   ├── plot_regret_vs_D_combine.py
│   │   ├── generate_table_from_saved_data.py
│   │   ├── plot_data/
│   │   └── plot_figs/
│   └── configs/                      # Configurations
│       └── default.py                # Default config
├── scripts/                          # Experiment scripts
│   ├── main_synthetic.py
│   ├── main_synthetic_with_best_gamma.py
│   ├── main_Baseline.py
│   ├── experiment.py
│   └── change_name.py
├── ARMUL_experiments/                          # ARMUL Experiment scripts
│   ├── ARMUL.py
│   ├── MTL.py
│   ├── preprocessing.py
│   ├── run_experiment.py
│   └── experiment.py
├── artifacts/                        # Outputs
│   ├── output_data/
│   └── output_data_real/
└── README.md
```

## How to use the new structure

### 1) Run experiment scripts

```bash
# from project root
python scripts/main_synthetic.py
```

### 2) Import modules

```python
# core modules
from OffClusBandit.core.Environment import Environment
from OffClusBandit.core.utils import generate_items
from OffClusBandit.core.Base import LinUCB, LinUCB_IND

# algorithms
from OffClusBandit.algorithms.bandits.CLUB import CLUB
from OffClusBandit.algorithms.bandits.Off_CLUB import OffCLUB

# configs
from OffClusBandit.configs.default import alpha_list, gamma_list

# helpers
from OffClusBandit.core.Tools import create_algorithm_instance
```

### 3) Example in scripts

```python
import sys
import os
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

from OffClusBandit.core.Environment import Environment
from OffClusBandit.core.utils import generate_items
from OffClusBandit.configs.default import alpha_list
from OffClusBandit.algorithms.bandits.CLUB import CLUB
```

## Completed migration items

✅ Layout reorganization  
✅ Core modules migrated  
✅ Algorithms migrated  
✅ Data processing migrated  
✅ Analysis migrated  
✅ Configs migrated  
✅ Scripts migrated  
✅ Import paths updated  
✅ Basic smoke tests passed  

## Notes

1. External dependencies: some modules need extra packages (e.g., `pyclustering`). Install as needed.
2. Data files: experiment outputs go to `artifacts/`; analysis intermediates and figures go to `OffClusBandit/analysis/plot_data` and `OffClusBandit/analysis/plot_figs`.
3. Imports: analysis and scripts append `sys.path` to enable absolute imports to avoid relative import issues.
4. Running scripts: ensure you are in the correct working directory.

## Recommendations

1. Provide a `requirements.txt` (exists in repo).
2. Add `setup.py` or `pyproject.toml` for installable packaging.
3. Improve docs and examples.
4. Add unit tests.
5. Consider configuration management for experiment parameters.
