mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-05-15 03:04:43 +08:00
311 lines
12 KiB
Markdown
311 lines
12 KiB
Markdown
---
|
||
name: santa-method
|
||
description: "具有收敛循环的多智能体对抗验证。两个独立的审查代理必须都通过,输出才能发送。"
|
||
origin: "Ronald Skelton - Founder, RapportScore.ai"
|
||
---
|
||
|
||
# 圣诞老人方法
|
||
|
||
多智能体对抗验证框架。列个清单,检查两遍。如果行为不端,就修正直到表现良好。
|
||
|
||
核心洞察:单个智能体审查自身输出时,会共享产生该输出的相同偏见、知识盲区和系统性错误。两个没有共享上下文的独立审查者可以打破这种故障模式。
|
||
|
||
## 何时激活
|
||
|
||
在以下情况调用此技能:
|
||
|
||
* 输出将被发布、部署或供最终用户使用
|
||
* 必须强制执行合规、监管或品牌约束
|
||
* 代码未经人工审查即投入生产
|
||
* 内容准确性至关重要(技术文档、教育材料、面向客户的文案)
|
||
* 大规模批量生成,抽检无法发现系统性模式
|
||
* 幻觉风险较高(声明、统计数据、API 参考、法律用语)
|
||
|
||
**不要**用于内部草稿、探索性研究或具有确定性验证的任务(这些请使用构建/测试/代码检查流水线)。
|
||
|
||
## 架构
|
||
|
||
```
|
||
┌─────────────┐
|
||
│ 生成器 │ 阶段 1:列出清单
|
||
│ (代理 A) │ 生成交付物
|
||
└──────┬───────┘
|
||
│ 输出
|
||
▼
|
||
┌──────────────────────────────┐
|
||
│ 双重独立审查 │ 阶段 2:复核两次
|
||
│ │
|
||
│ ┌───────────┐ ┌───────────┐ │ 两个代理,同一评分标准,
|
||
│ │ 审查者 B │ │ 审查者 C │ │ 无共享上下文
|
||
│ └─────┬─────┘ └─────┬─────┘ │
|
||
│ │ │ │
|
||
└────────┼──────────────┼───────┘
|
||
│ │
|
||
▼ ▼
|
||
┌──────────────────────────────┐
|
||
│ 裁决门 │ 阶段 3:判定好坏
|
||
│ │
|
||
│ B通过且C通过 → 好 │ 两者必须通过。
|
||
│ 否则 → 坏 │ 无例外。
|
||
└──────┬──────────────┬────────┘
|
||
│ │
|
||
好 坏
|
||
│ │
|
||
▼ ▼
|
||
[ 发布 ] ┌─────────────┐
|
||
│ 修复循环 │ 阶段 4:修复至通过
|
||
│ │
|
||
│ 迭代次数++ │ 收集所有标记。
|
||
│ 若 i > 最大: │ 修复所有问题。
|
||
│ 升级处理 │ 重新运行两个审查者。
|
||
│ 否则: │ 循环直至收敛。
|
||
│ 跳至阶段2 │
|
||
└──────────────┘
|
||
```
|
||
|
||
## 阶段详情
|
||
|
||
### 阶段 1:列清单(生成)
|
||
|
||
执行主要任务。无需改变正常的生成工作流程。圣诞老人方法是一个生成后验证层,而非生成策略。
|
||
|
||
```python
|
||
# The generator runs as normal
|
||
output = generate(task_spec)
|
||
```
|
||
|
||
### 阶段 2:检查两遍(独立双重审查)
|
||
|
||
并行生成两个审查智能体。关键不变项:
|
||
|
||
1. **上下文隔离** — 两个审查者互不见面对方的评估
|
||
2. **相同评估标准** — 两者收到相同的评估标准
|
||
3. **相同输入** — 两者都收到原始规格说明和生成的输出
|
||
4. **结构化输出** — 每个审查者返回类型化的判定,而非散文
|
||
|
||
```python
|
||
REVIEWER_PROMPT = """
|
||
You are an independent quality reviewer. You have NOT seen any other review of this output.
|
||
|
||
## Task Specification
|
||
{task_spec}
|
||
|
||
## Output Under Review
|
||
{output}
|
||
|
||
## Evaluation Rubric
|
||
{rubric}
|
||
|
||
## Instructions
|
||
Evaluate the output against EACH rubric criterion. For each:
|
||
- PASS: criterion fully met, no issues
|
||
- FAIL: specific issue found (cite the exact problem)
|
||
|
||
Return your assessment as structured JSON:
|
||
{
|
||
"verdict": "PASS" | "FAIL",
|
||
"checks": [
|
||
{"criterion": "...", "result": "PASS|FAIL", "detail": "..."}
|
||
],
|
||
"critical_issues": ["..."], // blockers that must be fixed
|
||
"suggestions": ["..."] // non-blocking improvements
|
||
}
|
||
|
||
Be rigorous. Your job is to find problems, not to approve.
|
||
"""
|
||
```
|
||
|
||
```python
|
||
# Spawn reviewers in parallel (Claude Code subagents)
|
||
review_b = Agent(prompt=REVIEWER_PROMPT.format(...), description="Santa Reviewer B")
|
||
review_c = Agent(prompt=REVIEWER_PROMPT.format(...), description="Santa Reviewer C")
|
||
|
||
# Both run concurrently — neither sees the other
|
||
```
|
||
|
||
### 评估标准设计
|
||
|
||
评估标准是最重要的输入。模糊的标准会产生模糊的审查。每个标准必须有客观的通过/失败条件。
|
||
|
||
| 标准 | 通过条件 | 失败信号 |
|
||
|-----------|---------------|----------------|
|
||
| 事实准确性 | 所有声明均可根据源材料或常识验证 | 编造的统计数据、错误的版本号、不存在的 API |
|
||
| 无幻觉 | 没有虚构的实体、引用、URL 或参考文献 | 指向不存在页面的链接、无来源的引用 |
|
||
| 完整性 | 规格说明中的每个要求都得到满足 | 缺少章节、遗漏边缘情况、覆盖不完整 |
|
||
| 合规性 | 通过所有项目特定的约束 | 使用禁用术语、语气违规、监管不合规 |
|
||
| 内部一致性 | 输出内无矛盾 | A 部分说 X,B 部分说非 X |
|
||
| 技术正确性 | 代码可编译/运行,算法合理 | 语法错误、逻辑错误、错误的复杂度声明 |
|
||
|
||
#### 特定领域评估标准扩展
|
||
|
||
**内容/营销:**
|
||
|
||
* 品牌语气一致性
|
||
* 满足 SEO 要求(关键词密度、元标签、结构)
|
||
* 无竞争对手商标滥用
|
||
* CTA 存在且链接正确
|
||
|
||
**代码:**
|
||
|
||
* 类型安全(无 `any` 泄漏,正确处理 null)
|
||
* 错误处理覆盖
|
||
* 安全性(代码中无秘密、输入验证、注入防护)
|
||
* 新路径的测试覆盖
|
||
|
||
**合规敏感(受监管、法律、金融):**
|
||
|
||
* 无结果保证或未经证实的声明
|
||
* 存在所需的免责声明
|
||
* 仅使用批准的术语
|
||
* 符合司法管辖区的语言
|
||
|
||
### 阶段 3:表现好坏(判定门控)
|
||
|
||
```python
|
||
def santa_verdict(review_b, review_c):
|
||
"""Both reviewers must pass. No partial credit."""
|
||
if review_b.verdict == "PASS" and review_c.verdict == "PASS":
|
||
return "NICE" # Ship it
|
||
|
||
# Merge flags from both reviewers, deduplicate
|
||
all_issues = dedupe(review_b.critical_issues + review_c.critical_issues)
|
||
all_suggestions = dedupe(review_b.suggestions + review_c.suggestions)
|
||
|
||
return "NAUGHTY", all_issues, all_suggestions
|
||
```
|
||
|
||
为什么两者都必须通过:如果只有一个审查者发现问题,那么该问题是真实存在的。另一个审查者的盲点正是圣诞老人方法旨在消除的故障模式。
|
||
|
||
### 阶段 4:修正直到表现良好(收敛循环)
|
||
|
||
```python
|
||
MAX_ITERATIONS = 3
|
||
|
||
for iteration in range(MAX_ITERATIONS):
|
||
verdict, issues, suggestions = santa_verdict(review_b, review_c)
|
||
|
||
if verdict == "NICE":
|
||
log_santa_result(output, iteration, "passed")
|
||
return ship(output)
|
||
|
||
# Fix all critical issues (suggestions are optional)
|
||
output = fix_agent.execute(
|
||
output=output,
|
||
issues=issues,
|
||
instruction="Fix ONLY the flagged issues. Do not refactor or add unrequested changes."
|
||
)
|
||
|
||
# Re-run BOTH reviewers on fixed output (fresh agents, no memory of previous round)
|
||
review_b = Agent(prompt=REVIEWER_PROMPT.format(output=output, ...))
|
||
review_c = Agent(prompt=REVIEWER_PROMPT.format(output=output, ...))
|
||
|
||
# Exhausted iterations — escalate
|
||
log_santa_result(output, MAX_ITERATIONS, "escalated")
|
||
escalate_to_human(output, issues)
|
||
```
|
||
|
||
关键:每轮审查使用**全新的智能体**。审查者不得携带之前轮次的记忆,因为先前的上下文会造成锚定偏差。
|
||
|
||
## 实现模式
|
||
|
||
### 模式 A:Claude Code 子智能体(推荐)
|
||
|
||
子智能体提供真正的上下文隔离。每个审查者是一个独立的进程,没有共享状态。
|
||
|
||
```bash
|
||
# In a Claude Code session, use the Agent tool to spawn reviewers
|
||
# Both agents run in parallel for speed
|
||
```
|
||
|
||
```python
|
||
# Pseudocode for Agent tool invocation
|
||
reviewer_b = Agent(
|
||
description="Santa Review B",
|
||
prompt=f"Review this output for quality...\n\nRUBRIC:\n{rubric}\n\nOUTPUT:\n{output}"
|
||
)
|
||
reviewer_c = Agent(
|
||
description="Santa Review C",
|
||
prompt=f"Review this output for quality...\n\nRUBRIC:\n{rubric}\n\nOUTPUT:\n{output}"
|
||
)
|
||
```
|
||
|
||
### 模式 B:顺序内联(备用方案)
|
||
|
||
当子智能体不可用时,通过显式上下文重置模拟隔离:
|
||
|
||
1. 生成输出
|
||
2. 新上下文:"你是审查者 1。仅根据此评估标准进行评估。找出问题。"
|
||
3. 逐字记录发现
|
||
4. 完全清除上下文
|
||
5. 新上下文:"你是审查者 2。仅根据此评估标准进行评估。找出问题。"
|
||
6. 比较两个审查结果,修复,重复
|
||
|
||
子智能体模式严格优于内联模拟——内联模拟存在审查者之间上下文渗透的风险。
|
||
|
||
### 模式 C:批量采样
|
||
|
||
对于大批量(100+ 项),对每个项目都执行完整的圣诞老人方法成本过高。使用分层采样:
|
||
|
||
1. 对随机样本(批量的 10-15%,最少 5 项)运行圣诞老人方法
|
||
2. 按类型对失败进行分类(幻觉、合规性、完整性等)
|
||
3. 如果出现系统性模式,对整个批量应用针对性修复
|
||
4. 重新采样并重新验证修复后的批量
|
||
5. 持续直到干净的样本通过
|
||
|
||
```python
|
||
import random
|
||
|
||
def santa_batch(items, rubric, sample_rate=0.15):
|
||
sample = random.sample(items, max(5, int(len(items) * sample_rate)))
|
||
|
||
for item in sample:
|
||
result = santa_full(item, rubric)
|
||
if result.verdict == "NAUGHTY":
|
||
pattern = classify_failure(result.issues)
|
||
items = batch_fix(items, pattern) # Fix all items matching pattern
|
||
return santa_batch(items, rubric) # Re-sample
|
||
|
||
return items # Clean sample → ship batch
|
||
```
|
||
|
||
## 故障模式与缓解措施
|
||
|
||
| 故障模式 | 症状 | 缓解措施 |
|
||
|-------------|---------|------------|
|
||
| 无限循环 | 修复后审查者仍不断发现新问题 | 最大迭代次数限制(3 次)。升级处理。 |
|
||
| 橡皮图章 | 两个审查者都通过所有内容 | 对抗性提示:"你的工作是发现问题,而不是批准。" |
|
||
| 主观漂移 | 审查者标记风格偏好,而非错误 | 严格的评估标准,仅包含客观的通过/失败标准 |
|
||
| 修复回归 | 修复问题 A 引入了问题 B | 每轮使用全新的审查者来捕获回归 |
|
||
| 审查者一致性偏差 | 两个审查者都遗漏了同一件事 | 独立性可缓解但无法消除。对于关键输出,添加第三个审查者或人工抽检。 |
|
||
| 成本激增 | 大型输出上迭代次数过多 | 批量采样模式。每个验证周期的预算上限。 |
|
||
|
||
## 与其他技能的集成
|
||
|
||
| 技能 | 关系 |
|
||
|-------|-------------|
|
||
| 验证循环 | 用于确定性检查(构建、代码检查、测试)。圣诞老人方法用于语义检查(准确性、幻觉)。先运行验证循环,再运行圣诞老人方法。 |
|
||
| 评估工具 | 圣诞老人方法的结果反馈给评估指标。跟踪圣诞老人方法运行中的 pass@k,以衡量生成器质量随时间的变化。 |
|
||
| 持续学习 v2 | 圣诞老人方法的发现成为本能。同一标准上的重复失败 → 学习到的行为以避免该模式。 |
|
||
| 战略压缩 | 在压缩**之前**运行圣诞老人方法。不要在验证过程中丢失审查上下文。 |
|
||
|
||
## 指标
|
||
|
||
跟踪以下指标以衡量圣诞老人方法的有效性:
|
||
|
||
* **首次通过率**:第一轮通过圣诞老人方法的输出百分比(目标:>70%)
|
||
* **收敛平均迭代次数**:达到"表现良好"的平均轮数(目标:<1.5)
|
||
* **问题分类**:失败类型的分布(幻觉 vs. 完整性 vs. 合规性)
|
||
* **审查者一致性**:两个审查者都标记的问题与仅一个审查者标记的问题的百分比(一致性低 = 需要收紧评估标准)
|
||
* **逃逸率**:发布后发现但圣诞老人方法本应捕获的问题(目标:0)
|
||
|
||
## 成本分析
|
||
|
||
每个验证周期,圣诞老人方法的代币成本大约是单独生成的 2-3 倍。对于大多数高风险的输出,这很划算:
|
||
|
||
```
|
||
圣诞老人的成本 = (生成代币) + 2×(每轮审查代币) × (平均轮数)
|
||
不做圣诞老人的成本 = (声誉损害) + (纠正努力) + (信任侵蚀)
|
||
```
|
||
|
||
对于批量操作,采样模式将成本降低到完全验证的约 15-20%,同时捕获超过 90% 的系统性问题。
|