## Script to generate the DAGs we use for the synthetic data experiments

source('R/scm/graph_functions.R')
source('R/experiments/helper_functions.R')

n_seeds <- 40
seeds <- seq(n_seeds)

# DAGs are determined by (n_nodes, n_expected_neighbors, n_expected_parents_y, min_parents_y, seed)
# Default setting: 10 nodes, 2 neighbors, 6 parents of y (mid), 3 minimum parents of y
# We vary each axis independently, but changing the number of expected parents of Y and the minimum parents of Y to
# be proportional to the number of nodes

combinations <- list(
  c(5, 2, 3, 2),
  c(10, 1, 6, 3),
  c(10, 2, 6, 3), # default setting
  c(10, 3, 6, 3),
  c(10, 2, 3, 3),
  c(10, 2, 9, 3),
  c(15, 2, 9, 5)
)

for (combination in combinations) {
  n_nodes <- combination[1]
  n_nodes <- n_nodes + 1 # add one for the y node
  n_expected_neighbors <- combination[2]
  n_expected_parents_y <- combination[3]
  min_parents_y <- combination[4]
  for (seed in seeds) {
    log_to_shell(paste0('Generating DAG with n_nodes ', n_nodes, ', n_expected_neighbors ', n_expected_neighbors,
                        ', n_expected_parents_y ', n_expected_parents_y, ', min_parents_y ', min_parents_y,
                        ', seed ', seed))
    dag <- generate_erdosrenyi_dag_sink_y(n_nodes, n_expected_neighbors, n_expected_parents_y, min_parents_y, seed)
    log_to_shell('Done generating DAG. Saving...')
    save_dag(dag, n_nodes, min_parents_y, n_expected_neighbors, n_expected_parents_y, seed)
    log_to_shell('Done saving DAG.')
  }
}




