// compile with c++20 or higher

#include <bits/stdc++.h>

#include "graph_cc_cost_working.hpp"

using namespace std;

void run_space_vs_error_full(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;

  // main big one
  // auto res = run_experiment<150>(G, k_seq<5>{}, space_seq<
  //      0.001     , 0.00119125, 0.00141908, 0.00169049, 0.0020138 ,
  //      0.00239895, 0.00285775, 0.00340431, 0.00405539, 0.004831  ,
  //      0.00575495, 0.0068556 , 0.00816676, 0.00972868, 0.01158932,
  //      0.01380582, 0.01644622, 0.01959162, 0.02333858, 0.02780216,
  //      0.03311942, 0.03945362, 0.04699926, 0.05598803, 0.06669592,
  //      0.07945174, 0.09464716, 0.11274874, 0.13431232, 0.16>{});
  auto res = run_experiment<100, false, true>(G, k_seq<15>{}, space_seq<
      0.02      , 0.02231316, 0.02489385, 0.02777302, 0.03098519,
      0.03456888, 0.03856704, 0.04302762, 0.04800411, 0.05355616,
      0.05975036, 0.06666096, 0.07437083, 0.0829724 , 0.09256882,
      0.10327514, 0.11521972, 0.1285458 , 0.14341314, 0.16      
    >{});
  auto [res_pivot, res_pruned_pivot, res_cc_cost, res_edge] = 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 base_file = out_folder + basename + "_space_vs_error_";
  string latest_file = base_file + "latest.txt";
  auto output_file = timestamp_filename(base_file, ".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 (auto x : res_edge)
    write_exec_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_space_vs_error_full(filename, threshold);

  return 0;
}
