Building an Agent for Tabular Data
As a simple entry point tutorial, we will create an agent that can answer questions from tabular data.
We start with creating a component to upload files, which is the end-point for entering the specific CSV file used in this example (list of films and their ratings).
data:image/s3,"s3://crabby-images/e65ca/e65caf30e3bfc6b231608589bd6f54d3f5b9ba1b" alt="Lunar Workflow"
We then connect the CSV component to a Python Coder component, which gets the serialized content of the file, with the associated attributes and values.
data:image/s3,"s3://crabby-images/57d3d/57d3d6db7200ce31c40d0d2abf182d8b9b05189a" alt="Lunar Workflow"
We name this Python coder component ‘Read file content’.
data:image/s3,"s3://crabby-images/13769/13769a6b540f994d122c3bd4c2693f5d6904bab1" alt="Lunar Workflow"
With access to the content in hand, we add an LLM component (in this case, a specific Azure API component, but any LLM will do), where we can specify a query prompt. Here one could define a prompt with free queries, however, to exemplify the notion of input variables in Lunar (here {imdb data} and {movie}), we link the output of the previous component as a part of the context creation process.
data:image/s3,"s3://crabby-images/b287a/b287adb2c49bbb58bd25456c0f97391fcf59bf92" alt="Lunar Workflow"
You are now ready to run your workflow:
data:image/s3,"s3://crabby-images/3449c/3449cdc26f14e6c760086236cdd34e0d3c6b1adf" alt="Lunar Workflow"
Where you can see the output at the bottom of the component.
data:image/s3,"s3://crabby-images/8faa3/8faa3ba894653742561693beff85a4455833d329" alt="Lunar Workflow"