think() and analyze() tools, and let the agent decide when to use them. The agent chooses when to reason, when to act, and when it has enough information to respond.
Agno provides four specialized reasoning toolkits, each optimized for different domains:
| Toolkit | Purpose | Core Tools |
|---|---|---|
| ReasoningTools | General-purpose thinking and analysis | think(), analyze() |
| KnowledgeTools | Reasoning with knowledge base searches | think(), search_knowledge(), analyze() |
| MemoryTools | Reasoning about user memory operations | think(), get/add/update/delete_memory(), analyze() |
| WorkflowTools | Reasoning about workflow execution | think(), run_workflow(), analyze() |
Note: All reasoning toolkits register theirAll four toolkits follow the same Think → Act → Analyze pattern but provide domain-specific actions tailored to their use case. This approach was first popularized by Anthropic in their “Extended Thinking” blog post, though many AI engineers (including our team) were using similar patterns long before.think()/analyze()functions under the same names. When you combine toolkits, the agent keeps only the first implementation of each function name and silently drops duplicates. Disableenable_think/enable_analyze(or rename/customize functions) on the later toolkits if you still want them to expose their domain-specific actions without conflicting with the scratchpad tools.
Why Reasoning Tools?
Reasoning Tools give you the best of both worlds:- Works with any model - Even models without native reasoning capabilities
- Explicit control - The agent decides when to think vs. when to act
- Full transparency - You see exactly what the agent is thinking
- Flexible workflow - The agent can interleave thinking with tool calls
- Domain-optimized - Each toolkit is specialized for its specific use case
- Natural reasoning - Feels more like human problem-solving (think, act, analyze, repeat)
think() and analyze() tools, giving you more control and visibility.
The Four Reasoning Toolkits
1. ReasoningTools - General Purpose Thinking
For general problem-solving without domain-specific tools. What it provides:think()- Plan and reason about the problemanalyze()- Evaluate results and determine next steps
- Mathematical or logical problems
- Strategic planning
- Analysis tasks that don’t require external data
- Any scenario where you want structured reasoning
2. KnowledgeTools - Reasoning with Knowledge Bases
For searching and analyzing information from knowledge bases (RAG). What it provides:think()- Plan search strategy and refine approachsearch_knowledge()- Query the knowledge baseanalyze()- Evaluate search results for relevance and completeness
- Document retrieval and analysis
- RAG (Retrieval-Augmented Generation) workflows
- Research tasks requiring multiple search iterations
- When you need to verify information from knowledge bases
- Agent calls
think(): “I need to search for quantum entanglement. Let me try multiple search terms.” - Agent calls
search_knowledge("quantum entanglement") - Agent calls
analyze(): “Results are too broad. Need more specific search.” - Agent calls
search_knowledge("quantum entanglement recent findings") - Agent calls
analyze(): “Now I have sufficient, relevant results.” - Agent provides final answer
3. MemoryTools - Reasoning about User Memories
For managing and reasoning about user memories with CRUD operations. What it provides:think()- Plan memory operationsget_memories()- Retrieve user memoriesadd_memory()- Store new memoriesupdate_memory()- Modify existing memoriesdelete_memory()- Remove memoriesanalyze()- Evaluate memory operations
- Personalized agent interactions
- User preference management
- Maintaining conversation context across sessions
- Building user profiles over time
- Agent calls
think(): “User is sharing dietary preferences. I should store this.” - Agent calls
add_memory(memory="User prefers vegetarian recipes and is allergic to nuts", topics=["dietary_preferences", "allergies"]) - Agent calls
analyze(): “Memory successfully stored with appropriate topics.” - Agent responds to user confirming the information was saved
4. WorkflowTools - Reasoning about Workflow Execution
For executing and analyzing complex workflows. What it provides:think()- Plan workflow inputs and strategyrun_workflow()- Execute a workflow with specific inputsanalyze()- Evaluate workflow results
- Multi-step automated processes
- Complex task orchestration
- When workflows need different inputs based on context
- A/B testing different workflow configurations
- Agent calls
think(): “I need to run the research workflow with ‘climate change agriculture’ as input.” - Agent calls
run_workflow(input_data="climate change impacts on agriculture") - Workflow executes all steps (search → summarize → fact-check)
- Agent calls
analyze(): “Workflow completed successfully. All fact-checks passed.” - Agent provides final synthesized answer
Common Pattern: Think → Act → Analyze
All four toolkits follow the same reasoning cycle:- THINK - Plan what to do, refine approach, brainstorm
- ACT (Domain-Specific)
- ReasoningTools: Direct reasoning
- KnowledgeTools:
search_knowledge() - MemoryTools:
get/add/update/delete_memory() - WorkflowTools:
run_workflow()
- ANALYZE - Evaluate results, decide next action
- REPEAT - Loop back to THINK if needed, or provide answer
Choosing the Right Reasoning Toolkit
| If you need to… | Use | Example |
|---|---|---|
| Solve logic puzzles or math problems | ReasoningTools | ”Solve: If x² + 5x + 6 = 0, what is x?” |
| Search through documents | KnowledgeTools | ”Find all mentions of user authentication in our docs” |
| Remember user preferences | MemoryTools | ”Remember that I’m allergic to shellfish” |
| Orchestrate complex multi-step tasks | WorkflowTools | ”Research, write, and fact-check an article” |
| Combine multiple domains | Use multiple toolkits | See examples for more patterns |
Combining Multiple Reasoning Toolkits
You can use multiple reasoning toolkits together for powerful multi-domain reasoning. Just remember that tool names must stay unique, so disable overlappingthink/analyze entries (or rename the later ones) to prevent silent overrides:
ReasoningToolssupplies the sharedthink/analyzescratchpad.KnowledgeToolsstill exposessearch_knowledge()(and any other unique methods) without trying to register duplicate scratchpad functions.MemoryToolscontributes the CRUD memory tools while inheriting the same central thinking loop.
think()/analyze() so each toolkit registers uniquely named functions (e.g., knowledge_think, memory_analyze).
Configuration Options
Enable/Disable Specific Tools
You can control which reasoning tools are available:Add Instructions Automatically
Many toolkits ship with pre-written guidance that explains how to use their tools. Settingadd_instructions=True injects those instructions into the agent prompt (when the toolkit actually has any):
ReasoningTools,KnowledgeTools,MemoryTools, andWorkflowToolsall include Agno-authored instructions (and optional few-shot examples) describing their Think → Act → Analyze workflow.- Other toolkits may not define default instructions; in that case
add_instructions=Trueis a no-op unless you supply your owninstructions=....
think() vs analyze(), how to iterate, and best practices for each domain. Turn them on unless you plan to provide custom guidance.
Add Few-Shot Examples
Want to show your agent some examples of good reasoning? Some toolkits come with pre-written few-shot examples that demonstrate the workflow in action. Turn them on withadd_few_shot=True:
ReasoningTools, KnowledgeTools, and MemoryTools have built-in examples. Other toolkits won’t use add_few_shot=True unless you provide your own examples.
These examples show the agent how to iterate through problems, decide on next actions, and mix thinking with actual tool calls.
When should you use them?
- You’re using a smaller or cheaper model that needs extra guidance
- Your reasoning workflow has multiple stages or is complex
- You want more consistent behavior across different runs
Custom Instructions
Provide your own custom instructions for specialized reasoning:Custom Few-Shot Examples
You can also write your own examples tailored to your domain:Monitoring Your Agent’s Thinking
Useshow_full_reasoning=True and stream_intermediate_steps=True to display reasoning steps in real-time. See Display Options in Reasoning Agents for details and Reasoning Reference for programmatic access to reasoning steps.
Reasoning Tools vs. Reasoning Agents
Both approaches add reasoning to any model, but they differ in control and automation:| Aspect | Reasoning Tools | Reasoning Agents |
|---|---|---|
| Activation | Agent decides when to use think() | Automatic on every request |
| Control | Explicit tool calls | Automated loop |
| Transparency | See every think() and analyze() call | See structured reasoning steps |
| Workflow | Agent-driven (flexible) | Framework-driven (structured) |
| Best for | Research, analysis, exploratory tasks | Complex multi-step problems with defined structure |
- Use Reasoning Tools when you want the agent to control its own reasoning process
- Use Reasoning Agents when you want guaranteed systematic thinking for every request