import numpy as np
from castle.algorithms import GOLEM
import graph


def run_golem(data_path):
    X = np.genfromtxt(data_path, delimiter=",", skip_header=1)
    n = GOLEM(equal_variances=False)
    n.learn(X)
    B = n.causal_matrix
    p, _ = B.shape
    dir_edges = []
    for u in range(p):
        for v in range(p):
            if u == v:
                continue
            if abs(B[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_golem.py <data.csv>")
        sys.exit(1)

    data_path = sys.argv[1]

    run_golem(data_path).write()
