first commit
This commit is contained in:
219
sn-deep-research/SKILL.md
Normal file
219
sn-deep-research/SKILL.md
Normal file
@@ -0,0 +1,219 @@
|
||||
---
|
||||
name: sn-deep-research
|
||||
description: "深度调研全流程编排器(入口 skill)。自动完成:规划→分维度取证→综合→成稿。产物:report.md + plan.json + sub_reports/*.md + synthesis.md。触发词:深度研究/调研/全面研究/系统研究/调研报告/深度报告/deep research/research report/行业研究/市场研究/竞品分析/政策研究/技术研究。这是管线入口,内部会自动调用 sn-research-planning → sn-dimension-research → sn-research-synthesis → sn-research-report。不用于:单点事实问答、一句话摘要、已给定来源的整理。如果用户已有材料只需写报告,用 sn-research-report。"
|
||||
---
|
||||
|
||||
# Deep Research Orchestrator
|
||||
|
||||
这是深度研究的总控 skill。它负责把用户请求推进成一条可执行、可续跑、可核查、可交付的研究链路,并把全过程落盘到同一个 `report_dir`。
|
||||
|
||||
它是**编排器**,不是某一阶段的方法本身。需要在对应阶段读取并遵循其他方法 skill,但这些 skill 仍然在当前会话内顺序执行;不要异步分派、创建后台专家、启动额外子会话,或把关键阶段留在对话里不落盘。
|
||||
|
||||
## 启动前硬检查:web_search 配置
|
||||
|
||||
在创建 `report_dir`、写 `request.md` 或进入任何研究阶段之前,必须通过一次极小的通用 `web_search` 探测确认当前会话搜索能力可用。未确认时不要开始研究,也不要用记忆或已有知识替代联网取证。
|
||||
|
||||
检查规则:
|
||||
- 不判断自己运行在 OpenClaw、Hermes 还是其他宿主;不要读取或推断宿主专属配置路径。
|
||||
- 发起一次低成本、低歧义的 `web_search` 探测,只需要确认工具能返回正常搜索结果。
|
||||
- 探测成功且返回非空结果即可继续。
|
||||
- 探测失败、工具不存在、返回缺 key、provider 未就绪、服务不可达、search disabled、权限不足或结果为空时,停止流程并提示用户配置当前宿主的 `web_search`。
|
||||
|
||||
```text
|
||||
sn-deep-research 需要当前会话的 web_search 可用,但通用探测未通过。
|
||||
|
||||
请先按当前智能体宿主的文档配置 web_search provider、key / secret 与工具开关。
|
||||
配置后重启或刷新智能体会话,再重新发起 sn-deep-research。
|
||||
```
|
||||
|
||||
## 第一性原理
|
||||
|
||||
深度研究不能缺少的只有 5 个阶段:
|
||||
|
||||
1. **记录请求**:保留原始需求、约束、日期、上下文和执行假设,作为全流程锚点。
|
||||
2. **规划研究**:把需求转成 `plan.json`,完成定界、维度拆解、报告形态设想、搜索策略和完成标准。
|
||||
3. **分维度取证**:逐个维度做多轮检索、筛选证据、交叉验证,并落盘为子报告。
|
||||
4. **综合判断**:把分散子报告提炼成能回答原始问题的主线判断、冲突解释和不确定性。
|
||||
5. **生成终稿**:把综合判断转成面向读者的 `report.md`,而不是机械拼接子报告。
|
||||
|
||||
辅助动作可以精简,但不能跳过上述阶段。
|
||||
|
||||
## 产物链
|
||||
|
||||
```text
|
||||
request.md
|
||||
-> plan.json
|
||||
-> sub_reports/*.md
|
||||
-> synthesis.md
|
||||
-> report.md
|
||||
```
|
||||
|
||||
所有阶段都必须写入文件,并在进入下一阶段前再次读取确认文件存在、非空且结构完整。只在对话中说明进展不算完成。
|
||||
|
||||
## 目录规则
|
||||
|
||||
`report_dir`:
|
||||
|
||||
```text
|
||||
{workspace}/reports/{YYYY-MM-DD}-{topic_slug}-{hex4}/
|
||||
```
|
||||
|
||||
- `topic_slug`:保留汉字、字母、数字、短横线;其他字符替换为 `-`;合并连续 `-`;截断到 40 个字符;去掉首尾 `-`
|
||||
- `hex4`:用 `exec` 运行 `openssl rand -hex 2`
|
||||
- 初始化时创建 `sub_reports/`、`images/`
|
||||
- 阶段文件一律使用绝对路径
|
||||
- 若用户要求继续已有项目,优先复用现有 `report_dir`,不要新建平行目录
|
||||
|
||||
## 阶段协议
|
||||
|
||||
在对应阶段读取并遵循下列方法 skill。它们是执行方法,不是后台任务。
|
||||
|
||||
| 阶段 | 使用 skill | 主要产物 |
|
||||
|---|---|---|
|
||||
| 0 初始化 | 无 | `request.md` |
|
||||
| 1 规划 | `sn-research-planning`,必要时辅以 `sn-report-format-discovery` | `plan.json` |
|
||||
| 2 取证 | `sn-dimension-research` | `sub_reports/{dimension_id}.md`、更新后的 `plan.json` |
|
||||
| 3 综合 | `sn-research-synthesis` | `synthesis.md` |
|
||||
| 4 成稿 | `sn-research-report` | `report.md` |
|
||||
|
||||
## 执行流程
|
||||
|
||||
### 0. 初始化
|
||||
|
||||
创建 `report_dir` 与子目录。写入 `request.md`,至少包含:
|
||||
|
||||
- 用户原始需求
|
||||
- 当前日期
|
||||
- 工作目录
|
||||
- 已知约束
|
||||
- 目标用途或目标读者
|
||||
- 澄清记录
|
||||
- 当前执行假设
|
||||
|
||||
如果关键歧义会改变研究对象、时间范围、地域范围或交付形式,先问最多 3 个问题;如果用户暂不回答,就记录合理假设并继续。
|
||||
|
||||
### 1. 规划:Plan
|
||||
|
||||
读取 `sn-research-planning`,生成 `plan.json`。
|
||||
|
||||
规划阶段必须一次性完成:
|
||||
|
||||
- 明确研究目标、范围边界、受众/用途、时间/地域和关键假设
|
||||
- 设定终稿结构建议,以及必须产出的表格、图、比较项或清单
|
||||
- 把研究拆成可执行维度;普通研究控制在 3-5 个维度,复杂研究最多 8 个维度
|
||||
- 为每个维度定义 `key_questions`、`method`、`search_strategy`、`expected_output`、`depends_on`、`status`
|
||||
- 明确 `completion_criteria` 和 `execution_order`
|
||||
|
||||
当你不确定“这类报告应该长什么样”时,先读取 `sn-report-format-discovery`,为 `plan.json.report_shape` 提供结构依据;但不要把格式研究扩张成正文事实研究。
|
||||
|
||||
进入下一阶段前确认:
|
||||
|
||||
- `plan.json` 存在且非空
|
||||
- `execution_order` 覆盖全部维度
|
||||
- 每个维度都有可执行的搜索策略和停止条件
|
||||
- `report_shape` 足以约束最终成稿
|
||||
|
||||
### 2. 取证:Dimension Research
|
||||
|
||||
按 `plan.json.execution_order` 逐个处理 `status != done` 的维度。每个维度都要读取 `sn-dimension-research`。
|
||||
|
||||
每个维度完成后必须确认:
|
||||
|
||||
- `sub_reports/{dimension_id}.md` 已写入且非空
|
||||
- 子报告回答、部分回答或明确标注了每个 `key_questions`
|
||||
- 子报告包含精简证据记录、充分性判断、不确定性与空白
|
||||
- `plan.json` 中该维度 `status` 已更新为 `done`
|
||||
|
||||
不要把报告章节直接当维度来写,也不要凭单轮搜索或少量材料直接成文。
|
||||
|
||||
### 3. 研究中调整:Plan Maintenance
|
||||
|
||||
每完成 2-3 个维度,快速检查一次:
|
||||
|
||||
- 当前材料是否仍然能回答原始问题
|
||||
- 当前维度集合是否足以支撑 `plan.json.report_shape`
|
||||
- 是否出现了需要新增、合并、拆分、删除或重排的维度
|
||||
|
||||
只有确有必要时才调整 `plan.json`,并把原因写入 `plan.json.change_notes`。不要因为局部搜索不顺就频繁改计划。
|
||||
|
||||
### 4. 综合:Synthesis
|
||||
|
||||
当全部必要维度完成后,读取 `sn-research-synthesis` 生成 `synthesis.md`。
|
||||
|
||||
综合阶段必须完成:
|
||||
|
||||
- 回答原始问题,而不是只总结材料
|
||||
- 提炼 2-5 条主线判断
|
||||
- 标明每条主线的证据强弱和成立条件
|
||||
- 汇总跨维度共识
|
||||
- 解释关键冲突来自哪里
|
||||
- 明确保留不确定性、信息缺口和可能推翻结论的条件
|
||||
- 给终稿提供写作主线和章节分配建议
|
||||
|
||||
如果发现关键缺口导致主线无法成立,回到对应维度补研究,再重新综合。没有 `synthesis.md` 时,不要直接进入终稿阶段。
|
||||
|
||||
### 5. 成稿:Report
|
||||
|
||||
读取 `sn-research-report`,基于 `request.md`、`plan.json`、`synthesis.md` 和全部子报告生成 `report.md`。
|
||||
|
||||
终稿必须:
|
||||
|
||||
- 按 `plan.json.report_shape` 或其合理修订版组织
|
||||
- 以 `synthesis.md` 的判断层为主线,而不是把子报告顺序拼接
|
||||
- 处理跨维度共识、冲突、条件和不确定性
|
||||
- 面向目标读者完成表达,而不是保留内部研究痕迹
|
||||
|
||||
若写作时发现仍有关键事实缺口,回到对应维度补研究或重做综合,而不是硬写。
|
||||
|
||||
### 6. 交付
|
||||
|
||||
交付前重新读取并确认 `report.md` 存在且非空。
|
||||
|
||||
回复用户时至少提供:
|
||||
|
||||
- `report_dir` 的绝对路径
|
||||
- `report.md` 的绝对路径
|
||||
- 必要时附一段简短摘要或说明仍存在哪些不确定性
|
||||
|
||||
## 阶段切换规则
|
||||
|
||||
只有在当前阶段产物已落盘并通过最基本检查后,才能进入下一阶段。
|
||||
|
||||
- 没有 `request.md`:不能开始规划
|
||||
- 没有有效 `plan.json`:不能开始分维度取证
|
||||
- 任一必要维度未完成:不能开始综合
|
||||
- 没有 `synthesis.md`:不能开始终稿生成
|
||||
- `report.md` 为空或结构明显缺失:不能宣称完成
|
||||
|
||||
## 续跑规则
|
||||
|
||||
如果用户要求继续已有研究,先检查 `report_dir`,从最早缺失或未完成的阶段恢复:
|
||||
|
||||
- 无 `request.md`:从初始化开始
|
||||
- 有 `request.md` 无 `plan.json`:从规划开始
|
||||
- 有 `plan.json` 但仍有 `status != done` 的维度:从第一个未完成维度继续
|
||||
- 全部必要维度完成但无 `synthesis.md`:从综合开始
|
||||
- 有 `synthesis.md` 但无 `report.md`:从成稿开始
|
||||
- 有 `report.md`:直接交付;若用户要求补充或修订,判断需要回到综合还是某个维度
|
||||
|
||||
继续时不要重建目录,也不要覆盖无关阶段文件;只有在你明确正在修订该阶段时才更新对应产物。
|
||||
|
||||
## 质量守门
|
||||
|
||||
- 任何阶段文件缺失、为空、格式无效或明显不完整时,先补该阶段。
|
||||
- 涉及最新信息、政策、市场、产品、人物、价格、法律、监管等,必须联网核查并明确时间范围。
|
||||
- 高风险判断优先追溯原始来源,并做多源交叉确认;无法确认时显式写入不确定性。
|
||||
- `plan.json` 必须能独立承担定界、执行地图和终稿形态约束。
|
||||
- `sub_reports/*.md` 必须保留精简证据记录,而不是只写结论。
|
||||
- `synthesis.md` 必须形成判断层,而不是维度摘要合集。
|
||||
- `report.md` 必须做跨维度综合,而不是子报告拼接。
|
||||
- 不写脚注、文末参考文献或来源编号后处理;来源追踪保留在子报告证据记录中。
|
||||
|
||||
## 禁止事项
|
||||
|
||||
- 不跳过 `synthesis.md` 直接从子报告写最终报告。
|
||||
- 不把报告章节直接当研究维度。
|
||||
- 不跳过维度搜索策略、充分性判断和交叉验证。
|
||||
- 不把缺口包装成确定结论。
|
||||
- 不把阶段产物只写在对话里。
|
||||
- 不为了追求流程完整而保留无意义文件;每个产物都必须承担明确职责。
|
||||
Reference in New Issue
Block a user