retrieve_explanations <- function(dir, seed, explanation_type,
                                 n_observation, n_samples_expectation, n_combinations, n_to_explain,
                                 n_batches = NULL, use_first_one = TRUE, return_shapley_values = FALSE) {
  # Filter filename using regex
  if (length(n_observation) > 1) {
    n_observation <- paste0("(", paste0(n_observation, collapse = "|"), ")")
  }
  if (length(n_samples_expectation) > 1) {
    n_samples_expectation <- paste0("(", paste0(n_samples_expectation, collapse = "|"), ")")
  }
  if (length(n_combinations) > 1) {
    n_combinations <- paste0("(", paste0(n_combinations, collapse = "|"), ")")
  } else if (length(n_combinations) == 0) {
    n_combinations <- "[0-9]*"
  }

  filter <- paste0("^", seed, "_",
                explanation_type, "_",
                n_observation, "O_",
                n_samples_expectation, "E_",
                n_combinations, "C_")
  if (!is.null(n_batches)) {
    filter <- paste0(filter, n_batches, "B_")
  } else {
    filter <- paste0(filter, "[0-9]*B_")
  }

  filter <- paste0(filter, n_to_explain, "S")

  files <- list.files(dir, pattern = filter)
  if (length(files) == 0) {
    return(NULL)
  }
  if (use_first_one) {
     if (return_shapley_values) {
        return(readRDS(file.path(dir, files[1]))$shapley_values)
    } else {
        return(files[[1]])
    }
  } else {
    if (return_shapley_values) {
        return(lapply(files, function(file) readRDS(file.path(dir, file))$shapley_values))
    } else {
        return(files)
    }
  }
}