#pragma once

#include <vector>

#include "candidates.h"
#include "config.h"
#include "dataset.h"
#include "distance.h"

// -----------------------------
// MMAS result structure
// -----------------------------
struct IterationStat {
    int iteration = 0;
    double best = 0.0;
    double iter_best = 0.0;
    double elapsed = 0.0;
    double gap = 0.0;
};

struct MMASResult {
    std::vector<IterationStat> stats;
    std::vector<int> best_tour;
    double best_length = 0.0;
    int best_iter = 0;
};

// Path length computation is used across modules
double tour_length(const DistanceProvider &dist, const std::vector<int> &tour);

// -----------------------------
// MMAS main solver
// -----------------------------
class MMASSolver {
public:
    MMASSolver(const Instance &inst,
               const DistanceProvider &dist,
               const CandidateList &cand,
               const Config &cfg);

    MMASResult run();

private:
    const Instance &inst_;
    const DistanceProvider &dist_;
    const CandidateList &cand_;
    const Config &cfg_;
};
