# MO-TRIPLE

## Environment
We suggest installing the environment from the `requirements.txt` file.
```bash
pip install -r requirements.txt
```
Before running the code, set your OpenAI API key (required by some backends).
```bash
export OPENAI_API_KEY=YOUR_KEY
```
In `src/LLM/WhiteBox.py`, update the directory path to point to your local copies of Llama3 or Gemma if you want to use local checkpoints:
```python
hf_checkpoints_path = "/YOUR/MODEL/PATH/"
```

## Pipeline

#### 0) Configure tasks/models (edit scripts)
Edit the `task` and `model` variables at the top of the scripts in `scripts/` (e.g., `cnn_dailymail`/`xsum`/`samsum` and `Llama3`/`Gemma`) so the pipeline targets your desired setup.

#### 1) Collect candidate prompts → `results/MO/${task}_WhiteBox_${model}/prompts.csv`
This step generates a pool of candidate prompts and saves them for later evaluation.
```bash
bash scripts/data_collection.sh
```

#### 2) Evaluate prompts (seed=43) → `results/MO/${task}_WhiteBox_${model}/prompts_43.csv`
This step scores the collected prompts under a fixed seed and writes the scored arm set.
```bash
bash scripts/prompt_evaluate.sh
```

#### 3A) Pareto-front experiments (EGE / MLP_EGE / Pareto_Uni)
This step runs multi-objective (Pareto) bandit experiments using the evaluated prompts.
```bash
bash scripts/main_exp_MO_pareto.sh
```

#### 3B) Constrained-selection experiments (CSR / MLP_CSR / Constrained_Uni)
This step runs constrained bandit experiments with a preset constraint threshold in the script.
```bash
bash scripts/main_exp_MO_constrained.sh
```
