dotnet/website/tutorial/Create-agent-with-tools.md
This tutorial shows how to use tools in an agent.
Tools are pre-defined functions in user's project that agent can invoke. Agent can use tools to perform actions like search web, perform calculations, etc. With tools, it can greatly extend the capabilities of an agent.
[!NOTE] To use tools with agent, the backend LLM model used by the agent needs to support tool calling. Here are some of the LLM models that support tool calling as of 06/21/2024
- GPT-3.5-turbo with version >= 0613
- GPT-4 series
- Gemini series
- OPEN_MISTRAL_7B
- ...
This tutorial uses the latest
GPT-3.5-turboas example.
[!NOTE] The complete code example can be found in Use_Tools_With_Agent.cs
[!Tip] You can Use AutoGen.SourceGenerator to automatically generate type-safe @AutoGen.Core.FunctionContract instead of manually defining them. For more information, please check out Create type-safe function.
First, install the AutoGen and AutoGen.SourceGenerator package using the following command:
dotnet add package AutoGen
dotnet add package AutoGen.SourceGenerator
Also, you might need to enable structural xml document support by setting GenerateDocumentationFile property to true in your project file. This allows source generator to leverage the documentation of the function when generating the function definition.
<PropertyGroup>
<!-- This enables structural xml document support -->
<GenerateDocumentationFile>true</GenerateDocumentationFile>
</PropertyGroup>
[!code-csharpUsing Statements]
Create an @AutoGen.OpenAI.OpenAIChatAgent with GPT-3.5-turbo as the backend LLM model.
[!code-csharpCreate an agent with tools]
Tool class and create toolsCreate a public partial class to host the tools you want to use in AutoGen agents. The method has to be a public instance method and its return type must be Task<string>. After the methods is defined, mark them with @AutoGen.Core.FunctionAttribute attribute.
In the following example, we define a GetWeather tool that returns the weather information of a city.
[!code-csharpDefine Tool class] [!code-csharpCreate tools]
In this case, when receiving a @AutoGen.Core.ToolCallMessage, the agent will not automatically invoke the tool. Instead, the agent will return the original message back to the user. The user can then decide whether to invoke the tool or not.
To implement this, you can create the @AutoGen.Core.FunctionCallMiddleware without passing the functionMap parameter to the constructor so that the middleware will not automatically invoke the tool once it receives a @AutoGen.Core.ToolCallMessage from its inner agent.
[!code-csharpSingle-turn tool call without auto-invoke]
After creating the function call middleware, you can register it to the agent using RegisterMiddleware method, which will return a new agent which can use the methods defined in the Tool class.
[!code-csharpGenerate Response]
In this case, the agent will automatically invoke the tool when receiving a @AutoGen.Core.ToolCallMessage and return the @AutoGen.Core.ToolCallAggregateMessage which contains both the tool call request and the tool call result.
To implement this, you can create the @AutoGen.Core.FunctionCallMiddleware with the functionMap parameter so that the middleware will automatically invoke the tool once it receives a @AutoGen.Core.ToolCallMessage from its inner agent.
[!code-csharpSingle-turn tool call with auto-invoke]
After creating the function call middleware, you can register it to the agent using RegisterMiddleware method, which will return a new agent which can use the methods defined in the Tool class.
[!code-csharpGenerate Response]
In some cases, you may want to send the tool call result back to the LLM to generate further response. To do this, you can send the tool call response from agent back to the LLM by calling the SendAsync method of the agent.
[!code-csharpGenerate Response]
Some LLM models support parallel tool call, which returns multiple tool calls in one single message. Note that @AutoGen.Core.FunctionCallMiddleware has already handled the parallel tool call for you. When it receives a @AutoGen.Core.ToolCallMessage that contains multiple tool calls, it will automatically invoke all the tools in the sequantial order and return the @AutoGen.Core.ToolCallAggregateMessage which contains all the tool call requests and results.
[!code-csharpGenerate Response]