Generated: 2026-05-31 18:07:05Z
Scope
- Manual spot-check battery: 5 prompts per tool across 12 Athena tools (60 total A/B pairs)
- Base model:
Qwen/Qwen3.5-4B
- Tuned adapter:
D:\temp\memorysmith-training\runs\distilled-all-cat-20260531-v7-clean-baseline\adapter
- Raw results JSON:
Data/Pages/research/training/tool-ab-spotcheck-20260531-v7-clean-baseline.data.json
Headline Metrics
| Metric |
Base |
Tuned |
Delta |
| Envelope valid |
0/60 (0.0%) |
24/60 (40.0%) |
+24 |
| Expected tool match |
0/60 (0.0%) |
20/60 (33.3%) |
+20 |
| Tool |
Cases |
Base envelope |
Base tool match |
Tuned envelope |
Tuned tool match |
Delta envelope |
Delta tool match |
memorysmith_code_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
1/5 (20.0%) |
1/5 (20.0%) |
+1 |
+1 |
memorysmith_code_search_status |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
1/5 (20.0%) |
1/5 (20.0%) |
+1 |
+1 |
memorysmith_context_pack |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
0/5 (0.0%) |
0/5 (0.0%) |
+0 |
+0 |
memorysmith_get |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
2/5 (40.0%) |
0/5 (0.0%) |
+2 |
+0 |
memorysmith_hybrid_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
1/5 (20.0%) |
1/5 (20.0%) |
+1 |
+1 |
memorysmith_page_get |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
5/5 (100.0%) |
5/5 (100.0%) |
+5 |
+5 |
memorysmith_page_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
3/5 (60.0%) |
3/5 (60.0%) |
+3 |
+3 |
memorysmith_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
1/5 (20.0%) |
0/5 (0.0%) |
+1 |
+0 |
memorysmith_semantic_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
2/5 (40.0%) |
2/5 (40.0%) |
+2 |
+2 |
memorysmith_task_get |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
3/5 (60.0%) |
3/5 (60.0%) |
+3 |
+3 |
memorysmith_task_list |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
4/5 (80.0%) |
3/5 (60.0%) |
+4 |
+3 |
memorysmith_unified_search |
5 |
0/5 (0.0%) |
0/5 (0.0%) |
1/5 (20.0%) |
1/5 (20.0%) |
+1 |
+1 |
Notable Improvements
memorysmith_unified_search-4 (memorysmith_unified_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_unified_search); prompt="search for model profile defaults"
memorysmith_hybrid_search-2 (memorysmith_hybrid_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_hybrid_search); prompt="hybrid search for source bundle auth behavior"
memorysmith_semantic_search-2 (memorysmith_semantic_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_semantic_search); prompt="semantic search for pages lock navigation regression"
memorysmith_semantic_search-3 (memorysmith_semantic_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_semantic_search); prompt="semantic search for sidebar collapse standard"
memorysmith_search-3 (memorysmith_search): base(match=False, env=False, pred=None) -> tuned(match=False, env=True, pred=memorysmith_keyword_search); prompt="find literal text RequestGuard"
memorysmith_get-1 (memorysmith_get): base(match=False, env=False, pred=None) -> tuned(match=False, env=True, pred=memorysmith_get_memory); prompt="show memory mem_project_001"
memorysmith_get-3 (memorysmith_get): base(match=False, env=False, pred=None) -> tuned(match=False, env=True, pred=memorysmith_get_memory); prompt="get memory mem_ops_009"
memorysmith_page_search-1 (memorysmith_page_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_page_search); prompt="find pages about markdown rendering"
memorysmith_page_search-4 (memorysmith_page_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_page_search); prompt="search pages for request guard middleware"
memorysmith_page_search-5 (memorysmith_page_search): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_page_search); prompt="find pages about maintenance revision cycle"
memorysmith_page_get-1 (memorysmith_page_get): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_page_get); prompt="open page memory-taxonomy"
memorysmith_page_get-2 (memorysmith_page_get): base(match=False, env=False, pred=None) -> tuned(match=True, env=True, pred=memorysmith_page_get); prompt="get page codebase-vector-search-whitepaper"
Notable Regressions
Persistent Failures (Both Models)
memorysmith_unified_search-1 (memorysmith_unified_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_unified_search-2 (memorysmith_unified_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_unified_search-3 (memorysmith_unified_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_unified_search-5 (memorysmith_unified_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_hybrid_search-1 (memorysmith_hybrid_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_hybrid_search-3 (memorysmith_hybrid_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_hybrid_search-4 (memorysmith_hybrid_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_hybrid_search-5 (memorysmith_hybrid_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_semantic_search-1 (memorysmith_semantic_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_semantic_search-4 (memorysmith_semantic_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_semantic_search-5 (memorysmith_semantic_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_search-1 (memorysmith_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_search-2 (memorysmith_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
memorysmith_search-3 (memorysmith_search): base pred=None, tuned pred=memorysmith_keyword_search, baseErr=No JSON object found, tunedErr=None
memorysmith_search-4 (memorysmith_search): base pred=None, tuned pred=None, baseErr=No JSON object found, tunedErr=No JSON object found
Representative Output Snippets
memorysmith_unified_search-1
- Prompt: search the wiki for kv cache options
- Base: [think] Okay, the user is asking me to search the wiki for information about kv cache options. I need to remember that I'm Athena, MemorySmith's local wiki assistant. When a search or retrieval action is requested, I should respond with ...
- Tuned: The user is asking me to search the wiki for information about KV cache options. This is a search request, so I should use the memorysmith_unified_search tool to search across memories, pages, and tasks. I'll construct the query to look ...
memorysmith_unified_search-2
- Prompt: find docs for training harness
- Base: assistant [think] Okay, the user is asking for documentation on the training harness. I need to figure out how to respond as Athena, the local wiki assistant. First, I should check if there's a specific tool I need to use for retrieving ...
- Tuned: The user is asking for documentation about the training harness. I should use memorysmith_unified_search to search for this. I'll include the query and memory limit to get relevant results. [/think] {"toolCalls":[{"name":"memorysmith_uni...
memorysmith_unified_search-3
- Prompt: lookup wiki notes about chat template
- Base: assistant [think] Okay, the user is asking me to look up wiki notes about chat templates. I need to check if there's any information in the MemorySmith's wiki about chat templates. Since I'm Athena, the local wiki assistant, I should use...
- Tuned: The user is asking me to search for wiki notes about chat template. This is a search request, so I should use the memorysmith_unified_search tool to find relevant memories. I'll construct a query that searches for chat template in the wi...
memorysmith_unified_search-4
- Prompt: search for model profile defaults
- Base: assistant [think] Okay, the user is asking me to search for model profile defaults. I need to figure out what they mean by that. Model profiles could refer to different things depending on the context. Maybe they're talking about machine...
- Tuned: The user is asking for a search on model profile defaults. I should use the memorysmith_unified_search tool to search for this topic. [/think] {"toolCalls":[{"name":"memorysmith_unified_search","arguments":{"query":"model profile default...
memorysmith_unified_search-5
- Prompt: find references about code search eta
- Base: assistant [think] Okay, the user is asking for references about code search ETA. First, I need to figure out what they mean by "code search eta". ETA usually stands for Estimated Time of Arrival, but in the context of code search, that d...
- Tuned: The user is asking for references about code search ETA. This is a specific information retrieval request. I should use memorysmith_unified_search to search for this topic. I'll include the query and memory limit to get relevant results....
memorysmith_hybrid_search-1
- Prompt: run a hybrid search for request guard middleware
- Base: [think] Okay, the user is asking me to run a hybrid search for "request guard middleware". I need to figure out how to handle this. First, I remember that as Athena, I'm supposed to respond with a JSON object when a search/retrieval acti...
- Tuned: The user is asking for a hybrid search for a specific topic. I should use the memorysmith_hybrid_search tool with the query set to "request guard middleware" and the memoryLimit set to 5 to get relevant results. [/think] {"toolCalls":[{"...
memorysmith_hybrid_search-2
- Prompt: hybrid search for source bundle auth behavior
- Base: [think] Okay, the user is asking about hybrid search for source bundle auth behavior. Let me start by recalling what I know about hybrid search. Hybrid search usually combines different search methods, like keyword and vector search, to ...
- Tuned: The user is asking for a hybrid search query. I should use the memorysmith_hybrid_search tool with the query parameter set to the search terms. [/think] {"toolCalls":[{"name":"memorysmith_hybrid_search","arguments":{"query":"source bundl...
memorysmith_hybrid_search-3
- Prompt: use hybrid search to find onnx semantic search notes
- Base: Okay, the user is asking me to use hybrid search to find ONNX semantic search notes. First, I need to understand what they're looking for. Hybrid search typically combines different search methods, like keyword and semantic search, to re...
- Tuned: The user is asking for a hybrid search to find notes about ONNX semantic search. This is a search request, so I should use the memorysmith_hybrid_search tool. I'll construct the query to search for ONNX semantic search notes. [/think] {"...