#!/bin/bash
gpu_list="0"  # GPUs to use for parallel execution
seeds=(0 1 2)

# =============================== No DEBIAS ================================
log_dir="results/repeat_run/celeba_no_debias"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running No DEBIAS with seeds ${seeds[*]}"
for seed in ${seeds[@]}; do
    log_file="${log_dir}/no_debias_seed_${seed}.log"
    task_cmd="echo \"Running No DEBIAS with seed=${seed}\" >> ${log_file} 2>&1 && make no_debias EXTRA_CONFIG=\"seed=${seed}\" GPU=\"\${GPU}\" >> ${log_file} 2>&1"
    echo "$task_cmd" >> "$tasks_file"
done

# Call gpu_scheduler.sh once with all tasks
echo "Total tasks: $(wc -l < "$tasks_file")"
echo "Starting gpu_scheduler.sh with GPUs: $gpu_list"
bash gpu_scheduler.sh "$gpu_list" "$tasks_file"

# =============================== SPACO ================================
log_dir="results/repeat_run/celeba_spaco"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running SPACO with seeds ${seeds[*]}"
for seed in ${seeds[@]}; do
    log_file="${log_dir}/spaco_seed_${seed}.log"
    task_cmd="echo \"Running SPACO with seed=${seed}\" >> ${log_file} 2>&1 && make spaco EXTRA_CONFIG=\"seed=${seed}\" GPU=\"\${GPU}\" >> ${log_file} 2>&1"
    echo "$task_cmd" >> "$tasks_file"
done

# Call gpu_scheduler.sh once with all tasks
echo "Total tasks: $(wc -l < "$tasks_file")"
echo "Starting gpu_scheduler.sh with GPUs: $gpu_list"
bash gpu_scheduler.sh "$gpu_list" "$tasks_file"

# =============================== ADV_DEBIAS ================================
log_dir="results/repeat_run/celeba_adv_debias"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running ADV_DEBIAS with seeds ${seeds[*]}"
for seed in ${seeds[@]}; do
    log_file="${log_dir}/adv_debias_seed_${seed}.log"
    task_cmd="echo \"Running ADV_DEBIAS with seed=${seed}\" >> ${log_file} 2>&1 && make adv_debias EXTRA_CONFIG=\"seed=${seed}\" GPU=\"\${GPU}\" >> ${log_file} 2>&1"
    echo "$task_cmd" >> "$tasks_file"
done

# Call gpu_scheduler.sh once with all tasks
echo "Total tasks: $(wc -l < "$tasks_file")"
echo "Starting gpu_scheduler.sh with GPUs: $gpu_list"
bash gpu_scheduler.sh "$gpu_list" "$tasks_file"
