Дата: 2026-04-01 Автор: Coordinator (AI) Статус: 🔵 HL — Обновлён по результатам RESEARCH
RESEARCH stage (TFW-11) работает, но взаимодействие агента с пользователем недостаточно управляемо и прозрачно. Агент запускает стейджи слишком автономно: проводит Gather, задаёт 3 вопроса, сразу переходит к Extract — без явного перехода, без плана, без возможности пользователю повлиять на направление исследования.
Ключевая мысль: Research существует для уточнения HL — плана, фаз, целей, ценностей. Его основной выход — обновлённый HL, а не прыжок в TS.
Пользователь хочет:
| Аспект | Состояние |
|---|---|
| Вход в research | Плоский: пользователь говорит «переходим» → агент сразу начинает первый стейдж |
| Plan preview | Нет. Агент не объясняет, что он собирается исследовать |
| Переходы между стейджами | Формальный checkpoint: findings + 3 вопроса → сразу в следующий стейдж |
| Роль пользователя перед стейджем | Реактивная — отвечает на вопросы, но не направляет |
| Темп | Слишком быстрый — стейджи проскакивают без ощущения глубины |
| Наводящие вопросы | Агент задаёт вопросы ПО итогам стейджа, но не ДО начала |
| Завершение research | Неявное — агент говорит «достаточно для TS», сразу идёт писать TS |
| HL update | Не предусмотрен — HL остаётся как было, даже если research раскрыл новые факты |
| Цикличность | Формально заложена (pass 2+), но нет явного self-check «хватит ли нам?» |
1. Пользователь: «переходим к research»
2. Агент: [выполняет Gather автономно] → «Вот findings. 3 вопроса.»
3. Пользователь: [отвечает]
4. Агент: [выполняет Extract автономно] → «Вот findings. 3 вопроса.»
5. ...
| Аспект | Целевое состояние |
|---|---|
| Вход в research | Briefing — агент представляет план исследования, спрашивает о пожеланиях |
| Plan preview | Обязателен. Короткий план: что ищем, зачем, какие цели по каждому стейджу |
| Переходы между стейджами | Stage Handoff — после checkpoint агент предлагает план на следующий стейдж, спрашивает пожелания |
| Роль пользователя | Активная — направляет, дополняет, корректирует фокус |
| Темп | Пользователь контролирует скорость — явные точки «погружаюсь» / «давай дальше» |
| Наводящие вопросы | Агент задаёт ДО И ПОСЛЕ каждого стейджа |
| Завершение research | Closure Protocol — явный итог: что зафиксировано, обновление HL, подтверждение перехода к TS |
| HL update | Обязательный — research уточняет HL (фазы, подход, зависимости). HL обновляется ВСЕГДА перед TS |
| Цикличность | Sufficiency Check — после каждого прохода агент явно оценивает: «хватит ли для финализации HL?» |
┌─────────────────────────────────────────────────────────────┐
│ RESEARCH CYCLE │
│ │
│ BRIEFING ──→ Gather ──→ Extract ──→ Challenge │
│ ↑ (checkpoint + stage handoff between each) │
│ │ │ │
│ │ SUFFICIENCY CHECK │
│ │ │ │ │
│ │ Нет ─┘ Да ──┘ │
│ │ │ │ │
│ └──── новый pass ◄──────────────┘ CLOSURE │
│ │ │
│ Обновить HL │
│ │ │
│ User confirms │
│ │ │
│ → TS │
└─────────────────────────────────────────────────────────────┘
1. Пользователь: «переходим к research»
2. Агент: BRIEFING
- «Вот что я собираюсь исследовать и зачем: [план по стейджам]»
- «Есть ли у вас мысли, пожелания, приоритеты?»
- «Что точно не нужно трогать?»
- 🛑 WAIT
3. Пользователь: [даёт направление]
4. Агент: [выполняет Gather с учётом briefing]
5. Агент: CHECKPOINT Gather
- Findings + вопросы
- STAGE HANDOFF: «Для Extract планирую: [план]. Мысли?»
- 🛑 WAIT
6. ... (Extract, Challenge — аналогично)
7. Агент: SUFFICIENCY CHECK
- «Хватит ли для финализации HL? Вот что я вижу: [оценка].»
- Если нет → новый pass (цикл к Gather с BRIEFING на новый pass)
- Если да → CLOSURE PROTOCOL
8. Агент: CLOSURE PROTOCOL
- Итог: что зафиксировано, какие решения приняты
- Обновляет HL: фазы, подход, зависимости, риски
- Показывает diff HL пользователю
- «HL обновлён. Переходим к TS?»
- 🛑 WAIT
9. Пользователь: [подтверждает / корректирует]
10. → TS пишется по обновлённому HL
Briefing — это NOT стейдж. Это протокол входа в RESEARCH. Может длиться несколько turns (раундов вопрос-ответ).
Содержание:
Turn-based ритм: ≤3 вопросов за один turn (раунд). Briefing и каждый стейдж могут длиться несколько turns. Turn = один раунд вопрос-ответ, не рестарт.
Stage Handoff встроен в checkpoint. После findings и вопросов по текущему стейджу, агент добавляет:
Это НЕ отдельный шаг, а расширение checkpoint.
Closure Protocol — это протокол выхода из RESEARCH. Происходит когда Sufficiency Check = «достаточно».
Содержание:
HL обновляется всегда. Research-агент пишет рекомендации в Closure секции RES, coordinator применяет их к HL. Это основной выход research.
Отдельный агент (рекомендация): Research рекомендуется запускать в отдельной сессии (
/tfw-research). Research-агент пишет RES → coordinator читает RES → обновляет HL → user confirms → TS.
Sufficiency Check — это самооценка агента после каждого полного прохода (pass) через стейджи. Агент должен честно ответить на вопрос:
«Достаточно ли информации для финализации HL? Можем ли мы уверенно зафиксировать фазы, подход и зависимости?»
Это не checkpoint для пользователя, а внутренний вопрос агента, результат которого он озвучивает пользователю вместе с рекомендацией: закрыть research или начать ещё один pass.
Проверяет:
5 файлов, одна фаза. Структура: 2 новых элемента + 2 расширения + 1 фикс (подтверждено RESEARCH).
research.mdRES.md templateplan.md.claude/commands/tfw-research.md — синхронизация с research.md (briefing, closure, turn-based).agent/workflows/tfw-research.md — синхронизация с research.md (briefing, closure, turn-based)Не меняем: стейджи, лимиты, Entry Modes, Role Lock, статусы. Это фикс UX, а не переделка процесса.
research.md: Briefing Protocol с turn-based ритмом (≤3 per turn)research.md: Checkpoint расширен Stage Handoffresearch.md: Closure Protocol (рекомендации к HL)research.md: Sufficiency Check = «хватит для финализации HL?»research.md: Hard Rules + Anti-patterns (briefing skip, rush-bias, skip-bias и т.д.)RES.md: секции Briefing и Closure (якоря)plan.md: Phase 3.5 gate (RES → update HL → confirm → TS)plan.md: skip-bias fix (pros/cons, user decides).claude/commands/tfw-research.md: синхронизация.agent/workflows/tfw-research.md: синхронизацияПри провале: упростить до минимума: briefing = план + 1 вопрос; closure = итог + «к TS?».
| Зависимость | Статус |
|---|---|
research.md (TFW-11) актуален |
✅ |
RES.md template актуален |
✅ |
plan.md актуален |
✅ |
.claude/commands/tfw-research.md актуален |
✅ |
.agent/workflows/tfw-research.md актуален |
✅ |
| PROJECT_CONFIG.yaml | Без изменений |
| Риск | Вероятность | Влияние | Mitigation |
|---|---|---|---|
| Briefing добавляет ещё одну остановку, которую пользователь начнёт пропускать | Низкая | Средняя | Briefing = 1 сообщение (план + 1-3 вопроса), не отдельный раунд Q&A |
| Stage Handoff раздувает checkpoint | Низкая | Низкая | 2 строки: «Планирую дальше: X. Есть мысли?» |
| Агент игнорирует briefing (не все модели следуют) | Средняя | Средняя | Hard Rule + Anti-pattern + пример в workflow |
| HL Update Gate — агент всегда говорит «HL ok» по инерции | Средняя | Высокое | Конкретный вопрос: «Что именно изменилось? Фазы? Подход? Зависимости?» |
| Closure Protocol удлиняет процесс | Низкая | Низкая | Это 1 сообщение, не отдельный раунд |
| Sufficiency Check — агент всегда отвечает «достаточно» | Средняя | Среднее | Обязательно указать конкретику: что именно ясно, что нет |
RESEARCH confirmed (2026-04-01): Live session reproduced all identified problems. 5 protocols simplified to 2+2+1. Scope expanded to 5 files. See RES.
| *HL — TFW-14: Research Interaction Model | 2026-04-01 (updated after RESEARCH)* |