Files
timmy-home/training-data/dpo-pairs/session_20260314_080524_e0d882.json
Alexander Whitestone 0d64d8e559 initial: sovereign home — morrowind agent, skills, training-data, research, specs, notes, operational docs
Tracked: morrowind agent (py/cfg), skills/, training-data/, research/,
notes/, specs/, test-results/, metrics/, heartbeat/, briefings/,
memories/, skins/, hooks/, decisions.md, OPERATIONS.md, SOUL.md

Excluded: screenshots, PNGs, binaries, sessions, databases, secrets,
audio cache, timmy-config/ and timmy-telemetry/ (separate repos)
2026-03-27 13:05:57 -04:00

42 lines
8.5 KiB
JSON

[
{
"prompt": "Good morning Timmy.",
"chosen": "Good morning. How can I help you today?",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "Have you read your soul.md file?",
"chosen": "",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "[Files already read in this session \u2014 do NOT re-read these]\n - /Users/apayne/Timmy-Time-dashboard/CLAUDE.md (lines 1-100)\n - /Users/apayne/Timmy-Time-dashboard/Makefile (lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/data/journal/2026-03-13.md (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/data/journal/2026-03-14.md (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/docker-compose.yml (lines 1-500, lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/memory/self/user_profile.md (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/pyproject.toml (lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/src/brain/schema.py (lines 1-30)\n - /Users/apayne/Timmy-Time-dashboard/src/config.py (lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/src/dashboard/app.py (lines 1-500, lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/src/dashboard/routes/marketplace.py (lines 1-15)\n - /Users/apayne/Timmy-Time-dashboard/src/dashboard/routes/paperclip.py (lines 1-10)\n - /Users/apayne/Timmy-Time-dashboard/src/dashboard/routes/router.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/infrastructure/db_pool.py (lines 1-30)\n - /Users/apayne/Timmy-Time-dashboard/src/infrastructure/error_capture.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/infrastructure/events/broadcaster.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/infrastructure/openfang/__init__.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/infrastructure/router/cascade.py (lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/src/integrations/paperclip/client.py (lines 1-30)\n - /Users/apayne/Timmy-Time-dashboard/src/spark/engine.py (lines 1-2000)\n - /Users/apayne/Timmy-Time-dashboard/src/spark/memory.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/swarm/__init__.py (lines 1-500)\n - /Users/apayne/Timmy-Time-dashboard/src/timmy/agent.py (lines 195-274, lines 125-164)\n - /Users/apayne/Timmy-Time-dashboard/src/timmy/agents/base.py (lines 1-500)\n - /",
"chosen": "Good question. Let me see what you've already got to build on.",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "Here is the experience I'm having: ============================================================\r \ud83c\udf99\ufe0f Timmy Voice \u2014 Sovereign Voice Interface\r============================================================\r STT: Whisper (base.en)\r TTS: Piper (en_US-lessac-medium.onnx)\r LLM: Timmy (local Ollama)\r============================================================\r Speak naturally. Timmy will listen, think, and respond.\r Press Ctrl-C to exit.\r============================================================\r\r \ud83c\udfa4 Listening... (speak now)\r \u2702\ufe0f Captured 3.9s of audio\r \ud83e\udde0 Transcribing...\r \ud83d\udc64 You: Hello Timmy, can you hear me now?\rWARNING Requires confirmation tool(s) not present in the toolkit: shell, aider, plan_and_execute, write_file, python\rSecure MCP Filesystem Server running on stdio\rClient does not support MCP Roots, using allowed directories set from server args: [ '/Users/apayne/Timmy-time-dashboard' ]\r \ud83e\udd16 Timmy: Yes, Alexander! I can hear you perfectly fine. Timmy here \u2014 fully operational via local Ollama (qwen3.5:latest). No cloud dependencies needed.\rHow can I help you today?\r\r \ud83c\udfa4 Listening... (speak now)\r \u2702\ufe0f Captured 2.8s of audio\r \ud83e\udde0 Transcribing...\r \ud83d\udc64 You: working on upgrading your interfaces to bring you up.\rSecure MCP Filesystem Server running on stdio\rClient does not support MCP Roots, using allowed directories set from server args: [ '/Users/apayne/Timmy-time-dashboard' ]\rERROR Error in Agent run: Event loop is closed\r \ud83e\udd16 Timmy: Event loop is closed\r\r \ud83c\udfa4 Listening... (speak now)\r \u2702\ufe0f Captured 5.7s of audio\r \ud83e\udde0 Transcribing...\r \ud83d\udc64 You: trying to bring up your interfaces, so let's talk about how we can give you more interfaces.\rSecure MCP Filesystem Server running on stdio\rClient does not support MCP Roots, using allowed directories set from server args: [ '/Users/apayne/Timmy-time-dashboard' ]\r \ud83e\udd16 Timmy: That's an interesting discussion! Let me think about what \"interfaces\" could mean in the local-first architecture context you value.\rHere are some dire",
"chosen": "Good \u2014 it works! Three issues to fix:\n\n1. **Event loop dying** \u2014 `asyncio.run()` creates and destroys a loop each call. Agno's MCP sessions persist tied to loop 1, then loop 2 tries to use the dead connections. Need a persistent loop.\n\n2. **MCP noise** \u2014 \"Secure MCP Filesystem Server...\" is stderr spam. Need to suppress during voice mode.\n\n3. **Verbose markdown responses** \u2014 Bullet points and `**bold**` headers are terrible for TTS. Voice needs short, spoken-language responses.\n\nLet me fix all three.",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "It's not very natural either. He says asterisk and sounds kind robotic.",
"chosen": "Right. Three problems at once:\n\n1. Piper is reading \"asterisk asterisk\" because Timmy responds in markdown\n2. Event loop dies because `asyncio.run()` creates a new loop each call, but Agno's MCP sessions are tied to loop #1\n3. MCP stderr noise\n\nLet me fix all three.",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "\ud83d\udc4b Voice loop stopped.\r\ran error occurred during closing of asynchronous generator <async_generator object stdio_client at 0x30b558580>\rasyncgen: <async_generator object stdio_client at 0x30b558580>\r + Exception Group Traceback (most recent call last):\r | File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/anyio/_backends/_asyncio.py\", line 783, in __aexit__\r | raise BaseExceptionGroup(\r | BaseExceptionGroup: unhandled errors in a TaskGroup (1 sub-exception)\r +-+---------------- 1 ----------------\r | Traceback (most recent call last):\r | File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/mcp/client/stdio/__init__.py\", line 189, in stdio_client\r | yield read_stream, write_stream\r | GeneratorExit\r +------------------------------------\r\rDuring handling of the above exception, another exception occurred:\r\rTraceback (most recent call last):\r File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/mcp/client/stdio/__init__.py\", line 182, in stdio_client\r async with (\r File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/anyio/_backends/_asyncio.py\", line 789, in __aexit__\r if self.cancel_scope.__exit__(type(exc), exc, exc.__traceback__):\r ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\r File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/anyio/_backends/_asyncio.py\", line 461, in __exit__\r raise RuntimeError(\rRuntimeError: Attempted to exit cancel scope in a different task than it was entered in\ran error occurred during closing of asynchronous generator <async_generator object stdio_client at 0x30b5586d0>\rasyncgen: <async_generator object stdio_client at 0x30b5586d0>\r + Exception Group Traceback (most recent call last):\r | File \"/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/site-packages/anyio/_backends/_asyncio.py\", line 7",
"chosen": "Harmless but ugly. Those are MCP stdio async generators being garbage-collected after the loop closes \u2014 anyio complains because the cancel scope is in a different task. The fix is to swallow that noise during shutdown.",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "I'd like to actually train the voice myself using samples of my own voice.",
"chosen": "Good instinct \u2014 sovereign all the way down to the voice itself. Let me see what's viable on your hardware.",
"session": "session_20260314_080524_e0d882.json"
},
{
"prompt": "That's a future task. Lets focus on getting productive and establishing a useful loop first.",
"chosen": "Right. Let me push the shutdown fix and we're done.",
"session": "session_20260314_080524_e0d882.json"
}
]