Skip to content
This repository has been archived by the owner on Sep 3, 2022. It is now read-only.

Charting and Chart Controls

Graham Wheeler edited this page Jun 2, 2016 · 5 revisions

Static and Dynamic Charts

The chart code currently generates both static and dynamic charts. The dynamic charts are generated by Google Charts (or Plotly) as SVG objects. The static charts are created by having the SVG objects render to a PNG.

The reason we do both is so that the saved notebook has a static rendering of the chart to display without having to execute Javascript. This is especially useful in GitHub, which supports viewing static notebooks.

In an environment that can execute Javascript, we don't want to show the static chart if the dynamic one is available. For this reason we add the static chart as an output in the notebook JSON but don't render it. When the notebook is opened in a non-executing environment the PNG output will be shown. In an environment that executes Javascript the PNG will be shown briefly but will be replaced by the dynamic chart once that is available (which will in turn add -but not display - a new static PNG). This explains why charts/tables can seem to 'flash' when opening a notebook; the static PNGs are shown momentarily before being replaced by the dynamic charts.

Chart controls

Improving the Help

One of the complaints we have had about the charts subsystem is that it is not very easy to figure out how to use; the help generated for %chart is minimal.

It was never reviewed and thus never merged, but is worth pointing out that there was a big attempt made to address this by adding both better help text and data schema validation to the chart subsystem. This PR can be found here.

Plotly support

The charts code in JS uses an abstract base class for a chart 'driver'. This has a Google Charts subclass as well as a Plotly subclass. The Plotly subclass is currently very limited and was added to allow us to draw confusion matrices, something not supported by Google Charts.

The code for this is quite ugly because the format of the data passed to the chart render() function is currently optimized for Google Charts, and needs to be quite significantly massaged to be used by Plotly. This may be okay for the current use case, but if we were to extend the Plotly support we would probably want to revisit the data format in order to come up with one that is more general and less Google Charts-specific.

Future

Some things that are worth considering in the future for the charts subsystem:

  • it may make sense to rebuild the chart system using ipywidgets. Right now ipywidgets isn't working 100% in Datalab; possible due to CSS issues. It is close though. The benefit here is that ipywidgets has a number of existing control types that we could use instead of building our own.

  • an interesting recent project on Github that provides similar functionality but with a different idiom is this.

  • changing to ipywidgets in future?