The finetuning code is present in fineTune.py
To carry out fine-tuning experiments:
model_name can be either 'meta-llama/Meta-Llama-3-8B' or 'allenai/OLMo-2-1124-7B'
accelerate launch \
    --mixed_precision bf16 \
    --num_machines 1 \
    --main_process_port $MASTER_PORT \
    --num_processes $NUM_GPUS \
    --use_deepspeed \
    --deepspeed_config_file stage3_no_offloading_accelerate.conf \
    open_instruct/fineTune_New.py \
    --model_name_or_path  ${model_name} \
    --use_flash_attn \
    --tokenizer_name ${model_name} \
    --use_slow_tokenizer \
    --dataset ${dataset} \
    --train_file ${train_file} \
    --validation_file ${validation_file} \
    --max_seq_length 512 \
    --reduce_loss 'sum' \
    --keep_last_n_checkpoints -1 \
    --preprocessing_num_workers 128 \
    --per_device_train_batch_size $BATCH_SIZE_PER_GPU \
    --gradient_accumulation_steps $GRADIENT_ACC_STEPS \
    --learning_rate 2e-5 \
    --lr_scheduler_type linear \
    --warmup_ratio 0.03 \
    --weight_decay 0. \
    --num_train_epochs 3 \
    --checkpointing_steps 128 \
    --output_dir ${output_dir}/ \
    --with_tracking True\
    --report_to wandb \
    --logging_steps 50 --push_to_hub False
    
    
To evaluate:
model_name is the path to finetuned model
input_file is the validation/test file
python evalOpenEnded.py --model ${model_name} --input_test_file ${input_file}

