Calling Children Flows
One of the powerful features of AnswerAI is that you can turn flows into tools. For example, having a main flow to orchestrate which/when to use the necessary tools. And each tool is designed to perform a niece/specific thing.
This offers a few benefits:
- Each children flow as tool will execute on its own, with separate memory to allow cleaner output
- Aggregating detailed outputs from each children flow to a final agent, often results in higher quality output
You can achieve this by using the following tools:
- Chatflow Tool
- Custom Tool
Chatflow Tool
- Have a chatflow ready. In this case, we create a Chain of Thought chatflow that can go through multiple chainings.
data:image/s3,"s3://crabby-images/b0fbc/b0fbc2f29ce465d7839893327f1af24d860de58b" alt="".png)
- Create another chatflow with Tool Agent + Chatflow Tool. Select the chatflow you want to call from the tool. In this case, it was Chain of Thought chatflow. Give it a name, and an appropriate description to let LLM knows when to use this tool:
data:image/s3,"s3://crabby-images/dae44/dae444cc6b72e57728c713faea13b2e104b4e636" alt="".png)
- Test it out!
data:image/s3,"s3://crabby-images/b51fd/b51fd622d7f649eaa4f3c05e0962d62e872aa3ab" alt="".png)
- From the response, you can see the input and output from the Chatflow Tool:
data:image/s3,"s3://crabby-images/4454e/4454e55daea27992dab34b03f09f2c5f9e70ac0f" alt="".png)
Custom Tool
With the same example as above, we are going to create a custom tool that will calls the Prediction API of the Chain of Thought chatflow.
- Create a new tool:
Tool Name | Tool Description |
---|---|
ideas_flow | Use this tool when you need to achieve certain objective |
Input Schema:
Property | Type | Description | Required |
---|---|---|---|
input | string | input question | true |
data:image/s3,"s3://crabby-images/52c89/52c898eadc8922b0c2313077e09f1fba72ed60aa" alt="" (1).png)
Javascript Function of the tool:
const fetch = require('node-fetch')
const url = 'http://localhost:3000/api/v1/prediction/<chatflow-id>' // replace with specific chatflow id
const body = {
question: $input
}
const options = {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(body)
}
try {
const response = await fetch(url, options)
const resp = await response.json()
return resp.text
} catch (error) {
console.error(error)
return ''
}
- Create a Tool Agent + Custom Tool. Specify the tool we've created in Step 1 in the Custom Tool.
data:image/s3,"s3://crabby-images/f60dc/f60dcad20d2685346cc101235613ea0772bf9acc" alt="".png)
- From the response, you can see the input and output from the Custom Tool:
data:image/s3,"s3://crabby-images/7c223/7c223c233cad4a8e0bbc4d62ab2a9ae3f05d492c" alt="".png)
Conclusion
In this example, we have successfully demonstrate 2 ways of turning other chatflows into tools, via Chatflow Tool and Custom Tool. Both are using the same code logic under the hood.