#include "dataset.h"

#include <fstream>
#include <stdexcept>

DataSet::DataSet(const std::string &path, int n) : n_(n) {
    std::ifstream in(path);
    if (!in) {
        throw std::runtime_error("Failed to open data file: " + path);
    }
    std::string tok;
    while (in >> tok) {
        tokens_.push_back(tok);
    }
    stride_ = 3 * n_ + 2;
    if (tokens_.size() % stride_ != 0) {
        throw std::runtime_error("Token count not divisible by 3*n+2");
    }
}

int DataSet::count() const {
    return static_cast<int>(tokens_.size() / stride_);
}

Instance DataSet::load_instance(int index) const {
    int total = count();
    if (index < 0 || index >= total) {
        throw std::runtime_error("instance_index out of range");
    }
    int base = index * stride_;
    if (tokens_[base + 2 * n_] != "output") {
        throw std::runtime_error("Expected 'output' token in data file");
    }

    Instance inst;
    inst.n = n_;
    inst.x.resize(n_);
    inst.y.resize(n_);
    for (int i = 0; i < n_; ++i) {
        inst.x[i] = std::stod(tokens_[base + 2 * i]);
        inst.y[i] = std::stod(tokens_[base + 2 * i + 1]);
    }
    inst.opt_tour.resize(n_);
    for (int i = 0; i < n_; ++i) {
        inst.opt_tour[i] = std::stoi(tokens_[base + 2 * n_ + 1 + i]) - 1;
    }
    inst.has_opt = true;
    return inst;
}
