#pragma once

#include <string>
#include <vector>

#include "dataset.h"
#include "distance.h"

// -----------------------------
// Candidate lists
// -----------------------------
struct CandidateList {
    int n = 0;
    int k = 0;
    // Fixed-length candidate list (k per row)
    std::vector<int> nodes;
    // Precomputed heuristic information (1/d)^beta
    std::vector<float> inv_dist_beta;

    const int *row(int i) const { return nodes.data() + i * k; }
    const float *row_inv(int i) const { return inv_dist_beta.data() + i * k; }
};

CandidateList build_nn_candidates(const Instance &inst,
                                  const DistanceProvider &dist,
                                  int k,
                                  double beta,
                                  int threads);

CandidateList build_heatmap_candidates(const Instance &inst,
                                       const DistanceProvider &dist,
                                       const CandidateList &nn,
                                       int k,
                                       double beta,
                                       const std::string &heatmap_path,
                                       double threshold,
                                       bool confidence_mode,
                                       double confidence_gamma); // When confidence_mode=true, use confidence as an extra heuristic factor
