The chemical language of AI agents.
Phero is a modern Go framework for building multi-agent AI systems. Like ants in a colony, agents in Phero cooperate, communicate, and coordinate toward shared goals, each with specialized roles, working together through a clean, composable architecture.
- 🤝 Agent orchestration Multi-agent workflows with role specialization, coordination, and agent handoffs
- 🧩 Composable primitives Small, focused packages that solve specific problems
- 🔧 Tool-first design Built-in support for function tools, skills, RAG, and MCP
- 🎨 Developer-friendly Clean APIs, opt-in tracing, OpenAI-compatible + Anthropic support
- 🪶 Lightweight No heavy dependencies; just Go and your choice of LLM provider
- 🤝 Agent orchestration Multi-agent workflows with role specialization, coordination, and runtime handoffs
- 🔀 Agent handoffs Transfer control between agents at runtime;
Result.HandoffAgenttells you where to route next - 🌐 A2A protocol Expose any agent as an HTTP A2A server, or call remote A2A agents as local tools
- 🧩 LLM abstraction Work with OpenAI-compatible endpoints (OpenAI, Ollama, etc.) and Anthropic
- 🖼️ Multimodal input Mix text and images with typed content parts (
llm.Text,llm.ImageURL,llm.ImageFile) - 🔊 Audio I/O OpenAI backend supports speech-to-text and text-to-speech via
llm.Transcriberandllm.SpeechSynthesizer - 🧱 LLM middleware Compose reusable cross-cutting behaviors around any backend with
llm.Use(...) - 🛠️ Function tools Expose Go functions as callable tools with automatic JSON Schema generation
- 📚 RAG (Retrieval-Augmented Generation) Built-in vector storage and semantic search
- 🧠 Skills system Define reusable agent capabilities in
SKILL.mdfiles - 🔌 MCP support Integrate Model Context Protocol servers as agent tools
- 🧾 Memory management Conversational context storage for agents
- 🔍 Tracing Typed lifecycle events with a colorized text tracer (
trace/text) and an NDJSON file tracer (trace/jsonfile); per-run summary with token usage and latency breakdowns - 🛡️ Tool guardrails Bash tool blocklist, allowlist, timeout, and safe-mode options
- ✂️ Text splitting Recursive and Markdown-aware chunkers under
textsplitter/recursiveandtextsplitter/markdown - 🧬 Embeddings Semantic search capabilities via OpenAI embeddings
- 🗄️ Vector stores Qdrant, PostgreSQL/pgvector, and Weaviate backends
- Go 1.25.5 or later
- An LLM provider (OpenAI / Ollama / OpenAI-compatible endpoint, or Anthropic)
Start with the Simple Agent example to learn the basics in ~100 lines of code.
Then try:
- Conversational Agent a multi-turn REPL chatbot with short-term memory
- Long-Term Memory semantic (RAG) memory backed by Qdrant
Then explore the examples/ directory for more advanced patterns:
- Multi-agent workflows
- Multimodal and audio pipelines
- RAG chatbots
- Skills integration
- MCP server connections
Some examples require extra services (e.g. Qdrant for vector search).
Phero is organized into focused packages, each solving a specific problem:
agentCore orchestration for LLM-based agents with tool execution, chat loops, and runtime handoffsmemoryConversational context management for multi-turn interactions (in-process, file-backed, RAG-backed, or PostgreSQL-backed)
llmProvider-agnostic chat interface with typed messages/content parts, function tools, JSON Schema utilities, audio interfaces, and LLM middleware compositionllm/openaiOpenAI-compatible client (works with OpenAI, Ollama, and compatible endpoints)llm/anthropicAnthropic API client
embeddingEmbedding interface for semantic operationsembedding/openaiOpenAI embeddings implementationvectorstoreVector storage interface for similarity searchvectorstore/qdrantQdrant vector database integrationvectorstore/psqlPostgreSQL + pgvector integrationvectorstore/weaviateWeaviate vector database integrationtextsplitterText splitting interface and shared typestextsplitter/recursiveRecursive character-based chunkertextsplitter/markdownMarkdown-aware chunker (heading-first separators)ragComplete RAG pipeline combining embeddings and vector stores
skillParse SKILL.md files and expose them as agent capabilitiesmcpModel Context Protocol adapter for external tool integrationa2aAgent-to-Agent (A2A) protocol — expose agents as HTTP servers or call remote agents as toolstraceTyped observability events;trace/textfor human-readable colorized output;trace/jsonfilefor NDJSON file logging;trace.NewLLMfor raw LLM call wrappingtool/agentCreate and run a sub-agent at runtime as a delegated tooltool/fileFilesystem tools (read,write,edit,glob,grep)tool/bashBash command execution with guardrails (blocklist, allowlist, timeout, safe mode) and background execution (RunInBackground,bash_output,kill_shell)tool/humanStructured user-interaction checkpoints; caller provides the interactor viaWithInteractortool/skillDispatcher-style SKILL.md loader tool that expands instructions in the main conversation
Comprehensive examples are included in the examples/ directory:
| Example | Description |
|---|---|
| Simple Agent | Start here! Minimal example showing one agent with one custom tool perfect for learning the basics |
| Multimodal | Send text + image inputs to a vision-capable model using typed content parts |
| Audio | End-to-end speech-to-text and text-to-speech using the OpenAI backend |
| LLM Middleware | Wrap an LLM with composable middleware for logging and other cross-cutting concerns |
| Conversational Agent | REPL-style chatbot with short-term conversational memory and a simple built-in tool |
| Long-Term Memory | REPL-style chatbot with semantic long-term memory (RAG) backed by Qdrant |
| Handoff | One agent hands work off to a specialist agent at runtime using the built-in handoff mechanism |
| A2A Server | Expose a Phero agent as an A2A-compliant HTTP server for cross-process agent calls |
| A2A Client | Connect to a remote A2A agent and use it as a local tool inside an orchestrator |
| Debate Committee | Multi-agent architecture where committee members debate independently and a judge synthesizes the final decision |
| Evaluator-Optimizer | Iterative generation loop where an optimizer proposes drafts and an evaluator critiques them until quality criteria are met |
| Human-in-the-Loop | Multi-agent flow that pauses for explicit human approval/input before continuing |
| Multi-Agent Workflow | Classic Plan → Execute → Analyze → Critique pattern with specialized agent roles |
| Orchestrator-Workers | Dynamic task decomposition where an orchestrator delegates sub-tasks to worker agents |
| Parallel Research | Fan-out/fan-in workflow that runs multiple specialist researchers in parallel and merges their findings |
| Prompt Chaining | Sequential multi-step prompting with a programmatic gate between stages |
| RAG Chatbot | Terminal chatbot with semantic search over local documents using Qdrant |
| Skill | Use the tool/skill dispatcher to load SKILL.md instructions into the current conversation |
| Social Simulation | Multi-agent social simulation with persona-driven actors and emergent interactions |
| MCP Integration | Run an MCP server as a subprocess and expose its tools to agents |
| Playwright MCP | Connect browser automation tools through MCP and orchestrate them from an agent |
| Supervisor Blackboard | Supervisor-worker pattern with a shared blackboard for coordination |
| Tracing | Attach a colorized tracer to an agent and inspect LLM requests, tool calls, and memory events in real time |
Phero embraces several core principles:
- Composability over monoliths Each package does one thing well
- Interfaces over implementations Swap LLMs, vector stores, or embeddings easily
- Explicit over implicit No hidden magic; clear control flow
- Tools are first-class Function tools are the primary integration point
- Developer experience matters Clean APIs, helpful tracing, good error messages
Contributions are welcome! Please feel free to submit issues, feature requests, or pull requests.
This project is licensed under the Apache License 2.0. See the LICENSE file for details.
Built with ❤️ by Simone Vellei.
Inspired by the collaborative intelligence of ant colonies where independent agents work together toward shared goals, recognizing one another and coordinating through clear protocols.
The ant is not just a mascot. It is the philosophy. 🐜
- Documentation: pkg.go.dev/github.com/henomis/phero
- Issues: github.com/henomis/phero/issues
- Discussions: github.com/henomis/phero/discussions
