Eliza Agent Framework
A comprehensive framework for building AI agents with persistent personalities across multiple platforms. ElizaOS provides the architecture, tools, and systems needed to create sophisticated agents.
Last updated
A comprehensive framework for building AI agents with persistent personalities across multiple platforms. ElizaOS provides the architecture, tools, and systems needed to create sophisticated agents.
Last updated
Take a minute to review the following organizational chart:
When a user message is received:
Service Reception: Platform service (Discord, Telegram, etc.) receives the message
Runtime Processing: Agent runtime coordinates the response generation
Context Building: Providers supply relevant context (time, recent messages, knowledge)
Action Selection: The agent evaluates and selects appropriate actions
Response Generation: The chosen action generates a response
Learning & Reflection: Evaluators analyze the conversation for insights and learning
Memory Storage: New information is stored in the database
Response Delivery: The response is sent back through the service
This creates a continuous cycle of interaction, reflection, and improvement that allows agents to maintain consistent personalities while adapting to new information.
The AgentRuntime class is the primary implementation of the IAgentRuntime interface, which manages the agent's core functions, including:
Services
Supports multiple communication platforms and specialized functionalities for seamless interaction.
State
Maintains context for coherent cross-platform interactions, updates dynamically. Also tracks goals, knowledge, and recent interactions
Plugins
Dynamic extensions of agent functionalities using custom actions, evaluators, providers, and adapters
Services
Connects with external services for IMAGE_DESCRIPTION
, TRANSCRIPTION
, TEXT_GENERATION
, SPEECH_GENERATION
, VIDEO
, PDF
, BROWSER
, WEB_SEARCH
, EMAIL_AUTOMATION
, and more
Memory Systems
Creates, retrieves, and embeds memories and manages conversation history.
Database Adapters
Persistent storage and retrieval for memories and knowledge
Cache Management
Provides flexible storage and retrieval via various caching methods.
initialize()
: Sets up the agent's runtime environment, including services, plugins, and knowledge processing.
processActions()
: Executes actions based on message content and state.
evaluate()
: Assesses messages and state using registered evaluators.
composeState()
: Constructs the agent's state object for response generation.
registerService()
: Adds a service to the runtime.
getService()
: Retrieves a registered service by type.
useModel()
: Utilizes AI models with typesafe parameters and results.
ensureRoomExists()
/ ensureConnection()
: Ensures the existence of communication channels and connections.
Services provide specialized functionality with standardized interfaces that can be accessed cross-platform:
The runtime maintains comprehensive state through the State interface:
Plugins extend agent functionality through a modular interface. The runtime supports various types of plugins including services, adapters, actions, and more:
Plugins can be configured through characterfile settings:
For detailed information about plugin development and usage, see the ElizaOS Registry.
, , , , , , , ,
, , ,
, , , , , ,