#!/bin/bash
gpu_list="0"  # GPUs to use for parallel execution

# ================================ SPACO ================================
# Generate all tasks
beta_grid=(2.0 3.0 4.0 5.0)
rho0_grid=(10.0 20.0 30.0 50.0)

log_dir="results/celeba_spaco_pareto"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running SPACO with beta in ${beta_grid[*]} and rho0 in ${rho0_grid[*]}"
for beta in ${beta_grid[@]}; do
    for rho0 in ${rho0_grid[@]}; do
        log_file="${log_dir}/beta_${beta}_rho0_${rho0}.log"
        task_cmd="echo \"Running SPACO with beta=${beta} and rho0=${rho0}\" >> ${log_file} 2>&1 && make spaco EXTRA_CONFIG=\"beta=${beta} penalty_rho0=${rho0}\" GPU=\"\${GPU}\" >> ${log_file} 2>&1"
        echo "$task_cmd" >> "$tasks_file"
    done
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"

# ================================ EG ================================
# Generate all tasks
beta_grid=(1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0)

log_dir="results/celeba_eg_pareto"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running EG with beta in ${beta_grid[*]}"
for beta in ${beta_grid[@]}; do
    log_file="${log_dir}/beta_${beta}.log"
    task_cmd="echo \"Running EG with beta=${beta}\" >> ${log_file} 2>&1 && make eg EXTRA_CONFIG=\"beta=${beta}\" 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 ================================
# Generate all tasks
adv_loss_weight_grid=(0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9)

log_dir="results/celeba_adv_debias_pareto"
tasks_file="${log_dir}_tasks.txt"
mkdir -p "$log_dir"

# Generate task list
> "$tasks_file"
echo "Running ADV_DEBIAS with adv_loss_weight in ${adv_loss_weight_grid[*]}"
for adv_loss_weight in ${adv_loss_weight_grid[@]}; do
    log_file="${log_dir}/adv_loss_weight_${adv_loss_weight}.log"
    task_cmd="echo \"Running ADV_DEBIAS with adv_loss_weight=${adv_loss_weight}\" >> ${log_file} 2>&1 && make adv_debias EXTRA_CONFIG=\"adv_loss_weight=${adv_loss_weight}\" 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"
