AI Assistant
Business users can ask questions about your organization's Cube data model and run queries using natural language. AI Assistant is integrated with the Playground and Semantic Catalog so that users can easily explore their results further.
AI Assistant is available in Cube Cloud on Premium and above (opens in a new tab) product tiers. Contact us (opens in a new tab) for details.
Getting Started
AI Assistant is currently in preview. To get started, please ask your account team to enable AI Assistant for you.
Then, if you've already set up Semantic Catalog, you're ready to use AI Assistant. If you haven't, do the following to enable AI Asisstant:
- In your Cube deployment sidebar, navigate to "Settings" and then "Catalog Services"
- Click the button to enable the Catalog. This will connect your Cube data model and enable AI Assistant.
- If you'd like to connect any downstream business intelligence tools, follow the guide on the Semantic Catalog page.
Using AI Assistant
Users can ask questions and have conversations with the AI Assistant to better understand the data in your Cube data model, to pull data, and run basic analyses. There are two specific types of questions that the AI Assistant can answer: catalog questions and data queries. These are described in more detail below.
Catalog questions
A catalog question is a question about what data is available to the user or what particular data assets mean (for example, a dimension or measure).
Example
A user might want to do some analysis around geographies, but they're not sure if their organization already has dashboards about users' locations or how granular their organization's data on user locations goes. They could ask:
What info do we have about user locations?
The AI Assistant will reply with a summary and display the dashboards, charts, and/or Cube view(s) containing location information for the user to explore.
Data Queries
A data query is one where the user wants the AI Assistant to generate and run a Cube query, and return the results. Users can get quick answers to questions instead of having to ask an analyst, file a ticket, or navigate a complex visualization tool.
Example
A sales analyst might want to know which cities orders are trending in lately. They could ask the following question:
Where did we have the most orders last month?
The query will automatically run in the sidebar and can be opened in the Playground for further exploration.
Advanced Usage
The advanced features discussed here are available on Cube version 1.1.7 and above.
Custom prompts
You can prompt the AI Assistant with custom instructions. For example, you may want it to always respond in a particular language, or to refer to itself by a name matching your brand. Custom prompts also allow you to give the model more context on your company and data model, for example if it should usually prefer a particular view.
To use a custom prompt, set the CUBE_CLOUD_AI_ASSISTANT_PROMPT
environment variable in your deployment.
Custom prompts add to, rather than overwrite, the AI Assistant's existing prompting.
Meta tags
The AI Assistant can read meta tags on your dimensions, measures, segments, and views.
Use the ai
meta tag to give context that is specific to AI and goes beyond what is
included in the description. This can have any keys that you want. For example, you can use it
to give the AI context on possible values in a categorical dimension:
- name: status
sql: status
type: string
meta:
ai:
values:
- shipped
- processing
- completed
Other LLM providers
See the AI API's documentation for information on how to "bring your own" LLM.
FAQ and limitations
1. What language model(s) does the AI Assistant use?
- The AI Assistant currently uses GPT-4o from OpenAI, but this may change in the future
2. Are conversations saved or used for training models?
- Per our terms with the LLM provider(s), they do not use the conversations for training models.
- They may save conversations for up to 30 days for abuse and fraud monitoring purposes.
- Note that customer data (i.e. the results of queries) is never visible to the LLM in the AI Assistant.
3. Can the LLM hallucinate or give incorrect results?
- We make every effort to avoid hallucinations and incorrect results. However, the nature of AI-based systems is that they may make mistakes from time to time.
- If the model hallucinates data assets (such as dimensions, measures, or views) that don't exist, the user will see an error in the playground. It will never return "fake" data, as a valid Cube query is needed to display results.
4. How can I give feedback or train the model?
- To give feedback to the model, use the thumbs-up and thumbs-down buttons that appear under each response.
- If a model is consistently getting something wrong, it may be a sign that the data model is confusing or incomplete. Check things like field labels and descriptions and make sure that irrelevant fields are not marked as visible in your Cube data model.