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


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

nbatches <- 64
ntoexplain <- 40

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

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

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

job_pattern <- "nmc_gauss_%s"


job_name <- sprintf(job_pattern, "causal_true")
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_causal_true_parallel.R",
  model_path_file = model_path_file,
  nmc = c(250, 500, 1000, 2000), nobs = nobs,
  ncomb = ncomb,
  nbatches = nbatches,
  time = time_mec
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)


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)

# iw not affected by nmc
# 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 = "5:00:00",
#   array = "1-120"
# )
# lapply(job_lines, writeLines, con = job_file_conn)
# close(job_file_conn)
# print(job_file_dir)
