Use Agent in flow
Agents are AI systems that use LLMs as a brain to analyze problems and select external tools.
Last updated
Agents are AI systems that use LLMs as a brain to analyze problems and select external tools.
Last updated
Instead of developers having to create logical statements to direct every possible path of a program, an agent can operate with autonomy. An agent can leverage external tools and APIs to gather information and take action, demonstrate chain-of-thought reasoning, and generate tailored text for specific purposes.
To simplify the development of agents, BroxiAI created a custom component that simplifies configuration and lets developers focus on solving problems with agents.
Developing agents in Langchain is complex.
The AgentComponent
is a component for easily creating an AI agent capable of analyzing tasks using tools you provide.
The component contains all of the elements you'll need for creating an agent. Instead of managing LLM models and providers, pick your model and enter your API key. Instead of connecting a Prompt component, enter instructions in the component's Agent Instruction fields.
Prerequisites
Create a problem-solving agent in BroxiAI, starting with the Tool calling agent.
Click New Flow, and then click Blank Flow.
Click and drag an Agent component to your workspace. The default settings are acceptable for now, so this guide assumes you're using Open AI for the LLM.
Add your Open AI API Key to the Agent component.
Add Chat input and Chat output components to your flow, and connect them to the tool calling agent.
This basic flow enables you to chat with the agent with the Playground after you've connected some Tools.
Connect the Search API tool component to your agent.
Add your Search API key to the component. Your agent can now query the Search API for information.
Connect a Calculator tool for solving basic math problems.
Connect an API Request component to the agent. This component is not in the Tools category, but the agent can still use it as a tool by enabling Tool Mode. Tool Mode makes a component into a tool by adding a Toolset port that can be connected to an agent's Tools port. To enable Tool Mode on the component, click Tool Mode. The component's fields change dynamically based on the mode it's in.
Your agent now has tools for performing a web search, doing basic math, and performing API requests. You can solve many problems with just these capabilities.
Your tabletop game group cancelled, and you're stuck at home. Point API Request to an online rules document, tell your agent You are a fun game organizer who uses the tools at your disposal
, and play a game.
You need to learn a new software language quickly. Point API Request to some docs, tell your agent You are a knowledgeable software developer who uses the tools at your disposal
, and start learning.
See what problems you can solve with this flow. As your problem becomes more specialized, add more tools. For example, add a Python REPL component to solve math problems that are too challenging for the calculator.
To edit a tool's metadata, click the Edit Tools button in the tool to modify its name
or description
metadata. These fields help connected agents understand how to use the tool, without having to modify the agent's prompt instructions.
For example, the URL component has three tools available when Tool Mode is enabled.
URL-fetch_content
Use this tool to fetch and retrieve raw content from a URL, including HTML and other structured data. The full response content is returned.
URL-fetch_content_text
Use this tool to fetch and extract clean, readable text content from a webpage. Only plain text content is returned.
URL-as_dataframe
Use this tool to fetch structured data from a URL and convert it into a tabular format. Data is returned in a structured DataFrame table format.
A connected agent will have a clear idea of each tool's capabilities based on the name
and description
metadata. If you think the agent is using a tool incorrectly, edit a tool's metadata to help it understand the tool better.
Tool names and descriptions can be edited, but the default tool identifiers cannot be changed. If you want to change the tool identifier, create a custom component.
To see which tools the agent is using and how it's using them, ask the agent, What tools are you using to answer my questions?
The agent component itself also supports Tool Mode for creating multi-agent flows.
Add an agent to your problem-solving flow that uses a different OpenAI model for more specialized problem solving.
Click and drag an Agent component to your workspace.
Add your Open AI API Key to the Agent component.
In the Model Name field, select gpt-4o
.
Click Tool Mode to use this new agent as a tool.
Connect the new agent's Toolset port to the previously created agent's Tools port.
Connect Search API and API Request to the new agent. The new agent will use gpt-4o
for the larger tasks of scraping and searching information that requires large context windows. The problem-solving agent will now use this agent as a tool, with its unique LLM and toolset.
The new agent's metadata can be edited to help the problem-solving agent understand how to use it. Click Edit Tools to modify the new agent's name
or description
metadata so its usage is clear to the problem-solving agent. For example, the default tool name is Agent
. Edit the name to Agent-gpt-4o
, and edit the description to Use the gpt-4o model for complex problem solving
. The problem-solving agent will understand that this is the gpt-4o
agent, and will use it for tasks requiring a larger context window.
An agent can use custom components as tools.
To add a custom component to the problem-solving agent flow, click New Custom Component.
Add custom Python code to the custom component. Here's an example text analyzer for sentiment analysis.
To enable the custom component as a tool, click Tool Mode.
Connect the tool output to the agent's tools input.
Ask the agent, What tools are you using to answer my questions?
Your response will be similar to the following, and will include your custom component.
If the component you want to use as a tool doesn't have a Tool Mode button, add tool_mode=True
to one of the component's inputs, and connect the new Toolset output to the agent's Tools input.
BroxiAI supports Tool Mode for the following data types:
DataInput
DataFrameInput
PromptInput
MessageTextInput
MultilineInput
DropdownInput
To add a Run flow component, click and drag a Run flow component to your workspace.
Select the flow you want the agent to use as a tool.
Enable Tool Mode in the component.
Connect the tool output to the agent's tools input.
To enable tool mode, select a Flow in the Run flow component, and then click Tool Mode.
Ask the agent, What tools are you using to answer my questions?
Your flow should be visible in the response as a tool.
For example, the example above adds tool_mode=True
to the MessageTextInput
input so the custom component can be used as a tool.
An agent can use flows that are saved in your workspace as tools with the component.