Messages#
In AutoGen AgentChat, messages facilitate communication and information exchange with other agents, orchestrators, and applications. AgentChat supports various message types, each designed for specific purposes.
Types of Messages#
At a high level, messages in AgentChat can be categorized into two types: agent-agent messages and an agent’s internal events and messages.
Agent-Agent Messages#
AgentChat supports many message types for agent-to-agent communication. They belong to the union type ChatMessage
. This message type allows both text and multimodal communication and subsumes other message types, such as TextMessage
or MultiModalMessage
.
For example, the following code snippet demonstrates how to create a text message, which accepts a string content and a string source:
from autogen_agentchat.messages import TextMessage
text_message = TextMessage(content="Hello, world!", source="User")
Similarly, the following code snippet demonstrates how to create a multimodal message, which accepts
a list of strings or Image
objects:
from io import BytesIO
import requests
from autogen_agentchat.messages import MultiModalMessage
from autogen_core import Image as AGImage
from PIL import Image
pil_image = Image.open(BytesIO(requests.get("https://picsum.photos/300/200").content))
img = AGImage(pil_image)
multi_modal_message = MultiModalMessage(content=["Can you describe the content of this image?", img], source="User")
img
The TextMessage
and MultiModalMessage
we have created can be passed to agents directly via the on_messages
method, or as tasks given to a team run()
method. Messages are also used in the responses of an agent. We will explain these in more detail in Agents and Teams.
Internal Events#
AgentChat also supports the concept of events
- messages that are internal to an agent. These messages are used to communicate events and information on actions within the agent itself, and belong to the union type AgentEvent
.
Examples of these include ToolCallRequestEvent
, which indicates that a request was made to call a tool, and ToolCallExecutionEvent
, which contains the results of tool calls.
Typically, events are created by the agent itself and are contained in the inner_messages
field of the Response
returned from on_messages
. If you are building a custom agent and have events that you want to communicate to other entities (e.g., a UI), you can include these in the inner_messages
field of the Response
. We will show examples of this in Custom Agents.
You can read about the full set of messages supported in AgentChat in the messages
module.