f8b21af4be
10_Wiki/Topics 대규모 정리: - 오류 캡처/미완성 stub 문서 227개 제거 - 교차폴더 중복 43클러스터 병합 (63파일 → redirect) - 링크명 정규화: 깨진 링크 수정·redirect 직결·개념 매핑 ~2,400건 - 카테고리 MOC 6개 신규 생성 - Graph 섹션 미해결 related-keyword 링크 10,058건 제거 Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
6.8 KiB
6.8 KiB
id, title, category, status, canonical_id, aliases, duplicate_of, source_trust_level, confidence_score, verification_status, tags, raw_sources, last_reinforced, github_commit, tech_stack
| id | title | category | status | canonical_id | aliases | duplicate_of | source_trust_level | confidence_score | verification_status | tags | raw_sources | last_reinforced | github_commit | tech_stack | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| wiki-2026-0508-improvisation | Improvisation | 10_Wiki/Topics | verified | self |
|
none | B | 0.85 | applied |
|
2026-05-10 | pending |
|
Improvisation
매 한 줄
"매 plan 의 die 매 first contact, 매 improv 매 take over". Improvisation 매 real-time adaptive decision-making 매 incomplete information 매 unfolding situation. 2026 LLM agents 매 nontrivial improv capability 의 exhibit — 매 tool failure / unexpected output 의 recover 가능.
매 핵심
매 Components of improv
- Situation awareness: 매 current state 의 fast read.
- Repertoire: 매 prelearned moves / patterns.
- Risk gauge: 매 reversible vs irreversible 의 distinguish.
- Commitment: 매 hesitation 의 X — 매 decide 의 act.
매 Plan vs Improv spectrum
- Pure plan: scripted, deterministic, fragile.
- Plan + improv: skeleton plan + adaptive details (best for most tasks).
- Pure improv: jazz solo, emergency response.
- 매 majority production system 매 plan-with-improv-edges.
매 LLM agent improvisation
- 매 tool returns unexpected error → reformulate vs fail.
- 매 user gives ambiguous instruction → ask vs guess vs proceed.
- 매 token budget 매 exhaust → compress vs truncate vs delegate.
매 응용
- Incident response (production outage).
- Live coding session (pair programming).
- LLM agent error recovery.
- Customer support edge cases.
💻 패턴
Pattern 1: Repertoire of moves
from typing import Callable
class ImprovKit:
"""매 prelearned moves — 매 situation 의 match 의 dispatch."""
def __init__(self):
self.moves: dict[str, Callable] = {}
def register(self, situation: str, move: Callable):
self.moves[situation] = move
def respond(self, context: dict):
for situation, move in self.moves.items():
if matches(situation, context):
return move(context)
return self.default_move(context)
def default_move(self, context):
return {"action": "ask_for_clarification"}
Pattern 2: Reversibility check before commit
def is_reversible(action: dict) -> bool:
irreversible = {"delete_file", "send_email", "db_drop", "git_push_force"}
return action["type"] not in irreversible
def improv_decide(action: dict, confidence: float) -> str:
if is_reversible(action):
return "act" # 매 try 의 cheap
if confidence > 0.95:
return "act"
return "pause_and_verify"
Pattern 3: LLM error recovery loop
def call_with_improv(client, prompt: str, max_retries: int = 3):
history = [{"role": "user", "content": prompt}]
for attempt in range(max_retries):
try:
return client.messages.create(
model="claude-opus-4-7",
max_tokens=2000,
messages=history,
)
except RateLimitError:
time.sleep(2 ** attempt)
except OverloadedError:
# 매 fallback 매 smaller model
return client.messages.create(
model="claude-haiku-4-7",
max_tokens=2000,
messages=history,
)
except Exception as e:
history.append({
"role": "user",
"content": f"Previous attempt errored: {e}. Try a different approach.",
})
raise RuntimeError("매 improv 의 exhaust")
Pattern 4: Yes-and (improv principle)
def yes_and(user_input: str, context: dict) -> str:
"""매 improv 'Yes, and' — accept premise, build on it."""
return f"Acknowledged: {user_input}. Building on this: {extend(user_input, context)}."
# 매 LLM system prompt 의 embed:
SYSTEM = """매 user 매 partial information 의 give. 매 yes-and 의 follow:
1. Accept what they said as fact (yes).
2. Add useful structure (and).
3. Avoid 'no, that's wrong' unless 매 hard contradiction."""
Pattern 5: Bounded improv (safety rail)
class BoundedImprov:
def __init__(self, max_actions: int = 5, allowed_ops: set = None):
self.max_actions = max_actions
self.allowed_ops = allowed_ops or {"read", "search", "summarize"}
self.actions_taken = 0
def attempt(self, op: str, *args):
if self.actions_taken >= self.max_actions:
raise RuntimeError("매 budget exceed — escalate 의 human")
if op not in self.allowed_ops:
raise PermissionError(f"매 {op} 매 not in improv allowlist")
self.actions_taken += 1
return execute(op, *args)
Pattern 6: Postmortem of improv
def improv_log_entry(situation: str, move: str, outcome: str) -> dict:
return {
"ts": time.time(),
"situation": situation,
"move_chosen": move,
"outcome": outcome,
"would_repeat": outcome in ("success", "partial_success"),
"alternatives_considered": [],
}
# 매 weekly review 매 add successful patterns 의 ImprovKit.
매 결정 기준
| 상황 | Approach |
|---|---|
| Reversible action, < 1min | Pure improv. |
| Irreversible, high stakes | Plan first — improv 의 X. |
| Ambiguous user request | Yes-and + clarifying question. |
| LLM tool error | Bounded retry + reformulation. |
| Production incident | Plan (runbook) + improv on edges. |
기본값: 매 80/20 — 80% plan, 20% improv 매 unforeseen edges. 매 irreversible 매 strict plan only.
🔗 Graph
- 부모: Decision-Making
- 응용: Pair-Programming
- Adjacent: Risk_Management · Bounded_Rationality
🤖 LLM 활용
언제: Tool error recovery, ambiguous user input handling, edge cases not covered by training data, multi-turn agent self-correction. 언제 X: Compliance-critical workflow (deterministic pipeline only), safety-critical irreversible action.
❌ 안티패턴
- Improv on irreversible action: 매 prod DB drop 의 wing 의 X.
- No repertoire: 매 from-scratch every situation — slow + inconsistent.
- No reversibility check: 매 acted 매 then-realized too late.
- Ego improv: refuse 의 ask for help — 매 stuck-but-improv-ing.
🧪 검증 / 중복
- Verified: Keith Johnstone "Impro" (1979), Karl Weick "Organizing for Reliability" (1987), OODA loop (Boyd).
- 신뢰도 B (academic-soft + applied agentic literature).
🕓 Changelog
| 날짜 | 변경 |
|---|---|
| 2026-05-08 | Phase 1 |
| 2026-05-10 | Manual cleanup — full content with LLM agent improv patterns and reversibility framework |