# Tree Drawing

TreePlot lays out the vertices of a graph in a tree of successive layers, or a collection of trees. If the graph g is not a tree, TreePlot lays out its vertices on the basis of a spanning tree of each component of the graph.

TreePlot[{v_{i 1}->v_{j 1},v_{i 2}->v_{j 2},…}] | generate a tree plot of the graph in which vertex is connected to vertex |

TreePlot[{{v_{i 1}->v_{j 1},lbl_{1}},…}] | associate labels with edges in the graph |

TreePlot[g,pos] | place roots of trees in the plot at position pos |

TreePlot[g,pos,v_{k}] | use vertex as the root node in the tree plot |

TreePlot[m] | generate a layered plot of the graph represented by the adjacency matrix m |

In[1]:= |

In[2]:= |

Out[2]= |

By default, TreePlot places each tree root at the top. TreePlot[g,pos] places the roots at position pos. Possible positions are: Top, Bottom, Left, Right, and Center.

In[3]:= |

Out[3]= |

In[4]:= |

Out[4]= |

## Options for TreePlot

In addition to options for Graphics, the following options are accepted for LayeredGraphPlot.

option name | default value | |

DataRange | Automatic | the range of vertex coordinates to generate |

DirectedEdges | False | whether to show edges as directed arrows |

EdgeLabeling | True | whether to include labels given for edges |

EdgeRenderingFunction | Automatic | function to give explicit graphics for edges |

LayerSizeFunction | 1& | the height to allow for each layer |

MultiedgeStyle | Automatic | how to draw multiple edges between vertices |

PackingMethod | Automatic | method to use for packing components |

PlotRangePadding | Automatic | how much padding to put around the plot |

PlotStyle | Automatic | style in which objects are drawn |

SelfLoopStyle | Automatic | how to draw edges linking a vertex to itself |

VertexCoordinateRules | Automatic | rules for explicit vertex coordinates |

VertexLabeling | Automatic | whether to show vertex names as labels |

VertexRenderingFunction | Automatic | function to give explicit graphics for vertices |

Options for TreePlot.

### DirectedEdges

The option DirectedEdges specifies whether to draw edges as directed arrows. Possible values for this option are True or False. The default value for this option is False.

In[5]:= |

Out[5]= |

### EdgeLabeling

The option EdgeLabeling specifies whether and how to display labels given for the edges. Possible values for this option are True, False, or Automatic. The default value for this option is True, which displays the supplied edge labels on the graph. With EdgeLabeling->Automatic, the labels are shown as tooltips.

In[6]:= |

Out[6]= |

In[7]:= |

Out[7]= |

In[8]:= |

Out[8]= |

### EdgeRenderingFunction

The option EdgeRenderingFunction specifies graphical representation of the graph edges. Possible values for this option are Automatic, None, or a function that gives a proper combination of graphics primitives and directives. With the default setting of Automatic, a dark red line is drawn for each edge. With EdgeRenderingFunction->None, edges are not drawn.

In[9]:= |

Out[9]= |

With EdgeRenderingFunction->g, each edge is rendered with the graphics primitives and directives given by the function g that can take three or more arguments, in the form , where are the coordinates of the beginning and ending points of the edge, are the beginning and ending vertices, and is any label specified for the edge or None. Explicit settings for EdgeRenderingFunction->g override settings for EdgeLabeling and DirectedEdges.

In[10]:= |

Out[10]= |

In[11]:= |

In[12]:= |

Out[12]= |

### LayerSizeFunction

The LayerSizeFunction option specifies the relative height to allow for each layer. By default the height is 1. Possible values include a function that gives real machine numbers.

In[13]:= |

In[14]:= |

Out[14]= |

In[15]:= |

Out[15]= |

### MultiedgeStyle

The option MultiedgeStyle specifies whether to draw multiple edges between two vertices. Possible values for MultiedgeStyle are Automatic (the default), True, False, or a positive real number. With the default setting MultiedgeStyle->Automatic, multiple edges are shown for a graph specified by a list of rules, but not shown if specified by an adjacency matrix. With MultiedgeStyle->δ, the multiedges are spread out to a scaled distance of δ.

In[16]:= |

Out[16]= |

In[17]:= |

Out[17]= |

In[18]:= |

Out[18]= |

#### PackingMethod

The option PackingMethod specifies the method used for packing disconnected components. Possible values for the option are Automatic (the default), , , , , , and . With PackingMethod->"ClosestPacking", components are packed as close together as possible using a polyomino method, starting from the top left. With PackingMethod->"ClosestPackingCenter", components are packed starting from the center. With PackingMethod->"Layered", components are packed in layers starting from the top left. With PackingMethod->"LayeredLeft" or PackingMethod->"LayeredTop", components are packed in layers starting from the top or left respectively. With PackingMethod->"NestedGrid", components are arranged in a nested grid. The typical effective default setting is PackingMethod->"Layered", and the packing starts with components of the largest bounding box area.

In[19]:= |

Out[19]= |

In[20]:= |

Out[20]= |

### PlotRangePadding

PlotRangePadding is a common option for graphics functions inherited by TreePlot.

### PlotStyle

PlotStyle is a common option for graphics functions inherited by TreePlot. The option PlotStyle specifies the style in which objects are drawn.

In[21]:= |

Out[21]= |

### SelfLoopStyle

The option SelfLoopStyle specifies whether and how to draw loops for vertices that are linked to themselves. Possible values for the option are Automatic (the default), True, False, or a positive real number. With SelfLoopStyle->Automatic, self-loops are shown if the graph is specified by a list of rules, but not if it is specified by an adjacency matrix. With SelfLoopStyle->δ, the self-loops are drawn with a diameter of δ (relative to the average edge length).

In[22]:= |

Out[22]= |

In[23]:= |

Out[23]= |

In[24]:= |

Out[24]= |

### VertexCoordinateRules

The option VertexCoordinateRules specifies the coordinates of the vertices. Possible values are None or a list of coordinates. Coordinates specified by a list of rules are not supported by TreePlot currently.

In[25]:= |

Out[25]= |

In[26]:= |

Out[26]= |

### VertexLabeling

The option VertexLabeling specifies whether to show vertex names as labels. Possible values for this option are True, False, Automatic (the default) and Tooltip. VertexLabeling->True shows the labels. For graphs specified by an adjacency matrix, vertex labels are taken to be successive integers , where is the size of the matrix. For graphs specified by a list of rules, labels are the expressions used in the rules. VertexLabeling->False displays each vertex as a point. VertexLabeling->Tooltip displays each vertex as a point, but gives its name in a tooltip. VertexLabeling->Automatic displays each vertex as a point, giving its name in a tooltip if the number of vertices is not too large. You can also use Tooltip[v_{k},v_{lbl}] anywhere in the list of rules to specify an alternative tooltip for a vertex .

In[27]:= |

Out[27]= |

In[28]:= |

Out[28]= |

In[29]:= |

Out[29]= |

### VertexRenderingFunction

The option VertexRenderingFunction specifies graphical representation of the graph edges. Possible values for this option are Automatic, None, or a function that gives a proper combination of graphics primitives and directives. With the default setting of Automatic, vertices are displayed as points, with their names given in tooltips.

In[30]:= |

In[31]:= |

Out[31]= |

In[32]:= |

Out[32]= |

With VertexRenderingFunction->g, each vertex is rendered with the graphics primitives given by , where is the coordinate of the vertex and is the label of the vertex. Explicit settings for VertexRenderingFunction->g override settings for VertexLabeling.

In[33]:= |

Out[33]= |

## Example Gallery

*k*-ary tree

In[14]:= |

Out[14]= |

In[15]:= |

Out[15]= |

In[16]:= |

Out[16]= |