generate_local_script <- function(job_name, shapley_file, model_path_file = NULL, cpdag_path_file = NULL, method = NULL, 
                                  ncomb=NULL, nmc=1024, nobs=1024, nbatches=64, n_lines = 40) {
  if (!is.null(model_path_file) && !is.null(cpdag_path_file)) {
    stop("Only one of model_path_file and cpdag_path_file can be specified.")
  }

  if (grepl("mec", shapley_file) && is.null(cpdag_path_file)) {
    stop("MEC requires a cpdag_path_file.")
  }

  if (grepl("mec", shapley_file) && is.null(method)) {
    stop("MEC requires a method.")
  }

  if (!is.null(model_path_file) && grepl("R/experiments", model_path_file)) {
    stop("model_path_file should be relative to the jobs folder.")   
  }
  if (!is.null(cpdag_path_file) && grepl("R/experiments", cpdag_path_file)) {
    stop("cpdag_path_file should be relative to the jobs folder.")   
  }

  lines <- list()

  lines <- append(lines, "#!/bin/bash\n")
  
  # Job name
  lines <- append(lines, paste0("job_name=\"", job_name, "\""))

  # Define base directory
  lines <- append(lines, "base_dir=\"$HOME/mec_shapley\"")

  # Define relative paths
  lines <- append(lines, "input_dir=\"R/experiments/jobs/\"")
  lines <- append(lines, "output_dir=\"logs\"")
  lines <- append(lines, "script_dir=\"R/experiments\"")
  
  # Model path setup
  lines <- append(lines, "# Path to your combined settings file")
  if (!is.null(model_path_file)) {
    lines <- append(lines, paste0("MODEL_PATH_FILE=\"$base_dir/R/experiments/jobs/", model_path_file, "\"\n"))
  } else if (!is.null(cpdag_path_file)) {
    lines <- append(lines, paste0("MODEL_PATH_FILE=\"$base_dir/R/experiments/jobs/", cpdag_path_file, "\"\n"))
  }
  
  # Change to the base directory
  lines <- append(lines, "cd $base_dir")

  # Create output directory if it doesn't exist
  lines <- append(lines, "mkdir -p $output_dir")

  # Loop through each task sequentially
  lines <- append(lines, paste0("for task_id in {1..", n_lines, "}; do"))
  lines <- append(lines, "  model_path=$(sed -n \"${task_id}p\" $MODEL_PATH_FILE)")
  lines <- append(lines, "  timestamp=$(date +\"%Y%m%d_%H%M%S\")")
  
  rscript_line <- paste0("  Rscript ${script_dir}/", shapley_file)
  if (!is.null(model_path_file)) {
    rscript_line <- paste0(rscript_line, " --modelpath $model_path")
  } else if (!is.null(cpdag_path_file)) {
    rscript_line <- paste0(rscript_line, " --cpdagpath $model_path")
  }
  rscript_line <- paste0(rscript_line, " --ntoexplain 40 ")
  rscript_line <- paste0(rscript_line, " --nmc ", nmc, " --nobs ", nobs)
  if (!is.null(ncomb)) {
    rscript_line <- paste0(rscript_line, " --ncomb ", ncomb)
  }
  rscript_line <- paste0(rscript_line, " --nbatches ", nbatches)

  if (!is.null(method)) {
    rscript_line <- paste0(rscript_line, " --method ", method)
  }

  rscript_line <- paste0(rscript_line, " > ${output_dir}/${job_name}_${task_id}_${timestamp}.out 2>&1")

  
  lines <- append(lines, rscript_line)
  lines <- append(lines, "done")

  return(lines)
}
