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

test_that("enumerate outputs the same output as pdag2dags", {
  set.seed(123)

  for (i in seq_len(40)) {
    n_expected_neighbors <- sample(1:3, 1)
    n_expected_parents_y <- sample(3:7, 1)
    n_nodes <- sample(7:12, 1)
    dag <- generate_erdosrenyi_dag_sink_y(n_nodes, n_expected_neighbors, n_expected_parents_y, 3)

    # pcalg method
    cpdag <- pcalg::dag2cpdag(igraph::igraph.to.graphNEL(dag)) # graph object
    cpdag_adj <- graph::adjacencyMatrix(as(cpdag, "graphBAM")) # to adjacency matrix in form [a,b] = 1 if a->b
    cpdag_adj <- t(cpdag_adj) # transpose such that [b,a] = 1 if a->b (as required by pcalg)

    dags <- pcalg::pdag2allDags(cpdag_adj)
    n_dags_in_cpdag <- nrow(dags$dags)
    dags_cpdag_pcalg <- vector("list", n_dags_in_cpdag)

    if(n_dags_in_cpdag == 1) {
      next
    }

    for (dag_idx in seq(n_dags_in_cpdag)) {
      adj_matrix <- matrix(dags$dags[dag_idx,], length(igraph::V(dag)), length(igraph::V(dag)), byrow=TRUE)
      adj_matrix <- t(adj_matrix)  # amat type from pcalg follows convention: amat[b,a]=1 if a->b, igraph the opposite
      colnames(adj_matrix) <- rownames(adj_matrix) <- dags$nodeNms
      dags_cpdag_pcalg[[dag_idx]] <- adj_matrix
    }

    # our method
    dags_in_cpdag_ours <- enumerate_cpdag(t(cpdag_adj)) # Convert back to [a,b] = 1 if a->b
    expect_equal(length(dags_in_cpdag_ours), n_dags_in_cpdag)
    for (j in seq(n_dags_in_cpdag)) {
      expect_true(any(sapply(dags_in_cpdag_ours, function(x) all(x == dags_cpdag_pcalg[[j]]))))
    }
  }
})

test_that("enumerate outputs does not contain any duplicates", {
  set.seed(123)

  for (i in seq_len(40)) {
    n_expected_neighbors <- sample(1:3, 1)
    n_expected_parents_y <- sample(3:7, 1)
    n_nodes <- sample(7:12, 1)
    dag <- generate_erdosrenyi_dag_sink_y(n_nodes, n_expected_neighbors, n_expected_parents_y, 3)

    # our method
    dags_in_cpdag_ours <- enumerate_cpdag(t(cpdag_adj)) # Convert back to [a,b] = 1 if a->b
    dags_in_cpdag_igraph <- lapply(dags_in_cpdag_ours, function(x) igraph::graph_from_adjacency_matrix(x, mode="directed"))

    for (j in seq(length(dags_in_cpdag_igraph) - 1)) {
      for (k in seq(j+1, length(dags_in_cpdag_igraph))) {
        expect_false(igraph::identical_graphs(dags_in_cpdag_igraph[[j]], dags_in_cpdag_igraph[[k]]))
      }
    }

  }
})


