A collection of template utility agents by Lyzr
Project description
Lyzr Agents
A collection of template utility agents by Lyzr.
Installation
# Basic installation
pip install lyzr-agents
# With STORM agent support
pip install lyzr-agents[storm]
Getting Your API Key
- Go to Lyzr Studio
- Sign up or log in to your account
- Navigate to Settings → API Keys
- Create a new API key
- Your User ID is your email address
Quick Start
Basic Agent Execution
from lyzr_agents import LyzrAgent
# Initialize the client
client = LyzrAgent(
api_key="your-lyzr-api-key",
user_id="your-user-id"
)
# Execute an agent
response = client.execute(
agent_id="your-agent-id",
message="Hello, what can you help me with?"
)
print(response.response)
STORM Agent - Long-form Article Generation
The STORM agent implements Stanford's STORM algorithm for generating comprehensive, research-backed articles.
from lyzr_agents.storm import StormAgent
# Initialize with default Lyzr agents
agent = StormAgent(
lyzr_api_key="your-api-key",
user_id="your-user-id",
no_of_personas=3, # Number of expert perspectives
no_of_questions=3, # Questions per persona
no_of_sections=5, # Article sections
)
# Generate an article (sync)
result = agent.write("quantum computing")
result.toFile("quantum_computing.md")
# Or use async for parallel execution (faster)
import asyncio
async def main():
result = await agent.write_async("quantum computing")
result.print()
asyncio.run(main())
Custom Agent Configuration
from lyzr_agents.storm import StormAgent, StormAgentConfig
config = StormAgentConfig(
persona_generator_agent_id="your-persona-agent",
question_generator_agent_id="your-question-agent",
research_agent_id="your-research-agent",
outline_generator_agent_id="your-outline-agent",
section_generator_agent_id="your-section-agent",
)
agent = StormAgent(
lyzr_api_key="your-api-key",
user_id="your-user-id",
config=config,
)
Event Callbacks for Visualization
Track the STORM process in real-time for building UIs:
from lyzr_agents.storm import StormAgent
def on_event(event):
print(f"[{event.status}] {event.step_name}: {event.event_type.value}")
agent = StormAgent(
lyzr_api_key="your-api-key",
user_id="your-user-id",
on_event=on_event,
)
result = agent.write("artificial intelligence")
# Get React Flow compatible graph data
graph_data = result.get_graph_data()
print(graph_data) # {"nodes": [...], "edges": [...]}
Target Article Length
Specify a target character count and the agent will enrich sections until the target is reached:
from lyzr_agents.storm import StormAgent
agent = StormAgent(
lyzr_api_key="your-api-key",
user_id="your-user-id",
no_of_chars=20000, # Target 20,000 characters
max_enrich_retries=3, # Max enrichment iterations per section
)
result = agent.write("quantum computing")
print(f"Article length: {len(result.article)} characters")
Live Terminal Visualization
Watch STORM execution in real-time with a beautiful tree display:
from lyzr_agents.storm import StormAgent, StormVisualizer
agent = StormAgent(
lyzr_api_key="your-api-key",
user_id="your-user-id",
)
# Sync with live visualization
with StormVisualizer() as viz:
result = agent.write("quantum computing", on_event=viz.on_event)
# Async with live visualization
async with StormVisualizer() as viz:
result = await agent.write_async("quantum computing", on_event=viz.on_event)
Terminal Output:
STORM: quantum computing [OK]
├── Generate Personas [OK] (3 items)
│ ├── Persona 1 [OK]
│ ├── Persona 2 [OK]
│ └── Persona 3 [OK]
├── Expert 1 Session [OK]
│ ├── Q1 [OK]
│ ├── Research Q1 [OK] (445 chars)
│ └── Q2 [OK]
├── Generate Outline [OK]
│ ├── Introduction [OK]
│ └── Core Concepts [OK]
├── Write: Introduction... [OK] (559 chars)
└── Assemble Article [OK]
Test Mode
Run without making API calls:
from lyzr_agents.storm import StormAgent, test_config
agent = StormAgent(
lyzr_api_key="test",
user_id="test",
config=test_config(),
)
# Returns mock data for testing
result = agent.write("test topic")
print(result.article)
STORM Algorithm
The STORM (Synthesis of Topic Outlines through Retrieval and Multi-perspective Question Asking) algorithm works in 6 steps:
- Persona Discovery - Generate diverse expert personas
- Question Generation - Each persona asks insightful questions
- Research - Answer questions using RAG-powered research
- Outline Generation - Create article structure from research
- Section Writing - Write each section with research context
- Assembly - Combine into final article
The async write_async() method runs persona conversations in parallel for faster execution.
API Reference
StormResult
The result object supports fluent method chaining:
result = agent.write("topic")
# Chain methods
result.toFile("output.md").print()
# Access data
print(result.article) # Final article text
print(result.personas) # List of generated personas
print(result.questions) # Dict of persona -> questions
print(result.research) # Dict of question -> answer
print(result.outline) # List of section titles
print(result.sections) # Dict of title -> content
print(result.events) # List of StormEvent objects
StormVisualizer
Context manager for live terminal visualization:
from lyzr_agents.storm import StormVisualizer
# Customize refresh rate (default: 4 times/second)
with StormVisualizer(refresh_rate=10) as viz:
result = agent.write("topic", on_event=viz.on_event)
# Hide details like character counts
with StormVisualizer(show_details=False) as viz:
result = agent.write("topic", on_event=viz.on_event)
Event Types
from lyzr_agents.storm import StormEventType
# Lifecycle
StormEventType.STORM_STARTED
StormEventType.STORM_COMPLETED
StormEventType.STORM_FAILED
# Per-step events
StormEventType.PERSONA_GENERATION_STARTED
StormEventType.PERSONA_CREATED
StormEventType.QUESTION_GENERATION_STARTED
StormEventType.RESEARCH_STARTED
StormEventType.SECTION_WRITING_STARTED
# ... and more
License
MIT License
Links
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lyzr_agents-0.1.1.tar.gz.
File metadata
- Download URL: lyzr_agents-0.1.1.tar.gz
- Upload date:
- Size: 58.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb94b5d27b7ceb14e95fcaac8262b0bff49dabba0221b4038a689e8c659ffa55
|
|
| MD5 |
f166c05177b6482361d70d11c4c18a71
|
|
| BLAKE2b-256 |
acb7f84969b2512a70d5da3c4c8012b6470b74f2cad9484be89ec943a42b8c10
|
File details
Details for the file lyzr_agents-0.1.1-py3-none-any.whl.
File metadata
- Download URL: lyzr_agents-0.1.1-py3-none-any.whl
- Upload date:
- Size: 20.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f72c9f9a7942e02db9e7c13ae7bbfd6541d27bc58018a60974128786d925ca2
|
|
| MD5 |
8efeaf3a030f462cd321e949fb067a2b
|
|
| BLAKE2b-256 |
aa780b8c7676d6118be4842a1482c394a1ada02138a300a21ff22eabcf138b2d
|