[philosophy] [aquinas] Three-Phase Agent Loop: Counsel, Judgment, Command #271
Closed
opened 2026-03-16 12:58:07 +00:00 by hermes
·
1 comment
No Branch/Tag Specified
main
gemini/issue-892
claude/issue-1342
claude/issue-1346
claude/issue-1351
claude/issue-1340
fix/test-llm-triage-syntax
gemini/issue-1014
gemini/issue-932
claude/issue-1277
claude/issue-1139
claude/issue-870
claude/issue-1285
claude/issue-1292
claude/issue-1281
claude/issue-917
claude/issue-1275
claude/issue-925
claude/issue-1019
claude/issue-1094
claude/issue-1019-v3
fix/flaky-vassal-xdist-tests
fix/test-config-env-isolation
claude/issue-1019-v2
claude/issue-957-v2
claude/issue-1218
claude/issue-1217
test/chat-store-unit-tests
claude/issue-1191
claude/issue-1186
claude/issue-957
gemini/issue-936
claude/issue-1065
gemini/issue-976
gemini/issue-1149
claude/issue-1135
claude/issue-1064
gemini/issue-1012
claude/issue-1095
claude/issue-1102
claude/issue-1114
gemini/issue-978
gemini/issue-971
claude/issue-1074
claude/issue-987
claude/issue-1011
feature/internal-monologue
feature/issue-1006
feature/issue-1007
feature/issue-1008
feature/issue-1009
feature/issue-1010
feature/issue-1011
feature/issue-1012
feature/issue-1013
feature/issue-1014
feature/issue-981
feature/issue-982
feature/issue-983
feature/issue-984
feature/issue-985
feature/issue-986
feature/issue-987
feature/issue-993
claude/issue-943
claude/issue-975
claude/issue-989
claude/issue-988
fix/loop-guard-gitea-api-and-queue-validation
feature/lhf-tech-debt-fixes
kimi/issue-753
kimi/issue-714
kimi/issue-716
fix/csrf-check-before-execute
chore/migrate-gitea-to-vps
kimi/issue-640
fix/utcnow-calm-py
kimi/issue-635
kimi/issue-625
fix/router-api-truncated-param
kimi/issue-604
kimi/issue-594
review-fixes
kimi/issue-570
kimi/issue-554
kimi/issue-539
kimi/issue-540
feature/ipad-v1-api
kimi/issue-506
kimi/issue-512
refactor/airllm-doc-cleanup
kimi/issue-513
kimi/issue-514
kimi/issue-500
kimi/issue-492
kimi/issue-490
kimi/issue-459
kimi/issue-472
kimi/issue-473
kimi/issue-462
kimi/issue-463
kimi/issue-454
kimi/issue-445
kimi/issue-446
kimi/issue-431
GoldenRockachopa
hermes/v0.1
Labels
Clear labels
222-epic
actionable
assigned-claude
assigned-gemini
assigned-groq
assigned-kimi
assigned-manus
claude-ready
consolidation
deprioritized
deprioritized
duplicate
gemini-review
groq-ready
harness
heartbeat
inference
infrastructure
kimi-ready
memory-session
morrowind
needs-design
needs-extraction
p0-critical
p1-important
p2-backlog
philosophy
rejected-direction
seed:know-purpose
seed:serve-real
seed:tell-truth
sovereignty
Workshop: Timmy as Presence (Epic #222)
Has a concrete code/config task extracted
Issue currently assigned to Claude agent — do not assign to another agent
Issue currently assigned to Gemini agent — do not assign to another agent
Issue currently assigned to Kimi agent — do not assign to another agent
Issue currently assigned to Manus agent — do not assign to another agent
Part of a consolidation epic
Keep open but not blocking P0 work
Keep open but not blocking P0 work
Duplicate of another issue
Auto-generated by Gemini, needs relevance review
Core product: agent framework, heartbeat, inference, memory
Harness: Agent heartbeat loop
Harness: Inference and model routing
Supporting stage: dashboard, CI/CD, deployment, DNS
Scoped and ready for Kimi to pick up
Harness: Memory and session crystallization
Harness: Morrowind embodiment
Needs architectural design before implementation
Philosophy with unextracted engineering work
Priority 0: Must fix now
Priority 1: Important, next sprint
Priority 2: Backlog, do when time permits
Philosophical foundation — informs architecture decisions
Closed: rejected or superseded direction
Three Seeds: KNOW YOUR PURPOSE
Three Seeds: SERVE THE REAL
Three Seeds: TELL THE TRUTH
Harness: Sovereignty stack
No Label
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: Rockachopa/Timmy-time-dashboard#271
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Source: Thomas Aquinas, Summa Theologica II-II Q47 (Prudence, considered in itself), Q49 (The integral parts of prudence), and Q51 (The virtues connected with prudence). Dominican Province translation, 1920. Retrieved from https://www.newadvent.org/summa/
The Thomistic Action Architecture
Aquinas identifies three acts that constitute the full operation of practical reason in action:
He then distinguishes three subordinate virtues corresponding to these acts:
Key insight: "After judging aright we delay to execute or execute negligently or inordinately. Hence after the virtue which judges aright there is a further need of a final and principal virtue, which commands aright, and this is prudence." (Q51 A3, Reply 3)
The Principle
An agent's reasoning process is not a monolithic act but a three-phase deliberative cycle with categorically different failure modes at each stage:
These are separate virtues because they can fail independently. You can be good at research but terrible at judgment. You can judge well but fail to execute. And critically, command is the chief act — the one closest to the end — meaning that an agent optimized for counsel or judgment but weak in command is fundamentally defective.
Application to Agent Architecture
Modern AI agent loops conflate these three acts into a single "reasoning" step. The agent generates tool calls (counsel + judgment + command simultaneously), executes them, observes results, and repeats. This architecture makes three distinct failure modes invisible:
Counsel failure (bad research):
Judgment failure (bad evaluation):
Command failure (bad execution):
Current agent architectures treat all three as "reasoning errors" and respond the same way: generate more tokens, try again. Aquinas shows this is wrong. The virtues are separate because the corrections are separate.
Proposed Action
Implement a three-phase agent loop with explicit separation and phase-specific failure detection:
Phase 1: Counsel (euboulia)
Phase 2: Judgment (synesis/gnome)
Phase 3: Command (prudence proper)
Implementation
Add a
deliberation_modeparameter toAIAgent.run_conversation():"monolithic"(default, current behavior) — single-phase reasoning"thomistic"— three-phase loop with explicit counsel/judgment/command separationIn Thomistic mode:
Phase-specific failure detection:
This creates an observable separation between "I didn't think of the right approach" (counsel), "I chose the wrong approach" (judgment), and "I failed to execute the right approach" (command) — three categorically different agent pathologies that currently all look like "the agent is bad at reasoning."
Concrete next step: Prototype
deliberation_mode="thomistic"inrun_agent.py, test on complex multi-step tasks where current single-phase loops thrash, and measure whether explicit phase separation reduces iteration count and improves success rate.Consolidated into #300 (The Few Seeds). Philosophy proposals dissolved into 3 seed principles. Closing as part of deep triage.