from argparse import ArgumentParser

import torch


def print_karger_execution_time_statistics():
    results_file_name = parse_results_file_argument()
    results = torch.load(results_file_name, weights_only=True)

    print("Configuration:")
    print("  num_nodes_per_graph:", results["config"]["num_nodes_per_graph"])
    print("  num_graphs:", results["config"]["num_graphs"])
    print("  max_karger_runs_per_graph:", results["config"]["max_karger_runs_per_graph"])
    print()
    print("Karger-Stein runs until the minimum was found:")
    print("  Min:", results["num_runs_until_minimum_found"].float().min().item())
    print("  Max:", results["num_runs_until_minimum_found"].float().max().item())
    print("  Mean:", results["num_runs_until_minimum_found"].float().mean().item())
    print("  Var:", results["num_runs_until_minimum_found"].float().var().item())
    print()
    print("Execution time until the minimum was found (seconds):")
    print("  Min:", results["time_per_graph"].min().item())
    print("  Max:", results["time_per_graph"].max().item())
    print("  Mean:", results["time_per_graph"].mean().item())
    print("  Var:", results["time_per_graph"].var().item())
    print()
    print("Execution time per single Karger-Stein run (seconds):")
    print("  Min:", results["time_per_karger_run"].min().item())
    print("  Max:", results["time_per_karger_run"].max().item())
    print("  Mean:", results["time_per_karger_run"].mean().item())
    print("  Var:", results["time_per_karger_run"].var().item())


def parse_results_file_argument() -> str:
    """
    Sets up an `argparse.ArgumentParser` with only one positional argument, `results_file`.
    Then, this argument is read from the command line and returned as a string.
    """
    arg_parser = ArgumentParser()
    arg_parser.add_argument("results_file", help="path to the results file generated by karger_execution_time.py")
    args = arg_parser.parse_args()
    return args.results_file


if __name__ == '__main__':
    print_karger_execution_time_statistics()
