#!/bin/bash

# Load necessary modules

# Change directory to the script location
cd "$HOME/mec_shapley//"

# Generate a timestamp
TIMESTAMP=$(date +"%Y%m%d_%H%M%S")

# Define output log file with timestamp
LOG_FILE="$HOME/mec_shapley/R/experiments/jobs/gaussian/causal_discovery/oracle_$TIMESTAMP.log"

# Path to the combined settings file
MODEL_PATH_FILE="$HOME/mec_shapley/R/experiments/jobs/gaussian/causal_discovery/dag_paths.txt"

# Export the necessary environment variables
export MODEL_PATH_FILE

# Function to process a single line from the MODEL_PATH_FILE
process_line() {
   local line="$1"
    Rscript "$HOME/mec_shapley/R/experiments/causal_discovery_oracle.R" "$line"
}

# Export the function so it can be used by parallel
export -f process_line

# Use GNU Parallel to process each line in parallel with a limit on the number of concurrent jobs
NUM_CONCURRENT_JOBS=20

cat "$MODEL_PATH_FILE" | parallel --jobs $NUM_CONCURRENT_JOBS process_line > "$LOG_FILE" 2>&1