#!/usr/bin/env python3
"""
简单的脚本用于验证 wandb run ID 是否正确
"""
import wandb
from wandb.apis.public import Api

# 实验配置（从 plot_extra_exploration.py 复制）
EXPERIMENTS = {
    "baseline-gspo-dapo-math-minibsz32": {
        "title": "GSPO",
        "wandb_runs": [
            "astrid_tuning_llm/verl-qwen3-4b-oct/e7mn9b4j",
            "astrid_tuning_llm/verl-qwen3-4b-oct/3cvtlkqw"
        ]
    },
    "skip-right-skip-limits10-gspo-dapo-math": {
        "title": "GSPO + ours",
        "wandb_runs": [
            "astrid_tuning_llm/verl-qwen3-4b-oct/u2e2zp05"
        ]
    }
}

def verify_runs():
    """验证所有配置的 wandb runs"""
    print("=" * 70)
    print("验证 wandb run ID")
    print("=" * 70)
    
    try:
        api = Api()
        print(f"✓ 成功连接到 wandb API\n")
    except Exception as e:
        print(f"✗ 无法连接到 wandb API: {e}")
        print("请确保已运行 `wandb login` 或设置了 WANDB_API_KEY 环境变量")
        return
    
    all_valid = True
    
    for exp_key, exp_config in EXPERIMENTS.items():
        print(f"\n实验: {exp_key} ({exp_config['title']})")
        print("-" * 70)
        
        for run_path in exp_config["wandb_runs"]:
            try:
                run = api.run(run_path)
                print(f"✓ {run_path}")
                print(f"  - Run 名称: {run.name}")
                print(f"  - 状态: {run.state}")
                print(f"  - URL: {run.url}")
                
                # 检查是否有 actor/entropy 数据
                try:
                    history = run.history(keys=["actor/entropy"], pandas=True)
                    if not history.empty and "actor/entropy" in history.columns:
                        print(f"  - ✓ 找到 actor/entropy 数据: {len(history)} 条记录")
                    else:
                        print(f"  - ⚠ 未找到 actor/entropy 数据")
                except Exception as e:
                    print(f"  - ⚠ 无法检查 actor/entropy: {e}")
                    
            except Exception as e:
                print(f"✗ {run_path}")
                print(f"  错误: {e}")
                all_valid = False
                print(f"  提示: 请检查 wandb 网页上该 run 的完整路径")
                print(f"  格式应该是: entity/project/run_id")
    
    print("\n" + "=" * 70)
    if all_valid:
        print("✓ 所有 run ID 都有效！")
    else:
        print("✗ 部分 run ID 无效，请检查上面的错误信息")
    print("=" * 70)

if __name__ == "__main__":
    verify_runs()
