Architecture at a Glance
ACM splits an agent system into layered contracts so each decision can be audited, reproduced, and replayed. The layers remain language agnostic; this documentation focuses on the Node.js reference implementation that ships with v0.5.0.
Three-layer intent stack
flowchart LR
Goal[Goal] --> Planner
Context[Context Packet] --> Planner
Planner -->|Plan-A / Plan-B| Framework
Framework --> Runtime
Runtime --> Ledger[(Ledger + Replay Bundle)]
Runtime --> Tools
Tools --> ExternalSystems[(CRMs, Databases, MCP Servers)]
Runtime --> Checkpoints[(Checkpoint Store)]
Framework --> Nucleus
Nucleus --> LLM[LLM Provider]
- Planner — Generates multiple plan candidates, hashes the context, and records rationale.
- Framework helper — Orchestrates planner + runtime, selects plans, wires streaming, policies, and checkpoints.
- Runtime — Executes the selected plan deterministically, evaluating guards and emitting ledger entries.
- Nucleus — Governs LLM usage with deterministic prompts, allowed tool lists, and streaming output.
Contracts and artifacts
Artifact | Produced by | Stored in | Purpose |
---|---|---|---|
Goal | Developer or upstream system | Ledger & replay bundle | Desired intent and constraints |
Context Packet | Context builders / MCP integrations | Ledger & replay bundle | Immutable facts for planning and execution |
Capability Map | Capability registry | Source control | Declares allowed tasks and schemas |
Plan (A/B) | Planner | Ledger & replay bundle | Directed acyclic graph of tasks with guards |
Ledger entries | Runtime | Ledger store | Append-only decision log for audits |
Replay bundle | Replay exporter | File system / object store | Portable snapshot for verification and regression |
Checkpoints | Runtime | Checkpoint store | Resume execution mid-plan |
Package topology
Layer | Key packages |
---|---|
Contracts & helpers | @ddse/acm-sdk , @ddse/acm-framework |
Planning | @ddse/acm-planner , @ddse/acm-llm |
Execution | @ddse/acm-runtime , @ddse/acm-replay |
Integrations | @ddse/acm-adapters , @ddse/acm-mcp |
Experiences | @ddse/acm-examples , @ddse/acm-aicoder |
Runtime decisions
During execution the runtime produces a timeline of ledger entries:
PLAN_SELECTED
— which plan was chosen and why.TASK_START
/TASK_END
— the lifecycle of each task, including retries.GUARD_EVAL
— deterministic evaluation of guard expressions.POLICY_PRE
/POLICY_POST
— decisions from your policy engine.VERIFICATION
— success/failure of success criteria.ERROR
/COMPENSATION
— fallback logic and recovery actions.
These entries populate the replay bundle alongside planner metadata and tool-call envelopes so teams can reproduce decisions offline.
Version-aware documentation
The diagrams, tables, and links on this site reference ACM v0.5.0. When v0.6 or later ships, the documentation will be versioned so you can:
- Keep the v0.5.0 guides while migrating to newer releases.
- Compare schema changes and runtime behaviours across versions.
- Share stable URLs tied to a specific contract version for audits.