# HeatACO: Heatmap-Guided Ant Colony Decoding for Large-Scale Travelling Salesman Problems

This is an **anonymous** repository for an ICML submission. It contains the code and configuration used to run HeatACO on large-scale TSP instances and TSPLIB benchmarks.

## Overview

HeatACO augments a Min-Max Ant System (MMAS) solver with optional heatmap-guided sparsification to accelerate decoding on large instances. The solver supports:

- Standard MMAS construction and updates.
- Candidate lists and ACOTSP-style local search (2-opt / 2.5-opt / 3-opt / LK).
- Heatmap-guided sparsification via thresholding, with optional confidence weighting.

## Repository Structure

- `MMAS/` — main solver for large synthetic instances.
- `MMAS_TSPLIB/` — solver configured for TSPLIB benchmarks.
- `all_heatmap/` — heatmap files for large instances (method-specific subfolders).
- `tsplib_heatmap/` — heatmaps for TSPLIB instances.
- `data/` — packed input data for large instances.
- `tsplib_eval/` — packed TSPLIB evaluation inputs.

## Requirements

- CMake >= 3.16
- C++20 compiler
- (Optional) Python 3 for heatmap generation scripts

## Build

```bash
cmake -S MMAS -B MMAS/build
cmake --build MMAS/build -j

cmake -S MMAS_TSPLIB -B MMAS_TSPLIB/build_tsplib
cmake --build MMAS_TSPLIB/build_tsplib -j
```

## Quick Start

Run a single instance using a config file:

```bash
./MMAS/build/mmas --config MMAS/config/example.ini
```

For TSPLIB benchmarks:

```bash
./MMAS_TSPLIB/build_tsplib/mmas --config MMAS_TSPLIB/config/pcb442.ini
```

## Configuration

Configs are INI files located under `MMAS/config/` and `MMAS_TSPLIB/config/`. Key options:

- `data_file`, `num_nodes`, `run_all`, `instance_index`
- MMAS parameters: `ants`, `iterations`, `alpha`, `beta`, `rho`, `q0`, `p_best`
- Candidate lists: `candidate_list_size`, `nn_ants`, `nn_ls`
- Local search: `local_search`, `max_2opt_passes`, `max_3opt_passes`, `lk_passes`, `lk_depth`
- Heatmaps: `heatmap_mode`, `heatmap_root`, `heatmap_type`, `heatmap_threshold`, `confidence_gamma`
- Output: `output_dir` (defaults to a structured path if empty)

See `MMAS/config/example.ini` for a full, documented template.

## Batch Runs (SLURM)

Scripts are provided for batch job submission:

- `MMAS/scripts/submit_all.sh`
- `MMAS_TSPLIB/scripts/submit_all.sh`

These scripts generate per-job configs and submit each run as a separate SLURM job.

## Output

For each run, the solver writes:

- `convergence.csv` — per-iteration best length and time
- `summary.csv` — run summary and parameters
- `best_tour.txt` — best tour (1-based indices)

For batch runs (`run_all=1`), the aggregated outputs are:

- `summary_all.csv`
- `convergence_all.csv`

## Anonymity

This repository is intentionally anonymized for double-blind review. If you notice any identifying information, please report it via the anonymous review channel.
