# Create the output CSV and append header info


cleanup() {
    echo "Terminating all running jobs..."
    kill $(jobs -p) 2>/dev/null
    exit 1
}

# Trap SIGINT (Ctrl+C) and call cleanup function
trap 'cleanup' SIGINT

makeheader=True 
# Maximum number of parallel jobs
max_parallel=10
# Function to wait if maximum parallel jobs are running
wait_for_jobs() {
    while [[ $(jobs -r | wc -l) -ge $max_parallel ]]; do
        sleep 1  # Wait for 1 second before checking again
    done
}

for setting in  "interventional"  "demographic" "observational" 
do
    if $makeheader; then    
        echo "# Date: $(date)" > "results/synthetic/$setting-effect-size.csv"
        echo "# Commit-Hash: $(git rev-parse HEAD)" >> "results/synthetic/$setting-effect-size.csv"
        echo "Method;n;d;tau;F1;F1-STD;Accuracy;Accuracy-STD;Purity;Purity-STD;Runtime;Runtime-STD;Precision;Precision-STD;Recall;Recall-STD" >> "results/synthetic/$setting-effect-size.csv"
    fi
    for tau in 1.5 2 2.5 3 3.5 4
    do
        for method in subcon  causaltree pysubgroup syflow honesttree
        do
            python run_synth.py --method $method --outpath "results/synthetic/$setting-effect-size.csv" --setting "$setting" --tau $tau &
            wait_for_jobs  # Wait if maximum parallel jobs are running
        done
    done
done

wait # Wait for all remaining jobs
exit 0

