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


n_nodes <- 16
n_neighbors <- 2
n_parents_y <- 9
nmc_causal_true <- 4000
nmc <- 1000
nobs <- 1000
ncombs <- 4096
ncombs_causal_true <- 8192

time <- "2:00:00"
time_mec <- "24:00:00"
time_causal_true <- "24:00:00"

nbatches <- 2048


model_path_file <- "gaussian/15_nodes/paths_dags.txt"
cpdag_path_file <- "gaussian/15_nodes/paths_cpdags.txt"

job_base_dir <- "R/experiments/jobs/gaussian/15_nodes/"

job_pattern <- "16_gauss_%s_%s"


job_name <- sprintf(job_pattern, ncombs_causal_true, "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(job_name, "shapley_causal_true_parallel.R",
  model_path_file = model_path_file,
  nmc = nmc_causal_true, nobs = nobs,
  ncomb = ncombs_causal_true,
  nbatches = nbatches * 2,
  time = time_causal_true,
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)


job_name <- sprintf(job_pattern, ncombs, "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(job_name, "shapley_marginal_parallel.R",
  model_path_file = model_path_file,
  nmc = nmc, nobs = nobs,
  ncomb = ncombs,
  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, ncombs, "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(job_name, "shapley_conditional_parallel.R",
  model_path_file = model_path_file,
  nmc = nmc, nobs = nobs,
  ncomb = ncombs,
  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, ncombs, "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-120%8"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)

job_name <- sprintf(job_pattern, ncombs, "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-120%8"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)

