# ⚠️ 重要：如何正确运行训练脚本

## 问题说明

如果你遇到以下错误：
```
FileNotFoundError: Reward function file 'recipe/fileagent/reward_score_batch.py' not found.
```

这是因为**运行脚本的工作目录不对**。

## ✅ 正确的运行方式

### 方式 1: 从任意位置运行（推荐）⭐

脚本已经**自动处理路径问题**，你可以在任意目录运行：

```bash
# 方式 1a: 使用绝对路径
bash /path/to/your/verl/recipe/fileagent/run_extracted_bench.sh

# 方式 1b: 先进入 recipe/fileagent 目录
cd /path/to/your/verl/recipe/fileagent
bash run_extracted_bench.sh

# 方式 1c: 从项目根目录运行（最推荐）
cd /mnt/bn/fileagent-storage/users/<your_username>/verl
bash recipe/fileagent/run_extracted_bench.sh
```

**脚本会自动 `cd` 到正确的项目根目录！**

### 方式 2: Ray Submit 模式

```bash
# Ray 模式也支持从任意位置运行
bash /mnt/bn/fileagent-storage/users/<your_username>/verl/recipe/fileagent/run_extracted_bench_ray.sh

# 或者
cd /mnt/bn/fileagent-storage/users/<your_username>/verl/recipe/fileagent
bash run_extracted_bench_ray.sh
```

## 🔧 脚本内部的修复

两个脚本都在开头添加了：

```bash
# run_extracted_bench.sh
PROJECT_DIR="/mnt/bn/fileagent-storage/users/<your_username>/verl"
cd ${PROJECT_DIR}  # 切换到项目根目录

# run_extracted_bench_ray.sh
PROJECT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)"
cd ${PROJECT_DIR}  # 自动计算并切换到项目根目录
```

这样确保了所有相对路径（如 `recipe/fileagent/reward_score_batch.py`）都能正确解析。

## 📂 相对路径说明

训练配置中使用的相对路径（从项目根目录开始）：

```yaml
# recipe/fileagent/config/extracted_bench_trainer.yaml
custom_reward_function:
  path: "recipe/fileagent/reward_score_batch.py"  # 相对于项目根目录
```

脚本中的相对路径：

```bash
tool_cfg_path="recipe/fileagent/config/tool/extracted_bench_tool.yaml"
agent_loop_cfg_path="recipe/fileagent/config/agent_loop.yaml"
new_sp_path="recipe/fileagent/prompts/extracted_bench_sp.md"
```

所有这些路径都假设**当前工作目录是项目根目录**：
```
/mnt/bn/fileagent-storage/users/<your_username>/verl/
```

## ❌ 错误示例

### 错误 1: 在错误的目录运行

```bash
# ❌ 错误：在 /root 目录运行
cd /root
bash /mnt/bn/fileagent-storage/users/<your_username>/verl/recipe/fileagent/run_extracted_bench.sh
# 这个现在也能工作了！因为脚本会自动 cd
```

### 错误 2: 旧版本脚本（已修复）

如果你使用的是旧版本脚本（没有 `cd ${PROJECT_DIR}`），必须手动在项目根目录运行：

```bash
cd /mnt/bn/fileagent-storage/users/<your_username>/verl  # 必须先 cd
bash recipe/fileagent/run_extracted_bench.sh
```

## ✅ 验证路径

如果你想验证路径是否正确，可以运行：

```bash
cd /mnt/bn/fileagent-storage/users/<your_username>/verl
ls -la recipe/fileagent/reward_score_batch.py
# 应该看到文件存在
```

## 🚀 现在可以正常运行了

使用最新的脚本，你可以在**任意目录**运行训练：

```bash
# 推荐方式（最清晰）
cd /mnt/bn/fileagent-storage/users/<your_username>/verl
bash recipe/fileagent/run_extracted_bench.sh
```

或者

```bash
# 也可以用绝对路径（任意位置都行）
bash /mnt/bn/fileagent-storage/users/<your_username>/verl/recipe/fileagent/run_extracted_bench.sh
```

## 📝 总结

| 问题 | 原因 | 解决方案 |
|------|------|---------|
| `FileNotFoundError` | 工作目录不对 | 脚本自动 `cd` 到项目根目录 ✅ |
| 相对路径找不到 | `recipe/fileagent/...` 需要从根目录开始 | 脚本开头执行 `cd ${PROJECT_DIR}` ✅ |
| Ray Submit 失败 | 同上 | 同上 ✅ |

**现在两个脚本都已修复，可以从任意位置运行！** 🎉

---

**更新日期**: 2025-10-15  
**修复版本**: v2.0
