Workflow Quick Start
A step-by-step guide on how to extract sentiment from restaurant reviews
Last updated
A step-by-step guide on how to extract sentiment from restaurant reviews
Last updated
Workflows are at the core of 90% of AirOps use cases. In this guide, we will make an example Sentiment Analysis workflow that extracts sentiment, keywords, and a sentiment score from a restaurant review.
Let's dive in...
Click on a Blank Workflow to start a draft of your Workflow
Click Add field to group in the Start step
Click on Long Text to create a multi-line text box
Label the field "Restaurant Review"
Optionally: configure the Variable Name, which will be used to reference the input. Notice the variable name will be "restaurant_review" by default.
Optionally: write a Hint to provide further detail or instructions for the user such as "Enter a single restaurant review to analyze"
Make the field Required by clicking on the toggle
Click Save field
Next, we need to use an LLM step to analyze the sentiment of the restaurant review. We are going to add the following info to the LLM Step :
System Prompt - The role/objective we want the model to fulfil
Example User / Assistant Pairs - Static examples of the model performing the task required to train it
A real request - The actual request we want the model to perform with the runtime data
Click Add Step > LLM > Configure
Choose GPT Turbo 3.5 as the model (always experiement with different models to find the best one)
Set the Temperature to 0.1 (temperature determines the amount of variability and creativity in the response - the higher the temperature, the more varied the response)
The System prompt specifies the persona and/or task of the AI, it is optional. Set it to the following :
System: You are a restaurant review analyzer. Extract positive keywords, negative keywords, and a sentiment score on a scale from -1.0 to 1.0, in 0.1 increments, from the restaurant review. Output in JSON only
Experiment further : You can specify whether you want to Stream Results (as they are generated by the model) or request consistent results from the model. For more information on these settings, please see our document on the LLM Step.
User / Assistant pairs are example input / output pairs that help demonstrate to the model how to behave with real examples.
The LLM will attempt to follow conventions and behaviors demonstrated in the User / Assistant pairs that you pass in. It's a very powerful way to "train" the model how to behave and with larger models, 5, 10 or even 50 examples can be passed in.
This technique is also known as K-Shot prompting. "K" represents the number of examples you are providing.
User: I ordered chirashi for lunch. Good presentation. Need to work on the freshness of the items. Service was good. Would not return for raw items.
Assistant:
{ "positive_keywords": [ "good presentation", "service was good"] "negative_keywords": [ "need to work on the freshness of the items", "would not return for raw items" ] "sentiment_score": 0.2 }
Use a real example: The best way to generate high-quality outputs is by providing a high-quality example to the model. Use the most realistic example when possible, whether from the internet or from your own data.
Now that we've provided an example to the model, we need to provide the restaurant review to the model by referencing the variable name with Liquid syntax:
Get the variable name from your input in the Start Step (restaurant_review)
Add a user message after the User/Assistant pair you provided from Step 2
Click on the pill of your input variable in the user message - this will apply Liquid syntax to your variable!
User: {{restaurant_review}}
Add a name and emoji for your Workflow to help distinguish it
Test and validate that it works as expected:
Click Test All
Copy and paste a restaurant review to analyze
Click Execute
Click Publish Workflow after testing
Click Run Workflow to see and run your final workflow