Function Calling
Get the LLM to interact with external APIs!
As described in the Enforcing JSON Schema cookbook, LLMs are now good at generating outputs that follow a specified syntax. We can combine this LLM ability with their reasoning ability to let LLMs interact with external APIs. This is called Function (or Tool) calling. In simple terms, function calling:
- Informs the user when a question can be answered using an external API
- Generates a valid request in the API’s format
- Converts the API’s response to a natural language answer
Function calling is currently supported on select models on Anyscale, Together AI, Fireworks AI, Google Gemini, and OpenAI. Using Portkey, you can easily experiment with function calling across various providers and gain confidence to ship it to production.
Let’s understand how it works with an example:
We want the LLM to tell what’s the temperature in Delhi today. We’ll use a “Weather API” to fetch the weather:
Here, we’ve defined what the Weather API expects for its requests in the tool
param, and set tool_choice
to auto. So, based on the user messages, the LLM will decide if it should do a function call to fulfill the request. Here, it will choose to do that, and we’ll see the following output:
We can just take the tool_call
made by the LLM, and pass it to our getWeather
function - it should return a proper response to our query. We then take that response and send it to our LLM to complete the loop:
We should see this final output:
Function Calling Workflow
Recapping, there are 4 key steps to doing function calling, as illustrated below:
Function Calling Workflow
Function Calling Workflow
Supporting Models
While most providers have standard function calling as illustrated above, models on Together AI & select new models on OpenAI (gpt-4-turbo-preview
, gpt-4-0125-preview
, gpt-4-1106-preview
, gpt-3.5-turbo-0125
, and gpt-3.5-turbo-1106
) also support parallel function calling - here, you can pass multiple requests in a single query, the model will pick the relevant tool for each query, and return an array of tool_calls
each with a unique ID. (Read here for more info)
Was this page helpful?