# Function to generate a Slurm job script with variable parameters
source("R/experiments/jobs/create_slurm_job.R")


n_nodes <- 11
n_neighbors <- 2
n_parents_y <- 6
nmc <- 1000
nobs <- 1000
ncombs <- 1024

time_mec <- "12:00:00"

nbatches <- 64

cpdag_path_file <- "gaussian/ncd/paths_cpdags.txt"

job_base_dir <- "R/experiments/jobs/gaussian/ncd/"

job_pattern <- "ncd_gauss_%s"

job_name <- sprintf(job_pattern,  "mec_sample")
job_file_dir <- paste0(job_base_dir, job_name, ".sh")
job_file_conn <- file(paste0(job_base_dir, job_name, ".sh"), open = "w")
job_lines <- generate_slurm_job(job_name, "shapley_mec_parallel.R",
  cpdag_path_file = cpdag_path_file,
  method = "sample",
  nmc = nmc, nobs = nobs,
  ncomb = ncombs,
  nbatches = nbatches,
  time = time_mec,
  array = "1-320%40"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)

job_name <- sprintf(job_pattern,  "mec_iw")
job_file_dir <- paste0(job_base_dir, job_name, ".sh")
job_file_conn <- file(paste0(job_base_dir, job_name, ".sh"), open = "w")
job_lines <- generate_slurm_job(job_name, "shapley_mec_parallel.R",
  cpdag_path_file = cpdag_path_file,
  method = "iw",
  nmc = nmc, nobs = nobs,
  ncomb = ncombs,
  nbatches = nbatches,
  time = time_mec,
  array = "1-320%40"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)
