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

config="configs/common.yaml"
optim_name="fedavg"
optim_config="configs/optimizers/${optim_name}.yaml"

loglevel="INFO"
nduplicate=1

seed=17
data_seed=11
master_port=29504

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

lrs=(1e-2 1e-1 1e-3)
lr_mins=(1e-3 1e-2 1e-4)
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)
# low priority tasks.
tasks=("mrpc" "stsb" "mnli" "qnli")
models=("bert" "bert" "bert" "bert")
nsteps=(200 1000 2000 2000)
t_initials=(150 800 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)
# cola: 500
# sst2: 200
# mrpc: 200
# stsb: 1000
# rte: 200
# qqp: 2000
# mnli: 2000
# qnli: 2000
# wnli: no

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 lr_idx in `seq 0 $((${#lrs[@]}-1))`; do
for dataset_idx in `seq 0 $((${#tasks[@]}-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"
train_config="configs/trains/${dataset_name}.yaml"

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}.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
