View source: R/print_and_plot.R
plot.DAG | R Documentation |
Plot a directed acyclic graph.
## S3 method for class 'DAG'
plot(
x,
labels = NULL,
algorithm = "sugiyama",
manual_layout = NULL,
text_size = 6,
box_x = 12,
box_y = 8,
edge_width = 1.5,
curvature = 0.02,
rotation = 0,
flip_x = FALSE,
flip_y = FALSE,
arrow = grid::arrow(type = "closed", 18, grid::unit(15, "points")),
...
)
x |
A 'DAG“ object, usually created with the |
labels |
An optional set of labels to use for the nodes. This should be a named vector, of
the form |
algorithm |
A layout algorithm from igraph, see
|
manual_layout |
Alternatively, precisely define the layout yourself, by providing a
|
text_size |
Size of the node label text. |
box_x |
To avoid the arrows colliding with the nodes, specify the rectangular dimensions of an invisible box around each node. If you have long labels, you need to increase this. |
box_y |
To avoid the arrows colliding with the nodes, specify the rectangular dimensions of an invisible box around each node. If you have multi-line labels, you need to increase this. |
edge_width |
Width of the edges. |
curvature |
Curvature of the edges. A slight curvature can look pretty. |
rotation |
Supply the degrees you want to rotate the layout by. This is useful in order to put rotate your upstream nodes towards the top if needed. |
flip_x |
Whether to flip the node positions horizontally. |
flip_y |
Whether to flip the node positions vertically. |
arrow |
A The order of facets is taken from the ordering of the list, with the facet labels coming from the names of the list. If the list is unnamed, sequential lettering is used. |
... |
Not used. |
d <- DAG(a ~ b + c + d)
plot(d)
# Plot with manually defined positions:
ml <- data.frame(
name = c('a', 'b', 'c', 'd'),
x = c(1, 1, 2, 2),
y = c(1, 2, 1, 2)
)
plot(d, manual_layout = ml)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.