# Robust Sequential Experimental Design for A/B Testing (Dynamic Setting)

This repository contains the official PyTorch implementation for the **dynamic setting experiments** presented in the paper *Robust Sequential Experimental Design for A/B Testing*.

The code implements a neural network-based policy for sequential experimental design along with some baselines for comparison.

## 📂 File Structure

The codebase consists of the following Python scripts:

* **`utils_self.py`**
    Contains essential auxiliary functions, including:
    * ATE (Average Treatment Effect) estimation methods.
    * Monte Carlo ground truth generation.
    * Other utility helpers for the environment.

* **`DGP_info.py`**
    Defines the configuration and parameters for the Data Generating Process (DGP) used in the experiments.

* **`train_robust.py`**
    The training script for the proposed **Robust Sequential** method.
    * *Output:* Saves model weights to `runs_robust/`.

* **`train_nonrobust.py`**
    The training script for the **Non-Robust** baseline method.
    * *Output:* Saves model weights to `runs_1/`.

* **`eval.py`**
    The evaluation script. It loads the trained checkpoints from both methods, runs simulations, and compares performance against various baselines (Non-robust, Random, Switchback, NMDP, TMDP).

## 🛠️ Requirements

* Python >= 3.8
* PyTorch
* NumPy
* Pandas
* Matplotlib
* Joblib (for parallel processing in evaluation)

To install dependencies, run:
```bash
pip install torch numpy pandas matplotlib joblib