Using the Agent Development Environment (ADE)
The ADE is an integrated development environment which allows you to create, edit, interact with and monitor Letta agents. You can use the ADE to chat with agents you’ve already created, or to design new agents from scratch - editing their memory state, data sources, and even customizing their tools all from within the ADE.
Agent simulator
The agent simulator visualizes the event/conversation history of your agent. The agent’s event history is comprised of messages, which can be:
Context window viewer
The context window viewer visualizes the current status of the agent’s context window, which includes:
Configuring the max context length
The max length of the context window is configurable in Letta (under “Advanced” agent settings). For example, if you’re using Claude Sonnet 3.5, but do not want the context window to exceed 16k for performance/cost/latency reasons, you can set the max context window in Letta to 16k (instead of the 200k default). When the context window reaches its max length, Letta will automatically evict old events/messages to external storage (they are not deleted, and are still accessible to the agent via tool calls).
Core memory
Core memory is comprised of memory blocks, which are text segments which are pinned to the context window (always visible) and are editable by the agent.
For example, if the agent learns a new fact about the user, it can store this fact by editing its core memory (for example, by using the tool core_memory_append
).
Because the core memory blocks are persistent (and because the context window is finite), core memory blocks have length limits. Blocks have a default length limit, which can be edited through the API or via the ADE core memory editor.
Archival memory
Archival memory is an out-of-context memory store that’s is accessible to the agent via tool calls (archival_memory_search
and archival_memory_insert
).
By default, archival memory is implemented as a vector database store: the memories inside archival memory are “chunks”, each of which has a corresponding embedding (based on the default embedding model of the agent, for example OpenAI’s text-embedding-3-small
).
Data sources
Data sources allow you to connect large datasets or file uploads to your agent. To connect your agent to a data source:
- Create a new data source (or select an existing one), for example Business Guidelines
- If you created a new data source, upload your data to the data source (for example, the PDF files related to your business guidelines).
- Attach the data source to the agent
The agent will now be able to view data in the data source via its archival_memory_search
tool. You can detach a data source from an agent at any time.
Tools
Use the tools panel to view the current tools attached to your agent, and add new tools to the agent. Tools can be added and removed from existing agents (you do not have to recreate your agent if you add/remove a tool).
To add a new tool to your agent, click “Add tool”, which will bring you to the tool browser. From the tool browser page, you can either select and existing tool and add it to your agent, or create a new tool from scratch.
The tool creation page allows you to dynamically run your tool (in a sandboxed environment) to help you debug and design your tools.
Pressing Run
will attempt to run your tool code with the arguments provided (arguments must be provided in JSON format).
Agent settings
You can change your agent name and system instructions in the “Agent Settings” panel. The agent ID is shown below the agent name, and is what you use to identify your agent when interacting with it via the Letta APIs / SDKs.
Changing the LLM model
You can change the LLM model of your agent to any model registered on the Letta server. To enable more models on your Letta server, follow the Letta server model configuration instructions.