- Pattern 1: Pre-planned Tools
- Provide the specific functions (tools) to be used by an LLM.
 
- Pattern 2: Dynamic Tool Discovery and Execution
- 
2.1: Tool List Expansion
- Use ACI_SEARCH_FUNCTIONSmeta function (tool):
- Search for relevant functions across all apps
- Add discovered tools directly to the LLM’s tool list
- Allow the LLM to invoke these discovered tools directly by name
 
- Use 
- 
2.2: Tool Definition as Text Context Approach
- Use ACI_SEARCH_FUNCTIONSandACI_EXECUTE_FUNCTIONmeta functions (tools)
- Use ACI_SEARCH_FUNCTIONSto retrieve tool definitions
- Present those definitions to the LLM as text content instead of adding them to the LLM’s tool list
- The LLM uses ACI_EXECUTE_FUNCTIONto execute these tools indirectly
 
- Use 
 
- 
2.1: Tool List Expansion
Pre-planned
This is the most straright forward use case. You can directly find the functions you want to use on the developer portal, retrieve the function definitions, and append them to your LLM API call. This way your agents will only use the tools you have selected and provided, it would not attempt to find and use other tools.Dynamic Tool Discovery and Execution With Tool List Expansion
In this use case, the tools list provided to LLM API calls changes according to the function definitions retrieved by the agent from the ACI.dev using the provided meta functions (tools). The retrieved function definitions are appended to the available tools list for LLMs to decide when and how to use it in subsequent LLM calls. This leverages the ability of many LLMs to enforce adherence of function-call outputs as much as possible to the provided definition, while still offering the flexibility to essentially access as many different tools as needed by the LLM-powered agent. The trade-off here is that the developer has to manage tool-list and know when to append or remove tools when making the LLM call. Example starting tools lists provided to the LLMDynamic Tool Discovery and Execution With Tool Definition as Text Content
In this use case, the tools list provided to the LLM is static, which are just the two meta functionsACI_SEARCH_FUNCTIONS and ACI_EXECUTE_FUNCTION.
The difference between this and the previous pattern is that retrieved function definitions are provided to the LLM directly as text content instead of being added to the tools list.
The LLM then has to decide whether to call the ACI_EXECUTE_FUNCTION to actually execute an API call.
By using the meta functions (tools) this way, the developer does not have to manage the tools list, but the accuracy of tool use can decrease.
Example tools list provided to LLM