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


n_nodes <- 6
n_neighbors <- 2
n_parents_y <- 3
nmc_causal_true <- 4000
nmc <- 1000
nobs <- 1000
ncombs <- 32
ncombs_causal_true <- 32

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

nbatches <- 8

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

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

job_pattern <- "6_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(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,
  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, "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,  "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,  "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,
  array = "1-120"
)
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-120%10"
)
lapply(job_lines, writeLines, con = job_file_conn)
close(job_file_conn)
print(job_file_dir)
