#pragma once

#include <string>

// -----------------------------
// Config parsing and common utilities
// -----------------------------
struct Config {
    // Input data file (packed coordinates + reference tour)
    std::string data_file;
    int instance_index = 0;
    // Batch run switch (true = run all instances in this size file)
    bool run_all = false;
    // If N cannot be inferred from filename, set explicitly
    int num_nodes = 0;

    // MMAS core parameters
    int ants = 64;
    int iterations = 500;
    int candidate_list_size = 20;
    // nn_ants/nn_ls follow ACOTSP-style candidate list sizes
    int nn_ants = 20;
    int nn_ls = 20;
    int threads = 0;
    double alpha = 1.0;
    double beta = 2.0;
    double rho = 0.2;
    double q = 1.0;
    double q0 = 0.0;
    double p_best = 0.05;
    double tau_min = -1.0;
    double tau_max = -1.0;
    double lambda = 0.05;
    double branch_fac = 1.00001;
    int u_gb = 25;
    int dlb_flag = 1;
    int max_time_seconds = 0;
    int seed = 1;

    // Local search parameters
    std::string local_search = "none";
    int max_2opt_passes = 1;
    int max_3opt_passes = 1;
    int lk_passes = 2;
    int lk_depth = 5;

    // Heatmap sparsification mode
    std::string heatmap_mode = "none";
    std::string heatmap_file;
    // Heatmap directory mode: specify only the folder name
    std::string heatmap_root = "all_heatmap";
    std::string heatmap_dir;
    std::string heatmap_type;
    double heatmap_threshold = 1e4;
    double confidence_gamma = 1.0;

    // Distance matrix policy
    std::string distance_mode = "auto"; // auto | precompute | ondemand
    int distance_precompute_limit = 4000;

    // Output directory (defaults when empty)
    std::string output_dir;
};

Config parse_config(const std::string &path);
