#!/bin/bash
# 合并checkpoint
# 用法: ./merge_checkpoint.sh [step]

# ============ 默认配置 ============
DEFAULT_CKPT_BASE="/home/*/workspace/verl-agent/checkpoints/verl_agent_alfworld_migpo/migpo_qwen2.5_1.5b"
DEFAULT_STEP="all"
# =================================

cd "$(dirname "$0")"

CKPT_BASE=${1:-$DEFAULT_CKPT_BASE}
STEPS=${2:-$DEFAULT_STEP}
CKPT_NAME=$(basename "$CKPT_BASE")
OUTPUT_DIR="./merged_models/${CKPT_NAME}"

mkdir -p "$OUTPUT_DIR"

echo "============================================"
echo "合并Checkpoint"
echo "============================================"
echo "源目录: $CKPT_BASE"
echo "输出目录: $OUTPUT_DIR"
echo "步数: $STEPS"
echo "============================================"

if [ "$STEPS" = "all" ]; then
    for step_dir in "$CKPT_BASE"/global_step_*; do
        step=$(basename "$step_dir" | sed 's/global_step_//')
        target="${OUTPUT_DIR}/step_${step}"
        if [ ! -d "$target" ]; then
            echo "合并 step_${step}..."
            python merge_checkpoint.py \
                --checkpoint_dir "${step_dir}/actor" \
                --target_dir "$target"
        else
            echo "跳过 step_${step} (已存在)"
        fi
    done
else
    IFS=',' read -ra STEP_ARRAY <<< "$STEPS"
    for step in "${STEP_ARRAY[@]}"; do
        step_dir="${CKPT_BASE}/global_step_${step}"
        target="${OUTPUT_DIR}/step_${step}"
        if [ ! -d "$step_dir" ]; then
            echo "警告: ${step_dir} 不存在"
            continue
        fi
        if [ ! -d "$target" ]; then
            echo "合并 step_${step}..."
            python merge_checkpoint.py \
                --checkpoint_dir "${step_dir}/actor" \
                --target_dir "$target"
        else
            echo "跳过 step_${step} (已存在)"
        fi
    done
fi

echo "完成!"
