This page describes a Guided Search feature in Vertex AI Search for commerce conversational search.
Conversational search enables retailers to provide a more interactive search experience for their users. The conversational search feature functions as part of the Guided Search package, benefiting customers by narrowing user queries and presenting relevant products faster.
Read more to find out about:
- How conversational search works
- The serving experience through the main (query) API
- The administrator experience through the control API and console
How conversational search works
When it is enabled, Conversational Vertex AI Search for commerce guides shoppers through their product search on merchandiser sites using conversation. After an initial text query in Vertex AI Search for commerce the online shopper gets a relevant follow-up question and multiple choice options. The follow-up question can either be answered by the user in free text or by clicking on a conversational multiple choice option.
If conversational search is enabled on the retailer site, follow-up questions drive a conversation that ensues until one of the three following scenarios occur:
- A preconfigured minimum product count is reached (a conversation is not useful when only two products show up, for instance).
- The user clicks on a product and adds it to their cart (the objective).
- Search and browse for retail runs out of AI-generated questions.
Under the hood
Conversational search is based on engaging the user with an ongoing conversation of multiple turns. Therefore, there is at least a second response required for conversational search to work. The user is presented with a follow-up question and suggested answers in the response. The user can respond to this follow-up question either by entering their answer or by clicking on a suggested answer (multiple choice option).
Multiple choice The multiple choice option functions behind the scenes like a facet (an event type filter), which narrows the query using filtering. In the background, when the user clicks on a multiple choice response, a filter is applied to the query. Applying a filter using conversational multiple choice is identical to applying the same filter using dynamic facets or tiles.
Free text If the user responds in free text, a new and narrower query is generated. Learn more about how conversational search enriches filter and user event capturing in the user journey.
Benefits of conversational search
Augmenting the Vertex AI Search for commerce experience with conversational search offers several benefits to both the retailer and the user.
Narrow queries in very few clicks
Conversational search offers a rapid way to filter 10,000 products down to less than 100 products more efficiently. This makes it more likely that the user decides to make a purchase, increasing the revenue-per-search rate.
Alternative to dynamic facets
Dynamic facets are associated with broad queries which have low revenue per query. Customers can become overwhelmed when they see tens of thousands of results, creating the risk that they abandon their search experience. In particular, search queries that return high product counts have an unusually low revenue per query. Conversational search is able to refine queries and can be used in conjunction with dynamic facets. Conversational search offers some advantages over dynamic facets, being more human, more interactive, and using less on-page real estate.
Customizable generative questions adapted to retailer preferences
Conversational search encourages a human-in-the-loop interaction with the generative AI questions by allowing retailers to preliminarily edit, overwrite or deselect AI-generated questions according to their preferences, based on the uploaded catalog. Questions can be edited or disabled individually or in bulk in the Console Search for commerce or the API in order to tailor the questions they want to appear in the search.
Console: Admin experience
The console allows retailers to manage generative questions in a conversational Vertex AI Search for commerce experience. Learn more about using generative questions in conversational search.
Steps to use the generative question service
Satisfy data requirements.
Configure manual overrides.
Turn the feature on.
Data requirements
In the console, Conversational search and browse, under the Coverage checks tab, or under Data quality > Conversation, you will see whether your search data is ready for conversational search.
In order to enable conversational search, you need to meet certain data requirements.
These are:
- 1,000 queries per day: After you reach this first threshold, a conversation plan is generated that evaluates your inputs and outputs:
- Inputs: filter count in events
- Outputs: conversational coverage
- 25% conversational coverage: Calculated by Vertex AI Search for commerce models, conversational coverage means the percentage of queries that have one question. A frequency-weighted 25% (by volume) of queries should have at least a first question that matches it.
If you don't have 25% conversational coverage yet, but have the first prerequisite 1000 queries per day, blocking and advisory checks begin to be applied to your outputs and inputs, respectively. Here, Vertex AI Search for commerce begins to calculate by how much of a percentage your user-event-applied filters have to increase in order to reach the 25% conversational coverage threshold. The more filters that are uploaded, the higher the coverage reached.
To view your conversational readiness:
Go to the Conversation tab in the Data quality page in the Search for commerce console. Here you will see the critical check of whether a minimum of 25% of search queries have at least one follow-up question, as well as advisory checks as to which percentage of user events with valid filters is needed to reach that conversational coverage goal.
If you pass the critical check, with sufficient user events with valid filters, proceed to the next step.
To control how generative questions are served, go to the Conversational search and browse page in the Search for commerce console.
Generative question controls
The generative AI writes a question for every indexable attribute in the catalog, using both names and values of attributes for system and custom attributes. These questions are generated by an LLM and aim to enhance the search experience. For example, for furniture type, values can be indoor or outdoor, the AI will synthesize a question about what type of furniture you are looking for.
Each facet will have one generated question. Based on historic user events and facet engagement from past search event data, the questions are sorted by expected frequency of the question appearing. The AI will first look at the questions on top, then find what is relevant by attribute. The list of questions is generated once. If a new attribute is added, it will be reflected in the list in two hours.
Go to the Conversational search and browse page in the Search for commerce console.
Go to the Conversational search and browse page.Under the Manage AI generated questions tab, you can see all questions sorted by how often they are used, in query-weighted frequency, meaning how often they are served with common queries. The ranking uses the frequency field in the
GenerativeQuestionConfig
. This field is responsible for sorting the AI-generated questions by how often they are used.You can use the filter option to filter the questions.
Check the box to enable question visibility for each attribute.
Click edit at the end of each row to open an edit panel for each question.
To make bulk edits, follow these steps:
Select or clear the boxes next to the questions you want to include or exclude in conversation.
Click either the addAllow in conversation or the removeDisallow in conversation buttons that appear at the top of the list. Alternatively, to edit an individual question, click edit and clear or recheck the box next to Allowed in conversation in the pane that opens:
How to use generative questions in conversational search
The generative question service API provides controls to mitigate potential inconsistencies in the LLM output. These can be managed from the console. Here, retailers can also configure conversational search by toggling its enabled state and setting the minimum number of products required to trigger it.
You can define the questions, specifying the question itself, potential answers, and whether the question is allowed in the conversation. Individual questions can be generated by an LLM or overridden by the retailer. The console supports reviewing AI-generated questions, allowing retailers to override them or toggle their conversational status. Questions can also be bulk edited.
Edit individual questions
You can also use controls to curate the individual questions. It is recommended to do this before you turn conversational search on.
For each question, there are two options. Click edit in in the last column to access the questions visible to the users panel:
- Turn off a question for all queries: The question will be enabled by default. Clear (or check again) the box next to Allowed in conversation. This option skips the question altogether. A retailer may opt to disable a question entirely if it does not relate to the queried attributes or could be misconstrued as inappropriate in some way (a question such as "What dress size are you looking for?" may be perceived as prying about a shopper's weight.)
- Rewrite a question: In the pane, you can see the AI-generated question, what attribute it is attached to and what values the attribute has. Click the pencil to rewrite it.
Turn on conversational search
After you have edited your generative AI questions in the console, you are ready to turn on conversational search.
To enable conversational search, go to the Conversational search and browse page in the Search for commerce console.
Go to the Conversational search and browse page in the Search for commerce console.
Go to the Conversational search and browse page.Under the Configure tab in the Search for commerce, you will find the system-wide setting. This includes setting the minimum products needed to match the query before a conversation can happen, thus when questions are generated. This minimum number is =>2. The minimum can be configured to be higher but never lower than 2. Consider the amount of products in your catalog you want to have returned in the search for users to begin a conversation. For example, a sweet spot for this number is one row to a page for minimum search results to trigger a conversation.
Switch the toggle to on. This page also provides information as to the status of your blocking and advisory checks. If you have enough search queries with at least one follow-up question, your site is now conversational search enabled.
Evaluate and test
Evaluate lets you preview the serving experience by running a test search and testing your questions against displayed facets. This part of the console provides you with a preview of your serving experience with conversational search.
To do so, find this module under the Search or Browse tabs in the Evaluate page of the Search for commerce console.
Go to the Evaluate page in the Search for commerce console.
Go to the Evaluate pageIn the Search Evaluation field, enter a test query that makes sense based on the catalog you have uploaded to search. Click Search preview. You will see search results and if you have conversational search enabled, you will see generative questions on the right panel.
On the right panel, you will see a list of test questions.
Generative question API: Admin experience
This section describes how to use the generative question API to integrate the conversational search API into your UI, manage the generative questions, and serve the feature on your site.
API integration
- Manage the GenerativeQuestion API from the Search for commerce using:
Objects:
- GenerativeQuestionsFeatureConfig
- GenerativeQuestionConfig
- GenerativeQuestions Service
- UpdateGenerativeQuestionsFeatureConfiguration
- UpdateGenerativeQuestionConfig
- ListGenerativeQuestionConfigs
- GetGenerativeQuestionFeatureConfig
- BatchUpdateGenerativeQuestionConfigs
The core of the integrating this feature lies in defining the "question" resource. This includes the question itself and whether the question is allowed in the conversation. The question is by default generated by an LLM but can be overridden by the administrator.
Enable the feature
Object:
- GenerativeQuestionsFeatureConfig
This object is a control configuration file for enabling the feature for generative questions to manage the overall serving experience of conversational search. GenerativeQuestionsFeatureConfig obtains using a GET method attribute information and whether the attributes are indexable or not from the catalog associated with the project.
The feature_enabled
switch determines whether questions are used at serving time. It manages the top-level toggles in the console.
Learn more about how you can turn on conversational search in the console.
Manage the generative questions
Object:
- GenerativeQuestionConfig
It can be conversation-enabled with the boolean field allowed_in_conversation
. It controls the configuration for a single generated question.
Fields (control behaviors for conversation highlighted) | |
catalog | string Used to identify which set of attributes (and by extension questions) are available. These values are all defined in the catalog. Required field. |
facet | string Facet to which a question is associated. Required field. |
generated_question | string The LLM generated default question. Output only. |
final_question | string The question that will be asked. It can have a max length of 300 bytes. Optional field. |
example_values | Repeated string Values that can be used to answer the question. Output only |
frequency | float The ratio of how often a question was asked. Output only. |
allowed_in_conversation | boolean Whether the question is asked at serving time. This field is optional. |
Serving experience enabled by this feature
The generative questions service (service GenerativeQuestionService{...}
) is used for managing LLM-generated questions. Its parent object is the catalog, where it retrieves information to return questions for a given catalog. The service is used to manage the overall generative question feature state, make individual or batch changes, and toggle questions on or off. Data requirements must be met to interface with the Service API and the questions need to first be initialized before they can be managed.
The service interacts with the feature level and question level configs with two sets of handlers:
GenerativeQuestionsFeatureConfig handlers (feature-level):
- Update: lets you change minimum products and enable fields
- Get: returns an object
GenerativeQuestion Config handlers (question-level):
- List: Returns all questions for a given catalog
- Update: Individual question management
- Batch Update: Grouped question management
The service will return a semantically appropriate question based on the initial query.
A follow-up question is generated by the LLM model and can be overridden. The questions are displayed based on how likely it will be used by customers by calling the search event history. If there is no search event history, the fallback is on the retailer search logs.
Different questions are generated based on the previous query. There are no fixed weights. The AI that drives the LLM-generated questions learns from the queries, and changes the weighting for every query, so that "shirt", for example, weighs the category very heavily, but "XL red shirt" weighs category, size and color.
Conversational search configuration API: Serving experience
The conversational search configuration API is integrated with the Vertex AI API search API.
API integration
The configuration API ConversationalSearchSpec
for the feature sits on top of the existing Vertex AI Search for commerce API. To support the new feature, conversational search, the following changes have been made to the already existing Vertex AI Search for commerce main (query) API:
ConversationalSearchSpec
: This optional field has been added in SearchRequest but is required if you want to use the conversational search feature. The field reuses the SearchRequest fields, query and filter. It also includes a field to enable a follow-up question served to the user after an initial query and aconversation_id
to maintain the state of the conversation between the client and server.ConversationalSearchResult
: A proto file contains extra information needed to be returned for the conversational CRS flow inSearchResponse
. This includes aconversation_id
,refined_query
,additional_filters
,follow_up_question
, andsuggested_answers
(see the User journey section).
User journey
The conversational flow works as follows: The user initiates a search with an initial query and the followup_conversation_requested
flag set to "true." The user then selects an answer or provides free-text input, which is sent back to the API using the user_answer
field. The API then refines the search results based on the user's input and provides a new follow-up question, prompting a follow-up query and continuing the conversation in multiple turns until the user finds what they're looking for on the retailer website.
Assuming conversational search is enabled on the website, the user journey and subsequent interaction with Vertex AI Search for commerce follows this path:
- Step 1. First query comes from user
- Step 1a. Follow-up conversation requested sent to search
- Step 1b. Initial Search response with refined query and suggested answers
- Scenario 2: User selects multiple choice
- Step 2a. Selected answer filter sent to search
- Step 2b. Search run again with filter applied
- Scenario 3: User selects free text
- Step 3a. Text answer sent to Search
- Step 3b. Search run again with a modified query
Step 1. First query comes from user
conversational_search_spec
: The introduction of this field within the SearchRequest
message allows the system to distinguish between conversational and regular searches. This determination influences whether users receive additional conversational responses, thus preserving the original search capabilities while extending it for conversational interactions. The conversational_search_spec
field is in the message format and houses details necessary for the conversational flow, such as user answers, conversation IDs and whether the user wants a follow up conversation. This information guides the system in understanding the context and user interactions.
If the followup_conversation_requested
boolean If this field is set to TRUE, the API responds with an initial set of results and a follow-up question. The user will be provided a conversational experience in their search. If this field is set to "FALSE", no follow-up question is served.
Step 1a. Retailer → search: Initial query with conversation enabled
Step 1b. Search → retailer: conversation ID, refined query, follow-up question, suggested answers
Scenario 2: User selects a multiple choice option
If a user selected a multiple choice answer yellow
:
- The
conversation_id
is restored from session storage. followup_conversation_requested
is set to be true.user_answer
string, uses either "selected_answer," which contains one product_attribute_value key-value pair, ortext_answer
which contains the value free text input to indicate the user's choice. This field is within theconversational_search_spec
field and contains further nested messages like "SelectedAnswer" to specify the user input types (text or selected answers).- The result reverts to calling the
SearchResults
object and its fields. selected_answer
This field passes the product attributes to guide the conversational search.
Step 2a. Retailer → search: selected answer filter
Step 2b. Search → retailer: filters applied
Scenario 3: User selects a free text input
If a user types in lavender
:
- the
conversation_id
is restored from session storage followup_conversation_requested
is set to trueuser_answer
is set for what the user inputs (with thetext_answer:
prefix)