import graph
import lingam
import numpy as np


def run_lingam(data_path):
    X = np.genfromtxt(data_path, delimiter=",", skip_header=1)
    model = lingam.DirectLiNGAM()
    model.fit(X)
    W = model.adjacency_matrix_
    p, _ = W.shape
    dir_edges = []
    for u in range(p):
        for v in range(p):
            if abs(W[u, v]) != 0.0:
                dir_edges.append((v, u))
    return graph.CausalGraph(p, dir_edges, [], "dag")


if __name__ == "__main__":
    import sys

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

    data_path = sys.argv[1]

    run_lingam(data_path).write()
