cd src/r1-v


export WORKSPACE_DIR="./robot/openvla-d"

export DATASET_PATH="${WORKSPACE_DIR}/train_all.json"

export PRETRAIN_MODEL_PATH="./model/Qwen2.5-VL-7B-Instruct"

export SAVE_PATH="./log/rl_video_nouse"                   # Absolute path to save checkpoints

export DEBUG_MODE="true" # Enable Debug if you want to see the rollout of model during RL
export LOG_PATH="./log/debug_log_2b.txt"
export DEBUG_MODE="true" # Enable Debug if you want to see the rollout of model during RL


CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 torchrun --nproc_per_node="8" \
    --nnodes="1" \
    --node_rank="0" \
    --master_addr="127.0.0.1" \
    --master_port="40365" \
    src/open_r1/grpo_drive.py \
    --output_dir ${SAVE_PATH} \
    --model_name_or_path ${PRETRAIN_MODEL_PATH} \
    --dataset_name ${DATASET_PATH} \
    --deepspeed local_scripts/zero3.json \
    --max_prompt_length 16384 \
    --max_completion_length 768 \
    --per_device_train_batch_size 1 \
    --gradient_accumulation_steps 1 \
    --learning_rate 1e-6 \
    --lr_scheduler_type "cosine" \
    --weight_decay 0.01 \
    --bf16 \
    --logging_steps 1 \
    --gradient_checkpointing true \
    --temporal true \
    --len_control true \
    --attn_implementation flash_attention_2 \
    --max_pixels 401408 \
    --num_train_epochs 1 \
    --run_name drive \
    --save_steps 100 \
    --beta 0.04 \
    --max_grad_norm 5 \
    --save_only_model false \
    --num_generations 2  # number of outputs G in grpo, reduce it would lead to faster training and smaller memory cost but higher variance  
    # --temperature 0.8 \