DATA_PATH=./data-bin/iwslt14.tokenized.de-en.joined.bpe
model=transformer
PROBLEM=iwslt14_de_en
ARCH=transformer_iwslt_de_en
OUTPUT_PATH=log/agd
NUM=5
mkdir -p $OUTPUT_PATH

# remove share all embeddings
export CUDA_VISIBLE_DEVICES=$1; \
    fairseq-train ${DATA_PATH} \
    --seed 1 \
    --arch ${ARCH} \
    --user-dir optim/ \
    --optimizer agd --agd-betas '(0.9, 0.98)' --clip-norm 0.0 \
    --agd-delta 1e-14 \
    --share-all-embeddings \
    --dropout 0.3 --attention-dropout 0.1 --relu-dropout 0.1 \
    --criterion label_smoothed_cross_entropy \
    --lr-scheduler inverse_sqrt --warmup-init-lr 1e-7 --warmup-updates 8000 \
    --lr 0.00005 --min-lr 1e-9 \
    --label-smoothing 0.1 --weight-decay 0.0001 \
    --max-tokens 4096 --save-dir ${OUTPUT_PATH} \
    --update-freq 1 --no-progress-bar --log-interval 50 \
    --ddp-backend no_c10d \
    --keep-last-epochs ${NUM} --max-epoch 55 \
    --restore-file ${OUTPUT_PATH}/checkpoint_best.pt \
    | tee -a ${OUTPUT_PATH}/train_log.txt

# --early-stop ${NUM} \

python scripts/average_checkpoints.py --inputs ${OUTPUT_PATH} --num-epoch-checkpoints ${NUM} --output ${OUTPUT_PATH}/averaged_model.pt

BEAM_SIZE=5
LPEN=1.0
TRANS_PATH=${OUTPUT_PATH}/trans
RESULT_PATH=${TRANS_PATH}/

mkdir -p $RESULT_PATH
CKPT=averaged_model.pt

export CUDA_VISIBLE_DEVICES=$1; \
    fairseq-generate \
    ${DATA_PATH} \
    --path ${OUTPUT_PATH}/${CKPT} \
    --user-dir optim/ \
    --batch-size 128 \
    --beam ${BEAM_SIZE} \
    --lenpen ${LPEN} \
    --remove-bpe \
    --log-format simple \
    --source-lang de \
    --target-lang en \
> ${RESULT_PATH}/res.txt
