MODEL=${MODEL:-facebook/opt-125m}
MODEL_NAME=(${MODEL//\// })
MODEL_NAME="${MODEL_NAME[@]: -1}"

BS=${BS:-16}
LR=${LR:-1e-6}
EPS=${EPS:-1e-3}
SEED=${SEED:-0}
TRAIN=${TRAIN:-1000}
DEV=${DEV:-500}
EVAL=${EVAL:-1000}
STEPS=${STEPS:-15000}
EVAL_STEPS=${EVAL_STEPS:-15000}
OPT=${OPT:-mezo}
LOW_RANK=${LOW_RANK:-1}
LAZY_UPDATE=${LAZY_UPDATE:-100}
MODE=${MODE:-ft}

MOMENTUM=${MOMENTUM:-False}
ADAM=${ADAM:-False}

EXTRA_ARGS=""

if [ "$MODE" == "prefix" ]; then
    EXTRA_ARGS="--prefix_tuning --num_prefix 5 --no_reparam --prefix_init_by_real_act"
elif [ "$MODE" == "lora" ]; then
    EXTRA_ARGS="--lora"
fi

if [ "$OPT" == "mezo" ]; then
    METHOD_ARGS=""
    TAG=mezo-$MODE-$STEPS-$BS-$LR-$EPS-$SEED
elif [ "$OPT" == "lozo" ]; then
    METHOD_ARGS="--enable_lozo --lozo_rank ${LOW_RANK} --lazy_interval ${LAZY_UPDATE}"
    TAG=lozo-$MODE-$STEPS-$BS-$LR-$EPS-$SEED
elif [ "$OPT" == "tizo" ]; then
    METHOD_ARGS="--enable_tizo --tizo_rank ${LOW_RANK}"
    TAG=tizo-$MODE-$STEPS-$BS-$LR-$EPS-$SEED
elif [ "$OPT" == "subzo" ]; then
    METHOD_ARGS="--enable_subzo --subzo_rank ${LOW_RANK} --lazy_interval ${LAZY_UPDATE}"
    TAG=subzo-$MODE-$STEPS-$BS-$LR-$EPS-$SEED
fi

EXTENSION_ARGS=""
if [ "$MOMENTUM" == "True" ]; then
    EXTENSION_ARGS="--use_momentum"
elif [ "$ADAM" == "True" ]; then
    EXTENSION_ARGS="--use_adam"
fi


TASK_ARGS=""
case $TASK in
    # For Copa, ReCoRD, SQuAD, DROP, we set --train_as_classification False; for others, set this flag to True
    CB) # It has <1000 training examples. Only use 100 for dev
        DEV=100
        ;;
    Copa) # It has <1000 training examples. Only use 100 for dev
        DEV=100
        TASK_ARGS="--train_as_classification False"
        ;;
    ReCoRD) 
        TASK_ARGS="--train_as_classification False"
        ;;
    DROP) 
        TASK_ARGS="--train_as_classification False"
        ;;
    SQuAD)
        TASK_ARGS="--train_as_classification False"
        ;;
esac

echo $TAG
echo "BS: $BS"
echo "LR: $LR"
echo "EPS: $EPS"
echo "SEED: $SEED"
echo "TRAIN/EVAL STEPS: $STEPS/$EVAL_STEPS"
echo "MODE: $MODE"
echo "Extra args: $EXTRA_ARGS $TASK_ARGS"

python run.py \
    --model_name $MODEL \
    --task_name $TASK \
    --output_dir result/$TASK-${MODEL_NAME}-$TAG --tag $TAG --train_set_seed $SEED --num_train $TRAIN --num_dev $DEV --num_eval $EVAL --logging_steps 10 \
    --max_steps $STEPS \
    --trainer zo --load_float16 \
    --learning_rate $LR --zo_eps $EPS --per_device_train_batch_size $BS --lr_scheduler_type "constant" \
    --train_as_classification \
    $EXTRA_ARGS \
    $TASK_ARGS \
    $METHOD_ARGS \
    $EXTENSION_ARGS \
    "$@"
