datasets=( "cifar100")      # cifar10 cifar100 svhn
split_types=("dir_0.1")     # "dir_0.1" "dir_0.3"
num_labels=(10)             # CIFAR100: 10 or 25, CIFAR-10/SVHN: 25 40, used in experiments
num_seen_classes=(80)       # CIFAR100: 80 or 50, CIFAR-10/SVHN: 6, used in experiments
seeds=(0)
algorithms=(
    "alone_os"
    "fedlabel"
    "semifl"
    "fl2"
    "openmatch"
    "iomatch"
    "bdmatch"
    "ssb"
    "fedopenmatch"
)  

available_gpus=(0 1 2 3 4 5 6 7) 
num_clients=100             ## 50 for CIFAR100 with 50 seen classes
join_ratio=0.1              ## 0.2 for CIFAR100 with 50 seen classes
c_batch_size=32
global_rounds=600
p_cutoff_neg=0.1            ## 0.01 For CIFAR-10
tau=1                       ## imbalance margin
cr_weight=1                 ## logit consistency
dsp='baseline'
data_dir="./data" 
declare -A pid_to gpu

for dataset in "${datasets[@]}"; do
    for seed in "${seeds[@]}"; do
        for split_type in "${split_types[@]}"; do
            for num_label in "${num_labels[@]}"; do
                for num_seen_class in "${num_seen_classes[@]}"; do
                    for algorithm in "${algorithms[@]}"; do

                        while [[ ${#available_gpus[@]} -eq 0 ]]; do
                            wait -n
                            running_pid=$(jobs -p)

                            for key in "${!pid_to_gpu[@]}"; do
                                if [[ ${running_pid[@]/${key}/} == ${running_pid[@]} ]]; then
                                    gpu=${pid_to_gpu[$key]}
                                    available_gpus+=("$gpu")
                                    unset pid_to_gpu[$key]
                                    break
                                fi
                            done
                        done

                        next_gpu="${available_gpus[0]}"
                        available_gpus=("${available_gpus[@]:1}")
                        python main.py --algorithm $algorithm --dataset $dataset --num_seen_class $num_seen_class --data_dir $data_dir \
                                        --split_type $split_type --num_labels $num_label --visible_gpu $next_gpu --seed $seed \
                                        --global_rounds $global_rounds --close_train False --close_test False --dsp $dsp \
                                        --num_clients $num_clients --join_ratio $join_ratio --c_batch_size $c_batch_size \
                                        --tau $tau --cr_weight $cr_weight --p_cutoff_neg $p_cutoff_neg &
                        current_pid=$!
                        pid_to_gpu["$current_pid"]="$next_gpu"
                        echo "pid_to_gpu: ${!pid_to_gpu[@]}"
                        echo "pid_to_gpu: ${pid_to_gpu[@]}"
                        sleep 20
                    done
                done
            done
        done
    done
done

