:github_url: https://github.com/google-deepmind/treescope/tree/main/docs

=========
Treescope
=========

Treescope is an interactive HTML pretty-printer and N-dimensional array
("tensor") visualizer, designed for machine learning and neural networks
research in IPython notebooks. It's a drop-in replacement for the standard
IPython/Colab renderer, and adds support for:

* Expanding and collapsing subtrees of rendered objects, to let you focus on
  the parts of your model that you care about,
* Automatically embedding faceted visualizations of arbitrary-dimensional arrays
  and tensors directly into the output renderings, so you can quickly understand
  their shapes and the distribution of their values,
* Color-coding parts of neural network models to emphasize shared structures,
* Inserting "copy path" buttons that let you easily copy the path to any part of
  a rendered object,
* Customizing the visualization strategy to support rendering your own data
  structures,
* And more!

Treescope was originally developed as the pretty-printer for the
`Penzai neural network library <https://penzai.readthedocs.io/en/stable>`_, but
it also supports rendering neural networks developed with other libraries,
including
`Equinox <https://docs.kidger.site/equinox/>`_,
`Flax NNX <https://flax.readthedocs.io/en/latest/nnx/index.html>`_,
and
`PyTorch <https://pytorch.org/docs/stable/>`_.
You can also use it with basic
`JAX <https://jax.readthedocs.io/en/latest/>`_
and
`Numpy <https://numpy.org/doc/stable/>`_
code.

With Treescope, instead of looking at this:

.. container:: glued-cell-output max-height-20em

  .. glue:any:: treescope_before
    :doc: _include/_glue_figures.ipynb

You could be looking at this:

.. container:: glued-cell-output

  .. glue:any:: treescope_after
    :doc: _include/_glue_figures.ipynb

Or even this:

.. container:: glued-cell-output

  .. glue:any:: treescope_penzai
    :doc: _include/_glue_figures.ipynb

These are interactive visualizations; try clicking the `▶` buttons to expand
parts of the output! (You can also hold shift while scrolling to
scroll horizontally instead of vertically.)

Getting Started
---------------

You can install Treescope using ::

  pip install treescope

and import it using ::

  import treescope

To render a specific object in an IPython notebook with Treescope, you can use
`treescope.show`, which is like `print` but produces a rich interactive output.

Alternatively, you can simply configure Treescope as the default pretty printer
for your notebook via ::

  treescope.register_as_default()

To turn on automatic array visualization, you can run ::

  treescope.active_autovisualizer.set_globally(treescope.ArrayAutovisualizer())

Or, if you'd like to both set up Treescope as the default pretty printer and
enable automatic array visualization, you can simply run ::

  treescope.basic_interactive_setup(autovisualize_arrays=True)

Once you've rendered an object, try clicking on it and pressing the ``r`` key!
This turns on "roundtrip mode", and adds qualified names to every type in the
visualization, making it easier to identify what the types in your object are.

Looking for a neural network library with first-class support for Treescope's
visualization features?
Try `Penzai <https://penzai.readthedocs.io/en/stable>`_!


.. toctree::
  :hidden:
  :caption: Getting Started

  notebooks/pretty_printing
  notebooks/array_visualization
  notebooks/building_custom_visualizations

.. toctree::
   :hidden:
   :caption: API Reference
   :maxdepth: 2

   api/treescope
   api/treescope.canonical_aliases
   api/treescope.context
   api/treescope.dataclass_util
   api/treescope.figures
   api/treescope.formatting_util
   api/treescope.handlers
   api/treescope.lowering
   api/treescope.ndarray_adapters
   api/treescope.renderers
   api/treescope.rendering_parts
   api/treescope.repr_lib
   api/treescope.type_registries


License
-------

Treescope is licensed under the
`Apache 2.0 License <https://github.com/google-deepmind/treescope/blob/main/LICENSE>`_.
