# HATS: Hierarchical Adaptive Task Scheduler

This repository contains the implementation of HATS (Hierarchical Adaptive Task Selection), a curriculum learning method for training MetaBBO optimizers.

This codebase is built upon [SYMBOL](https://github.com/MetaEvo/Symbol) (ICLR 2024).

## Installation

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

## Requirements

- Platform: Linux (recommended for better parallelism)
- Python 3.8+
- PyTorch 2.0+

## Quick Start

### Training

To train HATS (our proposed method):

```bash
bash run.sh hats 0
```

The first argument specifies the training mode, and the second argument specifies the GPU ID.

Available modes:
- `hats` or `mab-robust_plr`: HATS (our proposed method)
- `mab-plr`: MAB-based PLR without robust gradient strategy
- `robust_plr`: Standard Robust PLR
- `plr`: Standard PLR
- `dummy`: Standard training without curriculum

### Testing

```bash
python run.py --test --load_path _path_to_checkpoint
```

## Project Structure

```
.
├── run.py                  # Main entry point
├── run.sh                  # Training script
├── options.py              # Command-line arguments
├── requirements.txt        # Dependencies
├── dataset/                # Dataset and problem definitions
│   ├── cec_dataset.py
│   ├── cec_test_func.py
│   └── generate_dataset.py
├── data_scheduler/         # HATS scheduler implementation
│   └── plr_scheduler.py
├── execute/                # Training and evaluation logic
│   ├── train.py
│   ├── rollout.py
│   └── task.py
├── model/                  # Neural network models
│   ├── lstm.py
│   └── critic.py
├── pbo_env/                # Optimization environments
├── population/             # Population management
├── expr/                   # Expression parsing
├── env/                    # Parallel environment utilities
└── utils/                  # Utility functions
```

## License

MIT License
