source("R/experiments/jobs/create_slurm_job.R")


n_nodes <- 11
n_neighbors <- 2
n_parents_y <- 6
nmc <- 1000
nobs <- c(250, 500, 2000, 4000)
ncombs <- 1024
ncomb <- 1024

nbatches <- 64
ntoexplain <- 40

time <- "2:00:00"
time_mec <- "12:00:00"

model_path_file <- "gaussian/nobs/paths_dags.txt"
cpdag_path_file <- "gaussian/nobs/paths_cpdags.txt"

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

job_pattern <- "nobs_gauss_%s"

job_name <- sprintf(job_pattern, "marginal")
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_variable(job_name, "shapley_marginal_parallel.R",
  model_path_file = model_path_file,
  nmc = nmc, nobs = nobs,
  ncomb = ncomb,
  nbatches = nbatches,
  time = time
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)


job_name <- sprintf(job_pattern, "conditional")
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_variable(job_name, "shapley_conditional_parallel.R",
  model_path_file = model_path_file,
  nmc = nmc, nobs = nobs,
  ncomb = ncomb,
  nbatches = nbatches,
  time = time
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)


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_variable(job_name, "shapley_mec_parallel.R",
  cpdag_path_file = cpdag_path_file,
  method = "sample",
  nmc = nmc, nobs = nobs,
  ncomb = ncomb,
  nbatches = nbatches,
  time = time_mec,
  array = "1-120%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_variable(job_name, "shapley_mec_parallel.R",
  cpdag_path_file = cpdag_path_file,
  method = "iw",
  nmc = nmc, nobs = nobs,
  ncomb = ncomb,
  nbatches = nbatches,
  time = time_mec,
  array = "1-120%40"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)
