Copy
Ask AI
"""
Capture Reasoning Content Reasoning Tools
=========================================
Demonstrates this reasoning cookbook example.
"""
from textwrap import dedent
from agno.agent import Agent
from agno.models.openai import OpenAIChat
from agno.tools.reasoning import ReasoningTools
# ---------------------------------------------------------------------------
# Create Example
# ---------------------------------------------------------------------------
def run_example() -> None:
"""Test function to verify reasoning_content is populated in RunOutput."""
print("\n=== Testing reasoning_content generation ===\n")
# Create an agent with ReasoningTools
agent = Agent(
model=OpenAIChat(id="gpt-4o"),
tools=[ReasoningTools(add_instructions=True)],
instructions=dedent("""\
You are an expert problem-solving assistant with strong analytical skills! Use step-by-step reasoning to solve the problem.
\
"""),
)
# Test 1: Non-streaming mode
print("Running with stream=False...")
response = agent.run(
"What is the sum of the first 10 natural numbers?", stream=False
)
# Check reasoning_content
if hasattr(response, "reasoning_content") and response.reasoning_content:
print("[OK] reasoning_content FOUND in non-streaming response")
print(f" Length: {len(response.reasoning_content)} characters")
print("\n=== reasoning_content preview (non-streaming) ===")
preview = response.reasoning_content[:1000]
if len(response.reasoning_content) > 1000:
preview += "..."
print(preview)
else:
print("[NOT FOUND] reasoning_content NOT FOUND in non-streaming response")
# Process streaming responses to find the final one
print("\n\n=== Test 2: Processing stream to find final response ===\n")
# Create another fresh agent
streaming_agent_alt = Agent(
model=OpenAIChat(id="gpt-4o"),
tools=[ReasoningTools(add_instructions=True)],
instructions=dedent("""\
You are an expert problem-solving assistant with strong analytical skills! Use step-by-step reasoning to solve the problem.
\
"""),
)
# Process streaming responses and look for the final RunOutput
final_response = None
for event in streaming_agent_alt.run(
"What is the value of 3! (factorial)?",
stream=True,
stream_events=True,
):
# The final event in the stream should be a RunOutput object
if hasattr(event, "reasoning_content"):
final_response = event
print("--- Checking reasoning_content from final stream event ---")
if (
final_response
and hasattr(final_response, "reasoning_content")
and final_response.reasoning_content
):
print("[OK] reasoning_content FOUND in final stream event")
print(f" Length: {len(final_response.reasoning_content)} characters")
print("\n=== reasoning_content preview (final stream event) ===")
preview = final_response.reasoning_content[:1000]
if len(final_response.reasoning_content) > 1000:
preview += "..."
print(preview)
else:
print("[NOT FOUND] reasoning_content NOT FOUND in final stream event")
# ---------------------------------------------------------------------------
# Run Example
# ---------------------------------------------------------------------------
if __name__ == "__main__":
run_example()
Run the Example
Copy
Ask AI
# Clone and setup repo
git clone https://github.com/agno-agi/agno.git
cd agno/cookbook/10_reasoning/tools
# Create and activate virtual environment
./scripts/demo_setup.sh
source .venvs/demo/bin/activate
python capture_reasoning_content_reasoning_tools.py