set -e cudaid=$1 sample_rate=$2 cd ../.. dataset=cifar10 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 2 3 4) batch_sizes=(16 32 64) 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 k in {1..3}; do python federatedscope/main.py --cfg fedhpo/cnn/${dataset}.yaml 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_dir}_${sample_rate} expname lr${lrs[$l]}_wd${wds[$w]}_dropout${dps[$d]}_step${steps[$s]}_batch${batch_sizes[$b]}_seed${k} >/dev/null 2>&1 done done done done done done echo "HPO ends."