Plotting functionality makes use of the Sugiyama layout from igraph which plots nodes to reflect their position in a causal ordering.
The plot
method calls plot_model
and passes provided arguments to it.
model <- make_model("X -> Y") model |> plot_model()
The model that is produced is a ggplot
object and additional layers can be added in the usual way.
model |> plot_model() + annotate("text", x = c(1, -1) , y = c(1.5, 1.5), label = c("Some text", "Some more text")) + coord_flip()
Provide labels in the same order as model nodes.
model <- make_model("A -> B -> C <- A") # Check node ordering inspect(model, "nodes") #> #> Nodes: #> A, B, C # Provide labels model |> plot_model( labels = c("This is A", "Here is B", "And C"), nodecol = "white", textcol = "black")
You can manually set positions using the x_coord
and y_coord
arguments.
You can manually set positions using the x_coord
and y_coord
arguments.
model |> plot(x_coord = 0:2, y_coord = c(0, 2, 1))
You can manually control node color and text color for all nodes together or separately.
model |> plot(x_coord = 0:2, y_coord = c(0, 2, 1), nodecol = c("blue", "orange", "red"), textcol = c("white", "red", "blue"))
Unobserved confounding is represented using dashed curves.
make_model('X -> K -> Y <- X; X <-> Y; K <-> Y') |> plot()
make_model("I -> V -> G <- N; C -> I <- A -> G; G -> Z", add_causal_types = FALSE) |> plot()
This graph has bad node placement.
make_model("D <- A -> B -> C -> D -> E; B -> E", add_causal_types = FALSE) |> plot()
Better:
make_model("D <- A -> B -> C -> D -> E; B -> E", add_causal_types = FALSE) |> plot(x_coord = c(0, -.1, 0, .1, 0), y_coord = 5:1)
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.