#!/bin/bash

# --- 配置信息 ---
PYTHON_BIN="~/verl_250713/.conda/bin/python"
SCRIPT_PATH="~/verl_250713/scripts/bon3_print2.py"

# 定义 4 个 Rollout 根目录（对应你之前的 1, 2, 3, 4 部分）
ROLLOUT_DIRS=(
    "~/LLaMA-Factory-250514/saves_shuyan/llama3.2-1B-base/prime-sft-full/prime-rl-rollouts"
    "~/LLaMA-Factory-250514/saves_shuyan/llama3.2-3B/prime-sft/prime-rl-rollouts"
    "~/LLaMA-Factory-250514/saves_shuyan/qwen3-0.6B-base/prime-sft/prime-rl-rollouts"
    "~/LLaMA-Factory-250514/saves_shuyan/qwen3-8B-base/prime-sft/prime-rl-rollouts"
)

# 定义文件名的组成部分
MODELS=("llama321b" "llama323b" "qwen306b" "qwen38b")
SUFFIXES=("ref.json" "dpo.json" "implicitprm.json" "ipvrm.json" "qrm.json")

# --- 核心循环逻辑 ---

for dir in "${ROLLOUT_DIRS[@]}"; do
    for model in "${MODELS[@]}"; do
        for suffix in "${SUFFIXES[@]}"; do
            
            # 拼接完整的 output_path
            FILE_PATH="$dir/842_bo64_${model}_${suffix}"

            # 1. 如果文件不存在，打印并跳过
            if [ ! -f "$FILE_PATH" ]; then
                echo "--- [SKIP] 文件不存在: $FILE_PATH"
                continue
            fi

            # 2. 如果文件名包含 ref，跳过
            if [[ "$FILE_PATH" == *"ref"* ]]; then
                echo "--- [SKIP] Ref文件跳过: $(basename "$FILE_PATH")"
                continue
            fi

            echo ">>> [PROCESS] 正在处理: $(basename "$FILE_PATH")"

            # 3. 判断是否为 qrm 文件
            if [[ "$FILE_PATH" == *"qrm"* ]]; then
                # QRM 逻辑：不带 --ref-tag
                for n in 4 16 64; do
                    $PYTHON_BIN $SCRIPT_PATH \
                        --bon-dataset "$FILE_PATH" \
                        --num-bon "$n" \
                        --rm-tag rmlogp
                done
            else
                # 其他文件逻辑：带 --ref-tag
                for n in 4 16 64; do
                    $PYTHON_BIN $SCRIPT_PATH \
                        --bon-dataset "$FILE_PATH" \
                        --num-bon "$n" \
                        --rm-tag rmlogp \
                        --ref-tag reflogp
                done
            fi
        done
    done
done

echo "所有任务处理完成！"