Pythagorean Tree

Pythagorean tree visualisation for classification or regression trees.

Inputs
Tree
tree model
Selected Data
instances selected from the tree

Pythagorean Trees are plane fractals that can be used to depict general tree hierarchies as presented in an article by Fabian Beck and co-authors. In our case, they are used for visualizing and exploring tree models, such as Tree.

../../_images/Pythagorean-Tree1-stamped.png
  1. Information on the input tree model.

  2. Visualization parameters:

    • Depth: set the depth of displayed trees.
    • Target class (for classification trees): the intensity of the color for nodes of the tree will correspond to the probability of the target class. If None is selected, the color of the node will denote the most probable class.
    • Node color (for regression trees): node colors can correspond to mean or standard deviation of class value of the training data instances in the node.
    • Size: define a method to compute the size of the square representing the node. Normal will keep node sizes correspond to the size of training data subset in the node. Square root and Logarithmic are the respective transformations of the node size.
    • Log scale factor is only enabled when logarithmic transformation is selected. You can set the log factor between 1 and 10.
  3. Plot properties:

    • Enable tooltips: display node information upon hovering.
    • Show legend: shows color legend for the plot.
  4. Reporting:
    • Save Image: save the visualization to a SVG or PNG file.
    • Report: add visualization to the report.

Pythagorean Tree can visualize both classification and regression trees. Below is an example for regression tree. The only difference between the two is that regression tree doesn’t enable coloring by class, but can color by class mean or standard deviation.

../../_images/Pythagorean-Tree1-continuous.png

Example

The workflow from the screenshot below demonstrates the difference between Tree Viewer and Pythagorean Tree. They can both visualize Tree, but Pythagorean visualization takes less space and is more compact, even for a small Iris flower dataset. For both visualization widgets, we have hidden the control area on the left by clicking on the splitter between control and visualization area.

../../_images/Pythagorean-Tree-comparison.png

Pythagorean Tree is interactive: click on any of the nodes (squares) to select training data instances that were associated with that node. The following workflow explores these feature.

../../_images/Pythagorean-Tree-scatterplot-workflow.png

The selected data instances are shown as a subset in the Scatter Plot, sent to the Data Table and examined in the Box Plot. We have used brown-selected dataset in this example. The tree and scatter plot are shown below; the selected node in the tree has a black outline.

../../_images/Pythagorean-Tree-scatterplot.png

References

Beck, F., Burch, M., Munz, T., Di Silvestro, L. and Weiskopf, D. (2014). Generalized Pythagoras Trees for Visualizing Hierarchies. In IVAPP ‘14 Proceedings of the 5th International Conference on Information Visualization Theory and Applications, 17-28.