export CUDA_VISIBLE_DEVICES=0
export HF_ALLOW_CODE_EVAL=1
export PATH_TO_BASELINE_DATASET = ???
export PATH_TO_EDITSEQ_DATASET = ???
export PATH_TO_PRETRAINED_MODEL_WEIGHTS = ???
export PATH_TO_PRETRAINED_MODEL_TOKENIZER = ???

NUM_GPUS=1
BATCH_SIZE_PER_GPU=16
TOTAL_BATCH_SIZE=512
GRADIENT_ACC_STEPS=$(($TOTAL_BATCH_SIZE/$NUM_GPUS/$BATCH_SIZE_PER_GPU))

TOTAL_EPOCHS=10
NUM_EDIT_SEQS_PER_EXAMPLE=5
TOTAL_EDITSEQ_EPOCHS=$(($TOTAL_EPOCHS/$NUM_EDIT_SEQS_PER_EXAMPLE))

accelerate launch \
    --mixed_precision bf16 \
    --num_machines 1 \
    --num_processes $NUM_GPUS \
    --use_deepspeed \
    --main_process_port 29500 \
    --deepspeed_config_file configs/ds_configs/stage3_no_offloading_accelerate.conf \
    finetune.py \
    --use_flash_attn \
    --model_name_or_path $PATH_TO_PRETRAINED_MODEL_WEIGHTS \
    --tokenizer_name $PATH_TO_PRETRAINED_MODEL_TOKENIZER \
    --train_file $PATH_TO_EDITSEQ_DATASET \
    --max_seq_length 1024 \
    --preprocessing_num_workers 1 \
    --per_device_train_batch_size $BATCH_SIZE_PER_GPU \
    --gradient_accumulation_steps $GRADIENT_ACC_STEPS \
    --learning_rate 3e-4 \
    --lr_scheduler_type linear \
    --warmup_ratio 0.001 \
    --diff_experiment 1 \
    --weight_decay 0.01 \
    --num_train_epochs $TOTAL_EDITSEQ_EPOCHS \
    --reduce_loss sum \
    --output_dir output/tinycodelm_400m_merged_instruct_editseq_s${NUM_EDIT_SEQS_PER_EXAMPLE}_lr3e-4_redsum \
    --with_tracking \
    --report_to wandb \
    --checkpointing_steps epoch \
    --logging_steps 1 \
