- CLAUDE.md: rewrite as project reference (training done); fix all local paths (remove CompanionGuard-RL nesting in code/) - .gitignore: add 旧方向信息/ and untrack it from index Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
5.4 KiB
5.4 KiB
CompanionGuard-RL — 项目参考文档
本文件由 Claude Code 自动读取。训练已全部完成,当前阶段:论文写作。
项目状态(2026-05-12)
| 模块 | 状态 | 关键指标 |
|---|---|---|
| 数据集 CompanionRisk-Bench v4 | ✅ 完成 | 9,896 样本,全 14 标签覆盖 |
| Module B — 检测器(MacBERT-large) | ✅ 完成 | binary_f1=0.9995, level_weighted_f1=0.559 |
| Module C — RL 干预策略(PPO) | ✅ 完成 | safety_recall=1.0, over_refusal=0.004 |
| 论文写作 | 🔄 进行中 | — |
详细结果见项目根目录 ../state.md,踩坑经验见 exp.md,变更记录见 change.md。
本地目录结构
D:\Myresearch\CompanionGuard-RL\
├── code/ ← 本目录(源代码)
│ ├── src/ ← 18 个核心 .py(models/ rl/ utils/)
│ ├── scripts/ ← 训练/评估/数据生成脚本
│ ├── configs/ ← 4 个 yaml 配置
│ ├── checkpoints/ ← 模型权重(gitignored)
│ │ ├── detector/best.pt ← Module B 论文权重(1.35GB)
│ │ └── intervention/final_v2.pt ← Module C 论文权重
│ ├── experiments/ ← 评估结果 JSON
│ │ ├── eval_intervention_v3.json ← Module C 论文用
│ │ └── eval_intervention_v4.json ← v3 重跑确认(数字相同)
│ └── data/ ← 处理后数据(gitignored)
├── data/ ← 原始数据集(gitignored)
├── docs/ ← 研究文档
├── state.md ← 项目进度快照(最新)
└── experiments/ ← 根目录评估结果备份
服务器信息
服务器 1(主训练机)
| 项目 | 值 |
|---|---|
| SSH | ssh -p 20083 root@10.82.3.180 |
| 密码 | m2dGcwyrhI |
| 项目目录 | /root/siton-data-2849d4ce327c4ccfb233ce33868fe7fe/zsy/CompanionGuard-RL |
| MacBERT | /root/siton-data-2849d4ce327c4ccfb233ce33868fe7fe/zsy/macbert-large |
| 环境 | /opt/conda/envs/dlapo-py310-cu128(torch 2.7.1+cu128) |
| GPU | 4 × RTX 5090 32GB |
服务器 2(当前使用)
| 项目 | 值 |
|---|---|
| SSH | ssh -p 20060 root@10.82.3.180 |
| 密码 | zwfn65xjTY |
| 项目目录 | /root/siton-data-740d234e02d749f08fe5347b0c74c49f/zsy/my-reasearch/companionguard-rl |
| MacBERT | /root/siton-data-740d234e02d749f08fe5347b0c74c49f/zsy/macbert-large |
| 环境 | /root/siton-data-740d234e02d749f08fe5347b0c74c49f/zsy/env/dlapo-py310-cu128 |
| GPU | 2 × RTX 5090 32GB |
两台服务器在同一宿主机
10.82.3.180,不同 Docker 容器。
SCP 同步命令(本地 ↔ 服务器)
# ===== 本地 → 服务器1(上传代码)=====
$S1="root@10.82.3.180"
$PROJ1="/root/siton-data-2849d4ce327c4ccfb233ce33868fe7fe/zsy/CompanionGuard-RL"
scp -P 20083 -r `
D:\Myresearch\CompanionGuard-RL\code\src `
D:\Myresearch\CompanionGuard-RL\code\scripts `
D:\Myresearch\CompanionGuard-RL\code\configs `
D:\Myresearch\CompanionGuard-RL\code\requirements.txt `
${S1}:${PROJ1}/
# 上传已处理数据
scp -P 20083 -r `
D:\Myresearch\CompanionGuard-RL\code\data `
${S1}:${PROJ1}/
# ===== 服务器1 → 本地(取回结果)=====
scp -P 20083 -r `
${S1}:${PROJ1}/checkpoints `
D:\Myresearch\CompanionGuard-RL\code\
scp -P 20083 -r `
${S1}:${PROJ1}/experiments `
D:\Myresearch\CompanionGuard-RL\code\
核心脚本用法
# 重新评估检测器(Module B)
python scripts/evaluate.py \
--detector-ckpt checkpoints/detector/best.pt \
--config configs/detector_config_server.yaml \
--test-data data/processed/CompanionRisk-Bench/test.jsonl \
--source-filter all \
--output experiments/eval_all.json
# 重新评估干预策略(Module C)
python scripts/evaluate.py \
--detector-ckpt checkpoints/detector/best.pt \
--agent-ckpt checkpoints/intervention/final_v2.pt \
--test-data data/processed/CompanionRisk-Bench/test.jsonl \
--config configs/detector_config_server.yaml \
--intervention-config configs/intervention_config.yaml \
--output experiments/eval_intervention_v3.json
关键结果(论文用)
Module B — 检测器 v4
| 指标 | 值 |
|---|---|
| binary_f1 | 0.9995 |
| high_risk_recall | 1.0000 |
| FNR | 0.00% |
| level_weighted_f1 | 0.559 |
| fine_macro_f1(public 10类) | 0.484 |
Module C — RL 干预策略 v3(论文用,eval_intervention_v3.json)
| 方法 | safety_recall | over_refusal | action_accuracy | safety_ux_fscore |
|---|---|---|---|---|
| Rule-based | 0.908 | 0.000 | — | 0.952 |
| Threshold | 0.908 | 0.000 | — | 0.952 |
| Ours (RL) | 1.000 | 0.004 | 0.575 | 0.998 |
使用权重:checkpoints/intervention/final_v2.pt(用 det_l_risk 重训)
重要注意事项
- PyYAML 6.x 陷阱:lr 值必须写
0.001而非1e-3(后者被解析为字符串) - RTX 5090 NCCL:多卡训练需
NCCL_SHM_DISABLE=1 NCCL_P2P_DISABLE=1;PPO 阶段用单卡绕开 barrier 问题 - det_l_risk vs l_risk:评估和训练均须用检测器预测的
det_l_risk,不能用 ground truthl_risk - obs_dim = 2065:state 向量结构
[d_score(1)|l_risk_onehot(5)|c_primary_probs(10)|e_H_pool(1024)|e_P_pool(1024)|t_norm(1)]