library(igraph)

source('R/cpdag_enumerate.R')
source('R/scm/graph_functions.R')
source('R/causal_discovery.R')

parse_tetrad_output <- function(file_path, node_names) {

  # Create unconnected graph with nodes in the order of node_names
  g <- make_empty_graph(n = length(node_names), directed = TRUE)
  V(g)$name <- node_names

  # Read the file into R
  lines <- readLines(file_path, warn = FALSE)

  # Find the line where edge definitions start
  edge_line <- grep("Graph Edges:", lines)

  # Extract edge definitions from the lines following the "Graph Edges:" line
  edge_definitions <- lines[(edge_line + 1):length(lines)]

  # Filter out any lines that do not contain edge definitions
  edge_definitions <- edge_definitions[grep("-->|---", edge_definitions)]

  for (edge_line in edge_definitions) {

    # Format 1. ABETA --> APOE4
    # Extract first node
    parts <- strsplit(edge_line, " ")[[1]]
    from_node <- sub(".*\\. ", "", parts[2])
    to_node <- sub(" .*", "", parts[4])
    edge_type <- ifelse(grepl("-->", edge_line), "directed", "undirected")

    # Add the edge to the graph
    if (edge_type == "directed") {
      g <- add_edges(g, c(from_node, to_node), directed = TRUE)
    } else {
      # For undirected edges, add edges in both directions
      g <- add_edges(g, c(from_node, to_node), directed = FALSE)
      g <- add_edges(g, c(to_node, from_node), directed = FALSE)
    }
  }

  return(g)
}


parse_to_mec <- function(file_path, node_names) {
  igraph_cpdag <- parse_tetrad_output(file_path, node_names)

  # Enumerate dags in cpdag
  cpdag_adj_mat <- igraph::as_adjacency_matrix(igraph_cpdag, sparse = FALSE)

  if (!pcalg::isValidGraph(t(cpdag_adj_mat), "pdag")) {
    return(FALSE)
  }

  dags_adjacency_matrices <- enumerate_cpdag(cpdag_adj_mat)
  n_dags <- length(dags_adjacency_matrices)
  igraph_dags <- list()
  for (dag_idx in seq(n_dags)) {
    adj_matrix <- dags_adjacency_matrices[[dag_idx]]

    igraph_dag <- igraph::graph_from_adjacency_matrix(adj_matrix, mode = "directed")

    igraph_dags <- append(igraph_dags, list(igraph_dag))
  }
  return(igraph_dags)
}
