# MMAS

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

## Build

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

## Run

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

## Output

The solver writes results to `output_dir` (from config). If `output_dir` is empty,
it defaults to `output/{sparsify}/TSP{n}/gemma_{confidence_gamma}/thr{heatmap_threshold}/{local_search}/seed{seed}`.

- Single instance:
  - `convergence.csv`: per-iteration best lengths and elapsed time.
  - `summary.csv`: run summary and full parameter record.
  - `best_tour.txt`: 1-based tour order.
- Batch (`run_all=1`):
  - `summary_all.csv`: one row per instance with final results + all parameters.
  - `convergence_all.csv`: per-iteration convergence for each instance.

## Config Notes

- `data_file` points to the packed test data file.
- `instance_index` selects which instance to solve (0-based).
- `candidate_list_size` is a fallback when `nn_ants`/`nn_ls` are not provided.
- `nn_ants` controls candidate list depth for tour construction; `nn_ls` controls local search depth.
- `q0` is the greedy selection probability in ACOTSP-style construction.
- `lambda` and `branch_fac` control branching-factor-based restart.
- `u_gb` is the initial update interval; when local search is enabled, ACOTSP's schedule adjusts it.
- `dlb_flag=1` enables don't-look bits in local search.
- `heatmap_mode=threshold` uses heatmap sparsification with `heatmap_threshold`.
- `confidence_gamma` applies only to confidence heatmaps (`difusco`, `utsp`, `attgcn`, `dimes`) and multiplies the heuristic by `confidence^gamma`.
- `heatmap_root` + `heatmap_dir` lets you specify only the folder name (e.g. `heatmap_dir=utsp`) and will resolve to `all_heatmap/difusco/heatmap/tsp{n}/heatmaptsp{n}_{idx}.txt`.
- `heatmap_type` is an alias of `heatmap_dir` to switch methods such as `difusco`, `dimes`, `utsp`.
- If `heatmap_mode=threshold` and both `heatmap_type`/`heatmap_dir` are empty, the solver will iterate all heatmap types under `heatmap_root` sequentially. When `output_dir` is set in this mode, it is treated as a root prefix and outputs go to `output_dir/{heatmap_type}/TSP{n}/gemma_{confidence_gamma}/thr{heatmap_threshold}/{local_search}/seed{seed}`.
- `heatmap_file` can also be used (supports `{n}` and `{idx}` placeholders or a directory).
- `local_search` supports `none`, `2opt`, `2.5opt`/`2hopt`, `3opt`, `lk`.
- `2opt`/`2.5opt`/`3opt` are ACOTSP-style local search with candidate lists and DLB.
- `lk` is an optional depth-limited Lin-Kernighan search built on the candidate list.
- `convergence.csv` includes `best_gap` (percentage), computed against the reference tour embedded in the data file.
- `run_all=1` runs all instances in the data file and writes `summary_all.csv` + `convergence_all.csv`.
- `distance_mode=precompute` is recommended for speed; it precomputes all distances once (higher memory use).
