# MMAS config example (detailed notes)

# ===================== Input Data =====================
# data_file: data file for a given size (tsp500/tsp1000/tsp10000)
# num_nodes: set explicitly if N cannot be inferred from filename
# run_all: 1 = run all instances in the size file; 0 = run only instance_index
# instance_index: instance index for single-instance mode (0-based)
data_file = data/tsp500.txt
num_nodes = 500
run_all = 1
instance_index = 0

# ===================== MMAS Core Parameters =====================
ants = 32
iterations = 2500
alpha = 1.0
beta = 2.0
rho = 0.8
q = 1.0
q0 = 0.0
p_best = 0.05
candidate_list_size = 20
nn_ants = 20
nn_ls = 20
lambda = 0.05
branch_fac = 1.00001
u_gb = 25
dlb_flag = 1
# tau_min/tau_max <= 0 triggers auto-compute
# tau_max = 1 / (rho * L_nn)
# tau_min starts at tau_max/(2N); without local search, update via p_best after improvement
# tau_min = -1
# tau_max = -1

# ===================== Local search =====================
# none | 2opt | 2.5opt | 2hopt | 3opt | lk
local_search = 2hopt
max_2opt_passes = 0
max_3opt_passes = 0
lk_passes = 2
lk_depth = 5

# ===================== Heatmap Sparsification =====================
# heatmap_mode: none | threshold
# heatmap_root + heatmap_dir: specify only the folder name (recommended)
# heatmap_file: supports {n}/{idx} template, or a directory path (optional)
# heatmap_type: alias of heatmap_dir for quick method switching
# If heatmap_type and heatmap_dir are empty, iterate all types under all_heatmap
# Example: heatmap_type = attgcn/difusco / dimes / utsp 
heatmap_mode = threshold
heatmap_root = all_heatmap
# heatmap_dir = difusco
heatmap_type = difusco
# heatmap_file = all_heatmap/difusco/heatmap/tsp{n}/heatmaptsp{n}_{idx}.txt
heatmap_threshold = 0.0001
confidence_gamma = 0.5

# ===================== Distance matrix policy =====================
# distance_mode: auto | precompute | ondemand
# auto: precompute when N <= distance_precompute_limit
# precompute: force precompute (higher memory usage)
# ondemand: compute distances on the fly
# distance_precompute_limit: threshold for auto mode
distance_mode = precompute
distance_precompute_limit = 10000

# ===================== Run Control =====================
seed = 42
threads = 16
max_time_seconds = 0

# ===================== Output =====================
# Single instance: convergence.csv / summary.csv / best_tour.txt
# Batch (run_all=1): summary_all.csv / convergence_all.csv
output_dir = 
