`R/layout_circlepack.R`

`layout_tbl_graph_circlepack.Rd`

The circle packing algorithm is basically a treemap using circles instead of rectangles. Due to the nature of circles they cannot be packed as efficiently leading to increased amount of "empty space" as compared to a treemap. This can be beneficial though, as the added empty space can aid in visually showing the hierarchy.

```
layout_tbl_graph_circlepack(
graph,
weight = NULL,
circular = FALSE,
sort.by = NULL,
direction = "out"
)
```

- graph
An

`tbl_graph`

object- weight
An optional node variable to use as weight. Will only affect the weight of leaf nodes as the weight of non-leaf nodes are derived from their children.

- circular
Logical. Should the layout be transformed to a circular representation. Ignored.

- sort.by
The name of a node variable to sort the nodes by.

- direction
The direction of the tree in the graph.

`'out'`

(default) means that parents point towards their children, while`'in'`

means that children point towards their parent.

A data.frame with the columns `x`

, `y`

, `r`

, `leaf`

,
`depth`

, `circular`

as well as any information stored as node
variables in the tbl_graph object.

The circle packing is based on the algorithm developed by Weixin Wang and collaborators which tries to find the most dense packing of circles as they are added, one by one. This makes the algorithm very dependent on the order in which circles are added and it is possible that layouts could sometimes be optimized by choosing a different ordering. The algorithm for finding the enclosing circle is the randomized incremental algorithm proposed by Emo Welzl. Both of the above algorithms are the same as used in the D3.js implementation of circle packing and their C++ implementation in ggraph is inspired by Mike Bostocks JavaScript implementation.

Circle packing is a layout intended for trees, that is, graphs where nodes only have one parent and zero or more children. If the provided graph does not fit this format an attempt to convert it to such a format will be made.

Wang, W., Wang, H. H., Dai, G., & Wang, H. (2006). *Visualization of
large hierarchical data by circle packing*. Chi, 517-520.

Welzl, E. (1991). *Smallest enclosing disks (balls and ellipsoids)*. New
Results and New Trends in Computer Science, 359-370.

Other layout_tbl_graph_*:
`layout_tbl_graph_auto()`

,
`layout_tbl_graph_backbone()`

,
`layout_tbl_graph_cactustree()`

,
`layout_tbl_graph_centrality()`

,
`layout_tbl_graph_dendrogram()`

,
`layout_tbl_graph_eigen()`

,
`layout_tbl_graph_fabric()`

,
`layout_tbl_graph_focus()`

,
`layout_tbl_graph_hive()`

,
`layout_tbl_graph_htree()`

,
`layout_tbl_graph_igraph()`

,
`layout_tbl_graph_linear()`

,
`layout_tbl_graph_manual()`

,
`layout_tbl_graph_matrix()`

,
`layout_tbl_graph_metro()`

,
`layout_tbl_graph_partition()`

,
`layout_tbl_graph_pmds()`

,
`layout_tbl_graph_sf()`

,
`layout_tbl_graph_stress()`

,
`layout_tbl_graph_treemap()`

,
`layout_tbl_graph_unrooted()`