#! /bin/sh
rootdir="./results"

config="configs/common.yaml"
optim_name="fedproxdowl_init_eta1e-2_init_mu1.0_wd1e-8_warmup0"
optim_config="configs/optimizers/${optim_name}.yaml"

loglevel="INFO"
nduplicate=1

seed=17
data_seed=11

N=7
node_config="configs/nodes/node${N}.yaml"

lrs=(1e-3 )
lr_mins=(1e-3 )
dataset_name="glue"
# full tasks.
tasks=("cola" "sst2" "mrpc" "stsb" "rte" "qqp" "mnli" "qnli")
models=("bert" "bert" "bert" "bert" "bert" "bert" "bert" "bert" )
nsteps=(500 200 200 1000 200 2000 2000 2000)
t_initials=(450 150 150 800 150 1500 1500 1500)
# mid priority tasks.
tasks=("cola" "qqp")
models=("bert" "bert")
nsteps=(500 2000)
t_initials=(450 1500)
# high priority tasks.
tasks=("sst2" "rte")
models=("bert" "bert")
nsteps=(200 200)
t_initials=(150 150)

alphas=(100.0 1.0)
inner_loops=(100)
force_merge_parameter_interval=0
batch_size=32
min_size_rate=0.8

for inner_loop in ${inner_loops[@]}; do
for alpha in ${alphas[@]}; do
for dataset_idx in `seq 0 $((${#tasks[@]}-1))`; do
for lr_idx in `seq 0 $((${#lrs[@]}-1))`; do

nstep=${nsteps[dataset_idx]}
t_initial=${t_initials[dataset_idx]}

task=${tasks[dataset_idx]}
dataset="${dataset_name}-${task}"
model=${models[dataset_idx]}
lr=${lrs[lr_idx]}
lr_min=${lr_mins[lr_idx]}
model_config="configs/models/${model}_${dataset}.yaml"
if [ ${task} == "sst2" ]; then
  train_config="configs/trains/${dataset_name}_${task}_dog.yaml"
elif [ ${task} == "stsb" ]; then
  train_config="configs/trains/${dataset_name}_${task}_dog.yaml"
else
  train_config="configs/trains/${dataset_name}_dog.yaml"
fi

if [ ${inner_loop} -eq 100 ]; then
  outer_loop=1
elif [ ${inner_loop} -eq 10 ]; then
  outer_loop=10
elif [ ${inner_loop} -eq 1 ]; then
  outer_loop=100
fi

if [ ${alpha} == "even" ]; then
  dataset_config="configs/datasets/${dataset}_even.yaml"
  outdir="${rootdir}/n${N}_${model}_${dataset}_ds${data_seed}_b${batch_size}_even_${optim_name}_lr${lr}-${lr_min}_s${nstep}-${outer_loop}-${inner_loop}"
else
  dataset_config="configs/datasets/${dataset}_dirichlet_alpha${alpha}_min_size_rate${min_size_rate}_label_sort.yaml"
  outdir="${rootdir}/n${N}_${model}_${dataset}_ds${data_seed}_b${batch_size}_alpha${alpha}_${optim_name}_lr${lr}-${lr_min}_s${nstep}-${outer_loop}-${inner_loop}"
fi
bash ~/proxy.sh
python main.py ${outdir} ${config} ${node_config} ${dataset_config} ${model_config} ${optim_config} ${train_config} \
  --nstep ${nstep} --nouter ${outer_loop} --ninner ${inner_loop} --batch_size ${batch_size} \
  --lr ${lr} --lr_min ${lr_min} --seed ${seed} --data_seed ${data_seed} --data_nduplicate ${nduplicate} \
  --t_initial ${t_initial} \
  --logfile ${outdir}/stdout.txt --loglevel ${loglevel} --quiet 

done
done
done
done



