# In-Context Adversarial Generalization

This repository contains an implemention of the In-Context Adversarial Generalization (ICAG) and In-Context Adversarial Adaptation (ICAA).
ICAG is a robust in-context reinforcement learning using transformer for supervised pretraining. By robust data augmentation, ICAG bypass solving max-min optimization but generate more downstream tasks with robust offline trajectories. We build on the repos [DPT](https://github.com/jon--lee/decision-pretrained-transformer/tree/main) and [QARL](https://github.com/AryamanReddi99/quantal-adversarial-rl/tree/main).
 


This repo supports pretraining and evaluating in the following settings:
- Dark Room (2D sparse-reward navigation)
- A broad set of MuJoCo tasks


## Instructions for Setting Up the Environment


To create a new conda environment, open your terminal and run the following command:

```bash
conda create --name dpt python=3.8.17
```

Install PyTorch by following the [official instructions here](https://pytorch.org/get-started/locally/) appropriately for your system. The recommended versions for the related packages are as follows with CUDA 11.7:

```bash
torch==1.13.0
torchvision==0.14.0
```
For example, you might run:

```bash
conda install pytorch=1.13.0 torchvision=0.14.0 cudatoolkit=11.7 -c pytorch -c nvidia
```

The remaining requirements are fairly standard and are listed in the `requirements.txt`. These can be installed by running

```bash
pip install -r requirements.txt
```


## Running Experiments

Each experiment has three phases: (1) pretraining data collection (2) pretraining (3) evaluation of the in-context algorithm. Dark Room is in `run_darkroom.sh` that show example usage to run these. Specifically,the default setting for --env is 'darkroom_id'. The options include 'darkroom_ood','darkroom_mix','darkroom_ood8', 'darkroom_ood16'. ood indicates the data collection for our ICAG using different number of priors and mix implies the dataset for mix-DPT. For MuJoCo tasks, pretraining data collection can be done within mujoco/collect_data.py, before training transformer in the same train.py as for Dark Room.

