#!/bin/bash

SEEDS=(1234 5073 7762)
PROVS=("dtkp5")

declare -A PROV_MAP=(
  ["damp"]="diffaddmultprob"
  ["dtkp1"]="difftopkproofs"
  ["dtkp3"]="difftopkproofs"
  ["dtkp5"]="difftopkproofs"
)

declare -A K_MAP=(
  ["damp"]=5
  ["dtkp1"]=1
  ["dtkp3"]=3
  ["dtkp5"]=5
)

n=${#SEEDS[@]}

for PROV in "${PROVS[@]}"; do
    prov=${PROV_MAP[$PROV]}
    k=${K_MAP[$PROV]}
    gpu_count=0
    flag=true

    while $flag ; do
        pids=()

        for gpu in "$@"; do
            if ((gpu_count >= n)) ; then
                flag=false
                break
            fi
            seed=${SEEDS[$gpu_count]}
            gpu_count=$((gpu_count + 1))
            export CUDA_VISIBLE_DEVICES=$gpu
            nohup python run_scallop.py --phase="train" --train_size=1000 --provenance=$prov --train_top_k=$k --seed=$seed --epochs=1000 --use_cuda --save_name="${PROV}_seed[${seed}]" > /dev/null 2>&1 &
            pids+=($!)
        done

        for pid in "${pids[@]}"; do
            wait $pid
        done
    done
done