Skip to main content
In W&B Models, methods in wandb.plot let you track charts with wandb.Run.log(), including charts that change over time during training. To learn more about the custom charting framework, see the custom charts walkthrough.

Basic charts

To create a W&B chart:
  1. Create a wandb.Table object and add the data you want to visualize.
  2. Generate a plot using one of the W&B’s built-in helper functions
  3. Log the plot with wandb.Run.log().
The following basic charts can be used to construct basic visualizations of metrics and results.
Log a custom line plot, a list of connected and ordered points on arbitrary axes.
import wandb

with wandb.init() as run:
    data = [[x, y] for (x, y) in zip(x_values, y_values)]
    table = wandb.Table(data=data, columns=["x", "y"])
    run.log(
        {
            "my_custom_plot_id": wandb.plot.line(
                table, "x", "y", title="Custom Y versus X line plot"
            )
        }
    )
You can use this to log curves on any two dimensions. If you’re plotting two lists of values against each other, the number of values in the lists must match exactly. For example, each point must have an x and a y.
Custom line plot
For more information, see the Creating Custom Line Plots With W&B report.Run the code

Model evaluation charts

These preset charts have built-in wandb.plot() methods that make it quick and easy to log charts directly from your script and see the exact information you’re looking for in the UI.
Create a Precision-Recall curve in one line:
import wandb
with wandb.init() as run:
    # ground_truth is a list of true labels, predictions is a list of predicted scores.
    # For example ground_truth = [0, 1, 1, 0], predictions = [0.1, 0.4, 0.35, 0.8]
    ground_truth = [0, 1, 1, 0]
    predictions = [0.1, 0.4, 0.35, 0.8]
    run.log({"pr": wandb.plot.pr_curve(ground_truth, predictions)})
You can log this whenever your code has access to:
  • A model’s predicted scores (predictions) on a set of examples.
  • The corresponding ground truth labels (ground_truth) for those examples.
  • (Optional) A list of the labels or class names. For example, labels=["cat", "dog", "bird"], if label index 0 means cat, 1 means dog, 2 means bird.
  • (Optional) A subset (still in list format) of the labels to visualize in the plot.
Precision-recall curve
For more information, see the Plot Precision Recall Curves With W&B report.Run the code

Interactive custom charts

For full customization, tweak a built-in Custom Chart preset or create a new preset, then save the chart. Use the chart ID to log data to that custom preset directly from your script.
import wandb
# Create a table with the columns to plot.
table = wandb.Table(data=data, columns=["step", "height"])

# Map from the table's columns to the chart's fields.
fields = {"x": "step", "value": "height"}

# Use the table to populate the new custom chart preset.
# To use your own saved chart preset, change the vega_spec_name.
# To edit the title, change the string_fields.
my_custom_chart = wandb.plot_table(
    vega_spec_name="carey/new_chart",
    data_table=table,
    fields=fields,
    string_fields={"title": "Height Histogram"},
)

with wandb.init() as run:
    # Log the custom chart.
    run.log({"my_custom_chart": my_custom_chart})
Run the code

Matplotlib and Plotly plots

Instead of using W&B Custom Charts with wandb.plot(), you can log charts generated with matplotlib and Plotly.
import wandb
import matplotlib.pyplot as plt

with wandb.init() as run:
    # Create a simple matplotlib plot.
    plt.figure()
    plt.plot([1, 2, 3, 4])
    plt.ylabel("some interesting numbers")

    # Log the plot to W&B.
    run.log({"chart": plt})
Just pass a matplotlib plot or figure object to wandb.Run.log(). By default we’ll convert the plot into a Plotly plot. If you’d rather log the plot as an image, you can pass the plot into wandb.Image. We also accept Plotly charts directly.
If you get an error like “You attempted to log an empty plot”, store the figure separately from the plot with fig = plt.figure() and then log fig in your call to wandb.Run.log().

Log custom HTML to W&B Tables

W&B supports logging interactive charts from Plotly and Bokeh as HTML and adding them to Tables.

Log Plotly figures to Tables as HTML

You can log interactive Plotly charts to W&B Tables by converting them to HTML.
import wandb
import plotly.express as px

# Initialize a new run.
with wandb.init(project="log-plotly-fig-tables", name="plotly_html") as run:

    # Create a table.
    table = wandb.Table(columns=["plotly_figure"])

    # Create path for Plotly figure.
    path_to_plotly_html = "./plotly_figure.html"

    # Example Plotly figure.
    fig = px.scatter(x=[0, 1, 2, 3, 4], y=[0, 1, 4, 9, 16])

    # Write Plotly figure to HTML.
    # Set auto_play to False prevents animated Plotly charts
    # from playing in the table automatically.
    fig.write_html(path_to_plotly_html, auto_play=False)

    # Add Plotly figure as HTML file into Table.
    table.add_data(wandb.Html(path_to_plotly_html))

    # Log table.
    run.log({"test_table": table})

Log Bokeh figures to Tables as HTML

You can log interactive Bokeh charts to W&B Tables by converting them to HTML.
from scipy.signal import spectrogram
import holoviews as hv
import panel as pn
from scipy.io import wavfile
import numpy as np
from bokeh.resources import INLINE

hv.extension("bokeh", logo=False)
import wandb


def save_audio_with_bokeh_plot_to_html(audio_path, html_file_name):
    sr, wav_data = wavfile.read(audio_path)
    duration = len(wav_data) / sr
    f, t, sxx = spectrogram(wav_data, sr)
    spec_gram = hv.Image((t, f, np.log10(sxx)), ["Time (s)", "Frequency (hz)"]).opts(
        width=500, height=150, labelled=[]
    )
    audio = pn.pane.Audio(wav_data, sample_rate=sr, name="Audio", throttle=500)
    slider = pn.widgets.FloatSlider(end=duration, visible=False)
    line = hv.VLine(0).opts(color="white")
    slider.jslink(audio, value="time", bidirectional=True)
    slider.jslink(line, value="glyph.location")
    combined = pn.Row(audio, spec_gram * line, slider).save(html_file_name)


html_file_name = "audio_with_plot.html"
audio_path = "hello.wav"
save_audio_with_bokeh_plot_to_html(audio_path, html_file_name)

wandb_html = wandb.Html(html_file_name)

with wandb.init(project="audio_test") as run:
    my_table = wandb.Table(columns=["audio_with_plot"], data=[[wandb_html]])
    run.log({"audio_table": my_table})