"매 큰 그림 → 매 세부". 매 system 의 high-level abstraction 부터 시작 → 매 단계마다 decomposition. 매 1970s Niklaus Wirth 의 stepwise refinement 가 origin — 매 modern 2026 microservice / DDD 의 strategic design 까지 매 살아있는 design heuristic.
매 핵심
매 핵심 idea
매 추상 → 매 구체: System 전체 → subsystems → modules → functions → lines.
매 deferred decision: Lower-level detail 의 결정 의 미루기 — 매 abstraction barrier.
매 wishful thinking: 매 "이 helper 가 있다 가정" → 매 나중에 implement.
매 vs Bottom-Up
Top-Down: 매 unknown / new system 의 design 적합. 매 risk: leaf-level 에서 매 mismatch 발견.
Bottom-Up: 매 reusable primitive 부터. 매 known domain (e.g. data pipeline) 적합.
defrender_dashboard(user_id:str)->HTML:user=fetch_user(user_id)# assumemetrics=compute_metrics(user)# assumechart=build_chart(metrics)# assumereturnlayout(header(user),chart)# assume# 매 implement leaves 의 last.
DDD top-down decomposition
Bounded Context: Order Management
├─ Aggregate: Order
│ ├─ Entity: OrderLine
│ └─ Value Object: Money, Address
├─ Aggregate: Cart
└─ Domain Service: Pricing
deftest_charge_order_calls_gateway(mocker):gateway=mocker.Mock()repo=mocker.Mock()svc=OrderService(gateway,repo)# 매 collaborator 추측svc.charge(Order(id=1,total=100))gateway.charge.assert_called_once_with(100)# 매 mock 의 design 의 driver — 매 collaborator interface 의 top-down emerge.
언제: 매 새로운 system 의 design 의 시작, 매 unknown domain 의 explore, 매 architectural conversation 의 frame.
언제 X: 매 well-known primitive 의 mechanical assembly, 매 retrofit / legacy refactor (seam-first 가 더 안전).
❌ 안티패턴
Pseudocode 가 implementation 화: 매 leaf 의 implement 안 함. 매 wishful 의 영원히 wish.
Premature decomposition: 매 너무 일찍 fix layer boundary → 매 나중에 leaky.
No bottom check: 매 leaf primitive 가 매 expressible 인지 verify 안 함 → 매 mismatch.
🧪 검증 / 중복
Verified (Wirth 1971 "Program Development by Stepwise Refinement"; Evans DDD 2003).
신뢰도 A.
🕓 Changelog
날짜
변경
2026-05-08
Phase 1
2026-05-10
Manual cleanup — top-down 의 stepwise refinement / wishful thinking / DDD-microservice 의 application