"""
Convert the raw dataset into a Latex table format for inclusion in the paper (LateX).
"""

# Open the excel
import pandas as pd

if __name__ == "__main__":
    df = pd.read_csv("./output/results_T.csv")

    X = df.values[:, 3:]  # Exclude the first 3 columns

    # Round the elements to 2 decimal places
    X = X.astype(float)
    X = X.round(2)

    # Get the minimum for each row
    mins = X.min(axis=1)

    decoders = ['G1', 'G2', 'BS', 'CHRP']
    methods = ['soft_dist', 'DIFUSCO', 'GNNGLS', 'GNNAR']

    to_print = ""

    for i in range(X.shape[0]):
        n = df.iloc[i, 0]
        instance_name = df.iloc[i, 1]
        to_print += f"{n} & {instance_name} "
        # Add Chrstofides first
        christofides_val = df.iloc[i]['christofides']
        if christofides_val == mins[i]:
            to_print += f"& \\textbf{{{christofides_val:.2f}}} "
        else:
            to_print += f"& {christofides_val:.2f} "
        for decoder in decoders:
            for method in methods:
                col_name = f"{method}+{decoder}"
                val = round(df.iloc[i][col_name], 2)
                if val == mins[i]:
                    to_print += f"& \\textbf{{{val:.2f}}} "
                else:
                    to_print += f"& {val:.2f} "
        to_print += "\\\\ \n"

    print(to_print)