#  ASRO

## Overview

`asro` implements **ASRO (Algorithm-Space Response Oracles)**, a game-theoretic framework for automatic heuristic discovery.
The **core ASRO logic resides in `asro/core/`**, while **each combinatorial optimization task is implemented under `asro/problems/`** following a unified convention.

ASRO coordinates solver–generator co-evolution, restricted game updates, and evaluation.
Problem-specific components (data, baselines, evaluation protocols) are isolated from the core logic.

## ASRO Control Flow

### `asro/core/`

- Implements the ASRO loop and restricted-game updates  
- Maintains solver and generator strategy pools  
- Invokes LLM-based best-response oracles  
- Handles payoff evaluation and population updates  

### `asro/problems/<problem_name>/`

- Defines instance generation and solver interfaces  
- Specifies problem-specific evaluation protocols and baselines  
- Contains the experiment entry point  

ASRO logic is **problem-agnostic**; adding a new problem does **not** require changes to `asro/core/`.

---

## Running an Experiment

To run ASRO on a specific problem:

```bash
cd asro/problems/<problem_name>
python run_experiment.py
```
All experiment outputs (logs, solver/generator pools, metrics) are saved to:

```
heupsro/experiments/
```


## Configuration and LLM Setup

Each problem provides a config.py.
LLM usage is controlled exclusively through configuration:
```
llm_model: str = "gpt-4o-mini"
llm_api_endpoint: str = "https://api.openai.com/v1"
llm_api_key: str = "YOUR_API_KEY"
```
This enables flexible switching between different LLM backends without modifying core code.


## Acknowledgement

This codebase builds upon and reuses components from the **Evolution of Heuristics (EoH)** framework:

> Fei Liu et al., *Evolution of Heuristics: Towards Efficient Automatic Algorithm Design Using Large Language Model*,  
> ICML 2024.

The original EoH implementation is released under the **MIT License** and is publicly available at:  
https://github.com/FeiLiu36/EoH

We thank the authors for releasing their code, which serves as an important foundation for our implementation.
All reused or adapted components comply with the terms of the MIT License.




---

## Project Structure

```
asro/
├── core/                       # ASRO core logic (game loop, PSRO-style control)
│   ├── metagame.py/            
│   ├── controller.py/              
│   └── ...

│
├── problems/                   # Problem-specific implementations
│   ├── bp_online/
│   │   ├── run_experiment.py   # Entry point for ASRO on this problem
│   │   ├── config.py           # Experiment & LLM configuration
│   │   ├── evolution/          # Program search mechanism
│   │   └── testing/            #  evaluation interface
│   ├── tsp_gls/
│   ├── cvrp/
│   └── ...
│
└── ...
```


