# TextResNet

## Quick Start

### 1) Environment

```
python3 -m venv .venv
source .venv/bin/activate
```

### 2) Requirements

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

### 3) Set up API keys

```
export OPENAI_API_KEY=[YOUR KEY]
export ANTHROPIC_API_KEY=[YOUR KEY]
```

### 4) Optional: OpenRouter auto-routing (via LiteLLM)

```
export OPENROUTER_API_KEY=[YOUR KEY]
# optional (default is https://openrouter.ai/api/v1)
export OPENROUTER_API_BASE=https://openrouter.ai/api/v1

# optional (recommended by OpenRouter for attribution)
export OPENROUTER_HTTP_REFERER=https://your.site
export OPENROUTER_X_TITLE=textresnet
```

Auto-route existing model strings to OpenRouter:

```
export TEXTRESNET_USE_OPENROUTER=1
```

### 5) Train & Test

```
python -m scripts.train_textresnet --task hotpotqa --dataset hotpotqa --system_name hotpotqa_system
```

```
python -m scripts.train_textresnet --task bigcodebench --dataset bigcodebench --system_name bigcodebench_system
```

Outputs are stored at:

```
outputs/<dataset>/traces/
```

### 6) Configuration

Key CLI args:

```
--task <hotpotqa|bigcodebench|...>
--dataset <hotpotqa|bigcodebench|...>
--system_name <system name>
--output_dir <default: outputs>
--train_steps <int>
--samples_per_step <int>
--dev_size <int>
--max_concurrency <int>
--eval_every_step <int>
--eval_time <int>
--seed <int>
--wandb_project <str>
--wandb_entity <str>
--wandb_mode <online|offline|disabled>
```

Full defaults and hyperparameters are in `scripts/train_textresnet.py` under `TrainArgs`.