cleanup() {
    echo "Terminating all running jobs..."
    kill $(jobs -p) 2>/dev/null
    exit 1
}
max_parallel=1
wait_for_jobs() {
    while [[ $(jobs -r | wc -l) -ge $max_parallel ]]; do
        sleep 1  # Wait for 1 second before checking again
    done
}
# Trap SIGINT (Ctrl+C) and call cleanup function
trap 'cleanup' SIGINT


for method in syflow # causaltree pysubgroup honesttree # syflow subcon causaltree pysubgroup honesttree
do
    for setting in "interventional" "observational" "demographic" 
    do
        if [ $method == "syflow" ]; then
            config_range=3*3*3
        elif [ $method == "subcon" ]; then
            config_range=2*2*2*3
        elif [ $method == "causaltree" ]; then
            config_range=5*4
        elif [ $method == "pysubgroup" ]; then
            config_range=3*3*3
        elif [ $method == "honesttree" ]; then
            config_range=5*4
        fi
        echo "ConfigID;n;d;tau;f1;f1_std;accuracy;accuracy_std;purity;purity_std;runtime;runtime_std;precision;precision_std;recall;recall_std" > "hyperparameters/$method-$setting.csv"
        echo "Best config: 0.0" > "hyperparameters/best_params/$method-$setting.txt"

        for config_id in $(seq 0 $((config_range - 1)))
        do
            python run_hyperparameter_opt.py --method $method --config_id $config_id --setting $setting --tau 4 &
            wait_for_jobs  # Wait if maximum parallel jobs are running
        done
    done
done
wait
exit 0