Variable: histogram
consthistogram:ExtendedTool<HistogramToolArgs,HistogramLlmResult,HistogramAdditionalData,EChartsToolContext>
Defined in: packages/echarts/src/histogram/tool.ts:47
The histogram tool is used to create a histogram chart.
Example
import { getVercelAiTool } from '@openassistant/plots';
import { generateText } from 'ai';
const toolContext = {
  getValues: async (datasetName: string, variableName: string) => {
    return SAMPLE_DATASETS[datasetName].map((item) => item[variableName]);
  },
};
const onToolCompleted = (toolCallId: string, additionalData?: unknown) => {
  console.log('Tool call completed:', toolCallId, additionalData);
  // render the histogram using <HistogramComponentContainer props={additionalData} />
};
const histogramTool = getVercelAiTool('histogram', toolContext, onToolCompleted);
generateText({
  model: openai('gpt-4o-mini', { apiKey: key }),
  prompt: 'Can you create a histogram of the revenue per capita for each location in dataset myVenues?',
  tools: {histogram: histogramTool},
});
getValues()
See HistogramFunctionContext for detailed usage.
User implements this function to get the values of the variable from dataset.
For prompts like "can you show a histogram of the revenue per capita for each location in dataset myVenues", the tool will
call the getValues() function twice:
- get the values of revenue from dataset: getValues('myVenues', 'revenue')
- get the values of population from dataset: getValues('myVenues', 'population')
A duckdb table will be created using the values returned from getValues(), and LLM will generate a sql query to query the table to answer the user's prompt.