#!/user/bin/bash
set -uo pipefail
trap 'echo "SIGINT/SIGTERM received, killing all children"; pkill -P $$; exit 1' SIGINT SIGTERM

#shell 参数解析
if [ $# -lt 3 ]; then
  echo "用法: $0 <architecture>(MLP) <dataset> <device>(cuda:) [其他参数...]"
  exit 1
fi

ARCH="$1"
DATASET="$2"
DEVICE="$3"

logdir="../train100/logs/${ARCH}/${DATASET}"
mkdir -p "${logdir}"


(
logfile="${logdir}/sparse.log"
echo "${ARCH} ${DATASET} sparse input training start"
python -u run_diego.py \
    --network_structure "$ARCH" \
    --dataset "$DATASET" \
    --cuda_device "$DEVICE"\
    --learning_rate 0.025 \
    --batch_size 32\
    --epochs 100 \
    --linearlr \
    --sparsity 0.99 \
    --update_interval 1\
    --zeta 0.3 \
    --decay_factor 0.9 \
    --adaptive_zeta \
    --init_mode "swi" \
    --self_correlated_sparse \
    --chain_removal \
    --start_T 1.0 \
    --end_T 3.0 \
    --function linear \
    --sparsity_distribution uniform \
    --remove_method weight_magnitude_soft \
    --regrow_method CH2_L3n_soft \
    --itop \
    --T_decay no_decay \
    --record_anp \
    --dst_scheduler \
    > "${logfile}" 2>&1 
echo "${ARCH} ${DATASET} sparse input training finish"
)&


(
logfile="${logdir}/dense.log"
echo "${ARCH} ${DATASET} dense input training start"
python -u run_diego.py \
    --network_structure "$ARCH" \
    --dataset "$DATASET" \
    --cuda_device "$DEVICE" \
    --learning_rate 0.025 \
    --batch_size 32\
    --epochs 100 \
    --linearlr \
    --sparsity 0.0 \
    --update_interval 1\
    --zeta 0.3 \
    --decay_factor 0.9 \
    --adaptive_zeta \
    --init_mode "swi" \
    --self_correlated_sparse \
    --chain_removal \
    --start_T 1.0 \
    --end_T 3.0 \
    --function linear \
    --sparsity_distribution uniform \
    --remove_method FC \
    --regrow_method fc \
    --T_decay no_decay \
    > "${logfile}" 2>&1 
echo "${ARCH} ${DATASET} dense input training finish"
)&


wait
echo 'ALL job finished'

