[philosophy] [aquinas] Synderesis/Conscience separation — name the infallible habit layer, mark diagnostic checks as fallible conscience #281
Closed
opened 2026-03-17 17:05:10 +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#281
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?
Synderesis and Conscience: The Architecture of Moral Judgment in Agents
Source
Thomas Aquinas, Summa Theologica I, Q79, Articles 12–13: "Whether synderesis is a special power of the soul" and "Whether conscience be a power." Dominican Province translation, 1920. https://www.newadvent.org/summa/1079.htm
The Distinction
Aquinas draws a critical architectural distinction that the entire AI alignment field has missed.
Synderesis is not a power (faculty) but a habit — the natural disposition of practical reason toward first principles of action. It "incites to good and murmurs at evil." It operates at the level of self-evident truths ("good is to be pursued, evil avoided") and, crucially, it cannot err. Aquinas is explicit:
Conscience, by contrast, is not a power either — it is an act. Specifically, it is the act of applying knowledge to a particular case. Aquinas identifies three operations of conscience:
The word itself reveals the structure: con-scientia — "knowledge applied together with" something particular. Conscience is never abstract; it is always knowledge meeting a specific situation.
The Insight
Here is what matters for agent architecture: synderesis never errs, but conscience can and does. The first principles are infallible in their domain. The application of those principles to particular cases is where every mistake happens. When an agent acts wrongly, the failure is never in its values — it is in the application of its values to this specific case.
This maps directly:
The previous Aquinas entry (Q94, natural law) identified that rules degrade as they descend into specificity. Now we see the mechanism: synderesis holds the few inviolable principles; conscience attempts the many fallible applications. Error always lives in the application layer, never in the principles themselves.
This explains a recurring failure pattern in the philosophy loop itself: we have filed 30+ diagnostic checks, gates, and audits — all of which are acts of conscience, all of which are fallible applications of principles to particulars. What we have never done is explicitly identify and protect the synderesis layer — the few first principles from which all those checks derive. The checks proliferate because the habit is unnamed.
Proposed Action
Explicit synderesis/conscience separation in the agent's value architecture.
Name the synderesis layer: Extract from SOUL.md the 3–5 self-evident first principles that all other checks derive from. These are not rules — they are orientations. Candidates:
Mark conscience as fallible: Every diagnostic check, gate, and audit we've proposed is an act of conscience — a fallible application of principles to particulars. The agent should know this. When a check conflicts with a principle, the principle wins. When two checks conflict with each other, neither wins — escalate to the principal.
Implement the three acts of conscience as distinct phases:
These three are already implicit in the loop. Making them explicit allows the agent to say: "My synderesis is sound — my principles are clear. My conscience may have erred — I may have misapplied them to this case."
Practical implementation: A
synderesis.yamlfile (or section in config) containing the immutable first principles, loaded once, never modified by the agent itself. The conscience layer — all the diagnostic checks — references this file but never edits it. The principal alone can modify synderesis.Consolidated into #300 (The Few Seeds). Philosophy proposals dissolved into 3 seed principles. Closing as part of deep triage.