import numpy as np
import sys
from CausalDisco.baselines import r2_sort_regress

import graph


def run_r2(data_path):
    X = np.genfromtxt(data_path, delimiter=",", skip_header=1)
    W = r2_sort_regress(X)
    p, _ = W.shape
    dir_edges = []
    for u in range(p):
        for v in range(p):
            if W[u, v] != 0.0:
                dir_edges.append((u, v))
    return graph.CausalGraph(p, dir_edges, [], "dag")


if __name__ == "__main__":
    import sys

    if len(sys.argv) != 2:
        print("Usage: python run_r2.py <data.csv>")
        sys.exit(1)

    data_path = sys.argv[1]
    run_r2(data_path).write()
