#!/bin/bash

MODEL="ResNet18"
DATASET="CIFAR10"
SELECTION="Uncertainty"
UNCERTAINTY="Entropy"
ACCUMULATE="True"
BALANCE="False"

NUM_EXP=5  # Number of random trials

LR=0.1
EPOCHS=200
BATCH=128
WDECAY=0.0005
OPTIMIZER="SGD"
SCHEDULER="CosineAnnealingLR"
UNLEARN="True"
REG_GAMMA=0.01
UNLEARN_SMOOTH=0.9
ADAPTSIZE="True"
PREFIX_SIZE="True"
ONLYCORRECT="True"

EVAL_PURIF="False"

# Fraction of extracted data into the subset
FRACTION=0.5

SE_REPEATS=1
SE_EPOCHS=50
SE_WARMUP=10
SE_BATCH=128
SE_LR=0.001
SE_WD=0.00005
SE_MOMENTUM=0.9
SE_OPTIM="Adam"
SE_AUG="False"
SE_SNORM="True"

SE_SAVESET="False"

# Backdoor attack
TARGET=0
DEFAULT_PRATE=0.05

TRIGGERS="blendTrigger badnetsTrigger wanetTrigger"

NOTE="SE${SE_EPOCHS}_LR${SE_LR}_${SE_OPTIM}_Re${SE_REPEATS}"

if test "$BALANCE" == "True"
then
  NOTE="${NOTE}_Balance"
fi

if test "$SE_AUG" == "True"
then
  NOTE="${NOTE}_SEAug"
fi

OUTPUT_LOG=./${DATASET}_${MODEL}_${SELECTION}

if (test "$SELECTION" == "Uncertainty")
then

  if (test "$ACCUMULATE" == "True")
  then
    OUTPUT_LOG="${OUTPUT_LOG}_Cumulative_${UNCERTAINTY}"

    if test "$ONLYCORRECT" == "True"
    then
      NOTE="${NOTE}_OnlyCorr"
    fi

    if test "$UNLEARN" == "True"
    then
      NOTE="${NOTE}_UL_${REG_GAMMA}_LS_${UNLEARN_SMOOTH}"
    fi

    if [[ ${SE_WARMUP} -gt 0 ]];
    then
      NOTE="${NOTE}_WarmUp${SE_WARMUP}"
    fi

    if test "$SE_SNORM" == "True"
    then
      NOTE="${NOTE}_SNorm"
    fi
  fi
fi

if test "$ADAPTSIZE" == "True"
then
  OUTPUT_LOG=${OUTPUT_LOG}_FracAdapt
else
  OUTPUT_LOG=${OUTPUT_LOG}_Frac${FRACTION}
fi

if [[ ${NUM_EXP} -gt 1 ]];
then
  NOTE="${NOTE}_RunExp${NUM_EXP}"
fi

echo "Start in $SECONDS seconds"

for TRIGGER in $TRIGGERS
do
  echo "Running experiments for ${NUM_EXP} runs: ${DATASET} under ${TRIGGER} attack with ${MODEL}"

  PRATE=$DEFAULT_PRATE
  echo "Default poisoning rate = $DEFAULT_PRATE"

  echo "Running method ${SELECTION}-${UNCERTAINTY}"
  CUDA_VISIBLE_DEVICES=0 python -u main.py \
    --fraction ${FRACTION} \
    --dataset ${DATASET} \
    --data_path /share/${DATASET} \
    --num_exp ${NUM_EXP} \
    --workers 1 \
    --optimizer ${OPTIMIZER} \
    --lr ${LR} \
    --scheduler ${SCHEDULER} \
    -wd ${WDECAY} \
    -re ${SE_REPEATS} \
    -se ${SE_EPOCHS} \
    -sb ${SE_BATCH} \
    -warmup ${SE_WARMUP} \
    --selection ${SELECTION} \
    --model ${MODEL} \
    --lr ${LR} \
    --epochs ${EPOCHS} \
    --unlearn ${UNLEARN} \
    --unlearn_smooth ${UNLEARN_SMOOTH} \
    --reg_gamma ${REG_GAMMA} \
    --accumulative ${ACCUMULATE} \
    --adaptsize ${ADAPTSIZE} \
    --prefix_coresize ${PREFIX_SIZE} \
    --correct_only ${ONLYCORRECT} \
    --save_coreset ${SE_SAVESET} \
    -evlpur ${EVAL_PURIF} \
    -slr ${SE_LR} \
    -so ${SE_OPTIM} \
    -swd ${SE_WD} \
    -sm ${SE_MOMENTUM} \
    -ns ${SE_SNORM} \
    -saug ${SE_AUG} \
    -sp ./result \
    --batch ${BATCH} \
    --uncertainty ${UNCERTAINTY} \
    --balance ${BALANCE} \
    --trigger_type ${TRIGGER} \
    --target_label ${TARGET} \
    --inject_portion ${PRATE} \
    | tee ${OUTPUT_LOG}_${TRIGGER}_${TARGET}_${PRATE}_${NOTE}.log
done

echo "Completed in $SECONDS seconds"