Skip to main content
App version: 3.20251006

Configure a chart widget

Create custom chart widgets and include them in your dashboards and reports.

A chart with the following elements highlighted: a menu button, edit button, smoothing slider, and toggle for displaying point previews.

Create a widget

To add a new widget to your dashboard or report:

  1. In the top toolbar, click New widget and select Chart.

  2. (Optional) Change the chart title.

    The default chart title is based on the Y-axis series.

  3. Configure the X and Y axes.

  4. (Optional) To make each graph represents the mean of a run group, toggle Average grouped runs.

  5. Click Add widget.

    To create multiple charts in a row, toggle Create more. This option remembers all settings except for the Y-axis series.

Configure the X axis

You can specify the following X-axis options in your chart:

  • In Series, define the input values. You can choose from the following:

  • In Axis controls, set the axis range and choose the scale: linear, logarithmic, or inherited from global settings.

Configure the Y axis

You can specify the following Y-axis options in your chart:

  • In Series, select the metrics to display on the chart. The following options are available:

  • In Axis controls, set the axis range and choose the scale: linear, logarithmic, or inherited from global settings.

    Info

    Neptune distributes axis points evenly, even when the scaling is non-linear.

Supported attribute types

The chart widget supports the following data types:

Metadata typeNeptune attribute type
Numerical series (metrics, loss, accuracy)FloatSeries

Compare multiple metrics on one chart

To display several metrics on one chart widget:

  1. In a dashboard or report, add a new chart widget or edit an existing one.

  2. In Y-axisSeries, select at least two metrics or custom expressions.

    You can combine metrics with custom expressions.

  3. Configure other options as needed and save your changes.

You can plot a maximum of 1000 graphs on a single chart. For example, if you're displaying 20 metrics from each run, you can select a maximum of 50 runs to compare.

Select metrics dynamically

Use regular expressions to select all metrics that match the pattern and dynamically display them on a chart. When you log more metrics that match the pattern, the chart gets updated automatically to include them.

note
  • When you log new metrics that match an already applied regular expression, refresh the page to see them displayed on the chart.
  • Dynamic selection isn't available in auto-generated dashboards.

To dynamically display metrics on the chart:

  1. In a dashboard or report, create or edit a chart widget.

  2. Go to Y-axisSeriesDynamic selection.

  3. In the input box, type a regular expression and click Apply.

    You can apply one regular expression per chart. See also Syntax reference.

Create multiple charts at once

To create a separate chart for every selected metric:

  1. In a dashboard or report, add a new chart widget or edit an existing one.

  2. In Y-axisSeries, select at least two metrics.

  3. In Single or multi-chart, select Create a chart for each Y-axis.

Once you save your changes, multiple widgets are created, one for every selected metric.

Custom Y or X expressions

In dashboards and reports, you can build mathematical expressions of logged metadata. A single expression can consist of several attribute names and operations.

Using expressions lets you calculate and display derivative metrics after the data is logged. For example, a weighted average of five separate metrics.

Create a custom expression

To create a custom expression:

  1. In a dashboard or report, create or edit a chart widget.

  2. In Series, select Use custom expression.

  3. Name your expression.

  4. In the input box, type ${ and select an attribute from the drop-down menu. To complete the expression:

    • Use at least one supported operator

    • (Optional) Add more attributes, using the following syntax for each attribute:

      ${AttributeName}
  5. Save your changes. The expression is applied automatically.

Supported operators

For detailed descriptions of the supported functions, see ClickHouse SQL Reference.

See all supported functions
  • Operators

    OperatorSyntaxExample
    Addition+${metric1} + ${metric2}
    Subtraction-${metric1} - ${metric2}
    Multiplication*${metric1} * ${metric2}
    Division/${metric1} / ${metric2}
    Completion of metric calculationcompletion()completion(${metric})
    Maximummax()max(${metric1}, ${metric2}, 0.5)
    Minimummin()max(${metric1}, ${metric2}, 0.5)

    The arguments of the max() and min() functions can be attribute names, values, or expressions.

  • Arithmetic functions

    FunctionDescription
    negate()Negates the value of an argument.
    abs()Calculates the absolute value of an argument.
  • Mathematical functions

    • e()
    • pi()
    • exp()
    • exp2()
    • exp10()
    • intExp2()
    • intExp10()
    • log()
    • log2()
    • log10()
    • lgamma()
    • tgamma()
    • cbrt()
    • sqrt()
    • sin()
    • sinh()
    • cos()
    • cosh()
    • tan()
    • tanh()
    • asin()
    • asinh()
    • acos()
    • acosh()
    • atan()
    • atanh()
    • erf()
    • erfc()
    • sign()
    • sigmoid()
    • degrees()
    • radians()
    • factorial()
  • Rounding functions

    FunctionDescription
    floor()Returns the largest rounded number less than or equal to an argument.
    ceil()Like floor() but returns the smallest rounded number greater than or equal to an argument.
    trunc()Like floor() but returns the rounded number with largest absolute value that has an absolute value less than or equal to the arguments.
    round()Rounds a value to a specified number of decimal places.
    roundToExp2()Accepts a number. If the number is less than one, it returns 0. Otherwise, it rounds the number down to the nearest (whole non-negative) degree of two.
    roundDuration()Accepts a number. If the number is less than one, it returns 0. Otherwise, it rounds the number down to numbers from the set of commonly used durations.
  • Functions for generating random numbers

    FunctionReturned value
    rand()A random UInt32 number with uniform distribution.
    rand64()A random UInt64 integer (UInt64) number.
    randCanonical()A random Float64 number.

Example expressions

(${accuracy} - ${loss}) * some_value
exp(${accuracy} / 0.4)
log(${accuracy}) * 2
min(0.5, ${accuracy}, max(0.3, ${accuracy}-0.2))

Apply smoothing

To apply smoothing, access the widget menu (). You can:

  • Set the smoothing factor either with the slider or by inputting a number from 0 to 100.
  • Choose the smoothing algorithm.

Configure custom error bands

In the Advanced settings of a chart widget, you can disable the default error bands or configure your own custom bands. For details, see Error bands in charts.

Display point previews

To display incomplete points on charts, you must first log metric previews. Note that Neptune considers all metric previews as incomplete, regardless of their completion level.

Chart widget in the Neptune app. Displays both the metric and its completion level.

Show or hide incomplete points

Point previews are displayed by default. Charts that contain incomplete points have a special icon in the toolbar.

To display or hide the incomplete points, do one of the following:

  • Click the icon in the toolbar.
  • Open the widget menu () → Display point previews and select an option from the dropdown. To apply the global settings, choose Inherited.
View the completion level

To plot the completion level as a shaded area in the chart:

  1. In you account settings, go to Experimental features.
  2. Enable Show completion level of metrics.

Display reference lines

Reference lines are horizontal markers in charts that add more context to your visualizations. Use the reference lines to highlight values and compare data against them. For example, you can visualize how far the training is from the target value.

To add reference lines in charts:

  1. In a dashboard or report, create or edit a chart widget.
  2. In Advanced settings, enable Reference lines.
  3. Define the following options:
    • Name – in the chart legend, you can identify the line by its name
    • Value
    • Color – provide a hex or RGB value, or use the color picker
    • Style – choose between solid, dashed, or dotted
  4. To create another line, click Add line.

You can duplicate or delete the line from its menu (). To show or hide the line without deleting it, use the eye icon.

A chart widget with three reference lines and a chart legend.

Normalize by first value

To normalize data plotted in the chart:

  1. Add a new chart widget or edit an existing one.
  2. In Advanced settings, switch on Normalize by first value.

With this setting on, the first value of each series is substracted from all points. As a result, all series start at 0 on the Y-axis. The x values remain the same.

Note that when the Show inherited datapoints option is on, the first value comes from the earliest step logged in the lineage. Otherwise, it comes from the first step logged in the run.

Edit a widget

  • To change the attributes displayed on the chart, go to Edit chart widget.

  • To change the chart settings, open the widget menu ().

    A purple dot on the widget menu indicates that custom settings already apply to the chart.

    An orange dot on the widget menu indicates that custom settings differ from the currently configured global settings.

  • To rename the chart, double click its title or open the widget menu () and enter a new name in the input box.

  • To resize the widget, click and drag its bottom right corner.

Download or export a chart

To access download options for a chart, go to the widget menu (). You have the following options:

  • To duplicate the chart widget in the dashboard or report you're currently working on, select Duplicate.
  • To export the chart widget to a new or existing dashboard or report, select Move to.
  • To copy the chart as an image, select Copy to clipboard.
  • To download the chart as a PNG image, select Export image.