Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions explore-analyze/toc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -274,6 +274,7 @@ toc:
children:
- file: visualize/charts/area-charts.md
- file: visualize/charts/bar-charts.md
- file: visualize/charts/heat-map-charts.md
- file: visualize/charts/line-charts.md
- file: visualize/charts/metric-charts.md
- file: visualize/charts/pie-charts.md
Expand Down
231 changes: 231 additions & 0 deletions explore-analyze/visualize/charts/heat-map-charts.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,231 @@
---
navigation_title: Heat map charts
applies_to:
stack: ga
serverless: ga
products:
- id: kibana
description: Instructions and best practices for building heat map charts with Kibana Lens in Elastic.
---

# Build heat map charts with {{kib}}

Heat map charts display data as a grid of colored cells, where each cell's color represents the magnitude of a value. They are ideal for visualizing patterns across two categorical or temporal dimensions, identifying correlations, and spotting anomalies in large datasets.

You can create heat map charts in {{kib}} using [**Lens**](../lens.md).

![Example Lens heat map chart representing temperatures in various cities](/explore-analyze/images/heat-map-chart-example.png)

## Build a heat map chart

:::{include} ../../_snippets/lens-prerequisites.md
:::

To build a heat map chart:

::::::{stepper}

:::::{step} Access Lens
**Lens** is {{kib}}'s main visualization editor. You can access it:
- From a dashboard: On the **Dashboards** page, open or create the dashboard where you want to add a heat map chart, then add a new visualization.
- From the **Visualize library** page by creating a new visualization.
:::::

:::::{step} Set the visualization to Heat map
New visualizations often start as **Bar** charts.

Using the **Visualization type** dropdown, select **Heat map**.
:::::

:::::{step} Define the data to show
1. Select the {{data-source}} that contains your data.
2. Configure the [**Horizontal axis**](#horizontal-axis-settings) dimension to define the columns of the heat map.
3. Configure the [**Cell value**](#cell-value-settings) dimension to define the metric that determines cell colors.

Optionally:
- Configure the [**Vertical axis**](#vertical-axis-settings) dimension to define the rows of the heat map. Without a vertical axis, the heat map displays a single row of colored cells.

The chart preview updates to show a grid of colored cells. Cell colors represent the magnitude of the metric value. If the grid appears empty, verify that the axes have data for the current time range.
:::::

:::::{step} Customize the chart to follow best practices
Tweak the appearance of the chart to your needs. Consider the following best practices:

**Choose appropriate dimensions**
: Select dimensions that have a reasonable number of distinct values. Too many values create unreadable grids with tiny cells.

**Use sequential color palettes**
: For data that ranges from low to high, use a sequential palette (light to dark). Reserve diverging palettes for data with a meaningful midpoint.

**Consider data density**
: If cells are too small to read, reduce the number of buckets or use a larger time interval on your axes.

**Order categories meaningfully**
: For categorical axes, order values logically (alphabetically, by frequency, or by a natural ordering like days of the week).

Refer to [Heat map chart settings](#heat-map-chart-settings) to find all configuration options for your heat map chart.
:::::

:::::{step} Save the chart
- If you accessed Lens from a dashboard, select **Save and return** to save the visualization and add it to that dashboard, or select **Save to library** to add the visualization to the Visualize library and reuse it later.
- If you accessed Lens from the Visualize library, select **Save**. A menu opens and offers you to add the visualization to a dashboard and to the Visualize library.
:::::

::::::

## Advanced heat map chart scenarios

### Highlight anomalies with custom color ranges [anomaly-colors]

You can configure custom color ranges on the **Cell value** dimension to emphasize unusual values, making outliers immediately visible.

1. Create a **Heat map** chart with your dimensions configured.
2. Select the **Cell value** dimension to open its settings.
3. In the **Color palette** configuration, select **Custom** to define your own color ranges:
- Normal range: Neutral colors (blues, grays)
- Anomalous range: Attention-grabbing colors (red, orange)

![Example Lens heat map chart showing error rates per day for various errors](/explore-analyze/images/heat-map-chart-example-server-errors.png)

## Heat map chart settings [heat-map-chart-settings]

Customize your heat map chart to display exactly the information you need, formatted the way you want.

### Horizontal axis settings [horizontal-axis-settings]

The **Horizontal axis** dimension defines the columns of the heat map.

**Data**
: The **Horizontal axis** dimension supports the following functions:

- **Top values**: Create columns for the most common values in a field.
- **Field**: Select the field to group by. You can add up to 4 fields to create multi-term columns. When multiple fields are selected, each column represents a unique combination of values across those fields. You can reorder the fields by dragging them to change their priority.
- **Number of values**: How many top values to display.
:::{include} ../../_snippets/lens-rank-by-options.md
:::
:::{include} ../../_snippets/lens-breakdown-advanced-settings.md
:::
- **Date histogram**: Group data into time-based buckets.
- **Field**: Select the date field to use for the time-based grouping.
:::{include} ../../_snippets/lens-histogram-settings.md
:::
- **Intervals**: Create numeric ranges for continuous data.
- **Field**: Select the numeric field to create intervals from.
- **Include empty rows**: Include intervals with no matching documents.

**Appearance**
: - **Name**: Customize the axis label.

### Vertical axis settings [vertical-axis-settings]

The **Vertical axis** dimension defines the rows of the heat map.

**Data**
: The **Vertical axis** dimension supports the same functions as the horizontal axis:

- **Top values**: Create rows for the most common values in a field.
- **Field**: Select the field to group by. You can add up to 4 fields to create multi-term rows. When multiple fields are selected, each row represents a unique combination of values across those fields. You can reorder the fields by dragging them to change their priority.
- **Number of values**: How many top values to display.
:::{include} ../../_snippets/lens-rank-by-options.md
:::
:::{include} ../../_snippets/lens-breakdown-advanced-settings.md
:::
- **Date histogram**: Group data into time-based buckets.
- **Field**: Select the date field to use for the time-based grouping.
:::{include} ../../_snippets/lens-histogram-settings.md
:::
- **Intervals**: Create numeric ranges for continuous data.
- **Field**: Select the numeric field to create intervals from.
- **Include empty rows**: Include intervals with no matching documents.

**Appearance**
: - **Name**: Customize the axis label.

### Cell value settings [cell-value-settings]

The **Cell value** dimension defines the metric that determines cell colors.

**Data**
: The value that determines cell color intensity. When you drag a field onto the chart, {{kib}} suggests a function based on the field type. You can use aggregation functions like `Sum`, `Average`, `Count`, `Median`, and more, or create custom calculations with [formulas](/explore-analyze/visualize/lens.md#lens-formulas).

:::{include} ../../_snippets/lens-value-advanced-settings.md
:::

**Appearance**
: - **Name**: Customize the metric label displayed in tooltips.
- **Value format**: Control how numeric values are displayed (number, percent, bytes, and more).
- **Color palette**: Configure the color palette that maps cell values to colors. The default palette is **Temperature**. You can select a different palette, reverse the color direction, and define custom color ranges with specific value-to-color mappings.

### General layout [appearance-options]

When creating or editing a visualization, you can customize several appearance options from the {icon}`brush` **Style** or ![Legend icon](/explore-analyze/images/kibana-legend-icon.svg "") **Legend** menus.

#### Style settings

**Titles and text**

**Value labels**
: Control whether cell values are displayed as text inside each cell:
- **Hide**: Do not display values in cells (default).
- **Show, if able**: Display the metric value inside each cell when there is enough space. Cells that are too small to fit the text will not show a label.

**Vertical axis**

**Axis title**
: Show or hide the vertical axis title. When visible, you can enter a custom title or use the default field name.

**Tick labels**
: Toggle whether to show or hide the tick labels on the vertical axis.

**Horizontal axis**

**Axis title**
: Show or hide the horizontal axis title. When visible, you can enter a custom title or use the default field name.

**Tick labels**
: Toggle whether to show or hide the tick labels on the horizontal axis.

**Orientation**
: Control the orientation of horizontal axis tick labels. Only available when **Tick labels** is enabled.
- **Horizontal**: Labels are displayed horizontally (default).
- **Vertical**: Labels are rotated 90 degrees.
- **Angled**: Labels are displayed at a 45-degree angle.

#### Legend settings

**Visibility**
: Show or hide the legend:
- **Show**: Display the legend (default).
- **Hide**: Do not display the legend.

**Width**
: Control the width of the legend panel. Options include **Small**, **Medium**, **Large**, and **Extra large**.

**Label truncation**
: Toggle whether to truncate long legend labels. When enabled, set the **Line limit** to control the maximum number of lines for each label (defaults to 1).

## Heat map chart examples

The following examples show various configuration options for building impactful heat map charts.

**Request volume by day and hour**
: Visualize when your website receives the most traffic using a runtime field that extracts the hour of the day (0-23) from `@timestamp`:

* Example based on: {{kib}} Sample Data Logs
* **Horizontal axis**: `@timestamp` (Date histogram, daily)
* **Vertical axis**: `hour_of_day` (Top 24 values, "Aggregate by this dimension first" active, ranked by descending alphabetical order)
* **Cell value**: Count
* **Color palette**: Cool (sequential)

![Heat map showing request volume by hour and day](/explore-analyze/images/heat-map-example-request-volume.png "=70%")

**Sales performance by product and region**
: Compare product sales across geographic regions:

* Example based on: {{kib}} Sample Data eCommerce
* **Horizontal axis**: `geoip.city_name` (Top 10 values)
* **Vertical axis**: `category.keyword` (Top values)
* **Cell value**: `Sum(taxful_total_price)`
* **Color palette**: Positive (sequential)

![Heat map showing sales performance by product and region](/explore-analyze/images/heat-map-example-sales-performance.png "=70%")
2 changes: 1 addition & 1 deletion explore-analyze/visualize/lens.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ With Lens, you can create the following visualization types:
- [Table](/explore-analyze/visualize/charts/tables.md)
- [Pie chart](/explore-analyze/visualize/charts/pie-charts.md)
- Gauge chart
- Heat map chart
- [Heat map chart](/explore-analyze/visualize/charts/heat-map-charts.md)
- Waffle chart
- Region map chart
- Treemap chart
Expand Down
Loading