FS-TFP/benchmark/FedHPOBench/scripts/bert/run_opt_glue.sh

40 lines
1.5 KiB
Bash

# https://huggingface.co/google/bert_uncased_L-2_H-128_A-2
set -e
cudaid=$1
sample_rate=$2
dataset=$3
k=$4
cd ../..
out_dir=out_${dataset}
echo "HPO starts..."
lrs=(0.01 0.01668 0.02783 0.04642 0.07743 0.12915 0.21544 0.35938 0.59948 1.0)
wds=(0.0 0.001 0.01 0.1)
dps=(0.0 0.5)
steps=(1)
batch_sizes=(8 16 32 64 128)
lrs_server=(0.1 0.5 1.0)
momentums_server=(0.0 0.9)
for ((l = 0; l < ${#lrs[@]}; l++)); do
for ((w = 0; w < ${#wds[@]}; w++)); do
for ((d = 0; d < ${#dps[@]}; d++)); do
for ((s = 0; s < ${#steps[@]}; s++)); do
for ((b = 0; b < ${#batch_sizes[@]}; b++)); do
for ((sl = 0; sl < ${#lrs_server[@]}; sl++)); do
for ((ms = 0; ms < ${#momentums_server[@]}; ms++)); do
python main.py --cfg fedhpo/glue/${dataset}.yaml fedopt.use True federate.method FedOpt fedopt.lr_server ${lrs_server[$sl]} fedopt.momentum_server ${momentums_server[$ms]} device $cudaid optimizer.lr ${lrs[$l]} optimizer.weight_decay ${wds[$w]} model.dropout ${dps[$d]} federate.local_update_steps ${steps[$s]} data.batch_size ${batch_sizes[$b]} federate.sample_client_rate $sample_rate seed $k outdir out_fedopt/${out_dir}_${sample_rate} federate.share_local_model False federate.online_aggr False expname lr${lrs[$l]}_wd${wds[$w]}_dropout${dps[$d]}_step${steps[$s]}_batch${batch_sizes[$b]}_lrserver${lrs_server[$sl]}_momentumsserver${momentums_server[$ms]}_seed${k} >/dev/null 2>&1
done
done
done
done
done
done
done
echo "HPO ends."