// compile with c++20 or higher

#include <bits/stdc++.h>

#include "graph_cc_cost_working.hpp"

using namespace std;


void run_k_vs_error(string input_file, float threshold) {
  cout << "reading in graph from " << input_file << "..." << endl;

  auto in = deserialize(input_file, threshold);
  vector<element> G;
  G.reserve(in.size());
  for (int i = 0; i < in.size(); i++)
    G.push_back({i, in[i]});

  cout << "finished reading graph!" << endl;
  
  // output_packs(Ints<1, 2, 3>{}, Doubles<1.5, 2.5, 3.5>{});
  // return;
  
  // auto res = run_experiment<10, 15, .01, .02, .04, .08, .16>(G);
  // auto [res_pivot, res_pruned_pivot, res_cc_cost] = run_k_vs_error_experiment<30, .08, 5, 10, 15, 20>(G);
  // auto [res_pivot, res_pruned_pivot, res_cc_cost] = run_experiment<3, 1, .01>(G);


  // main big one
  // auto res = run_experiment<30>(G, k_range<1,30>{}, space_seq<.01, .02, .04, .08, .16>{});
  auto res = run_experiment<150>(G, k_range<1,30>{}, space_seq<.001, .002, .005, .01, .02, .04, .08, .16>{});

  // auto res = run_experiment<10>(G, k_range<1,30>{}, space_seq<.04>{});

  // auto res = run_experiment<30>(G, k_seq<5,10,15>{}, space_seq<.01, .04, .08>{});
  // auto res = run_experiment<30>(G, k_seq<5,10,15>{}, space_seq<.01, .02, .04, .08, .16>{});
  
  auto [res_pivot, res_pruned_pivot, res_cc_cost] = res;

  string out_folder = "./results/";
  assert(folder_exists(out_folder));

  std::filesystem::path input_path(input_file);
  string basename = input_path.stem().string();

  if (threshold > 0) {
    std::stringstream ss;
    ss << std::fixed << std::setprecision(3) << threshold;
    std::string thresh_str = ss.str().substr(2);
    basename += "_threshold_" + thresh_str;
  }

  string latest_file = out_folder + basename + "_kve_results_latest.txt";
  auto output_file = out_folder + timestamp_filename(basename + "_kve_results_", ".txt");

  std::ofstream of(output_file);

  of << "[\n";

  for (auto x : res_pivot)
    write_baseline_stats_json(of, x, true);
  for (auto x : res_pruned_pivot)
    write_baseline_stats_json(of, x, true);
  for (int i = 0; i < res_cc_cost.size(); i++)
    write_exec_stats_json(of, res_cc_cost[i], i+1 < res_cc_cost.size());

  of << "]" << endl;

  of.close();

  stringstream command;
  command << "cp " << output_file << " " << latest_file;
  std::system(command.str().c_str());
}

int main(int argc, char* argv[]) {
  cin.tie(0)->sync_with_stdio(0);
  cin.exceptions(cin.failbit);

  if (argc < 2) {
    cerr << "usage: " << argv[0] << " graph_file" << endl;
    return 1;
  }

  string filename = argv[1];
  if (!filename.ends_with(".bin") && !filename.ends_with(".npz")) {
    cerr << "input graph must be in binary format (.bin) or numpy format (.npz)" << endl;
    return 1;
  }

  float threshold = argc < 3 ? -1 : std::stof(argv[2]);

  // run(filename);
  run_k_vs_error(filename, threshold);

  return 0;
}

