node_instrumental
tags instrumental variables given an exposure and
outcome. ggdag_instrumental
plots all instrumental variables. See
dagitty::instrumentalVariables()
for details.
Usage
node_instrumental(.dag, exposure = NULL, outcome = NULL, ...)
ggdag_instrumental(
.tdy_dag,
exposure = NULL,
outcome = NULL,
...,
size = 1,
edge_type = c("link_arc", "link", "arc", "diagonal"),
node_size = 16,
text_size = 3.88,
label_size = text_size,
text_col = "white",
label_col = "black",
edge_width = 0.6,
edge_cap = 10,
arrow_length = 5,
use_edges = TRUE,
use_nodes = TRUE,
use_stylized = FALSE,
use_text = TRUE,
use_labels = FALSE,
label_geom = geom_dag_label_repel,
unified_legend = TRUE,
text = NULL,
label = NULL,
node = deprecated(),
stylized = deprecated()
)
Arguments
- .dag
A
tidy_dagitty
ordagitty
object- exposure
A character vector, the exposure variable. Default is
NULL
, in which case it will be determined from the DAG.- outcome
A character vector, the outcome variable. Default is
NULL
, in which case it will be determined from the DAG.- ...
additional arguments passed to
tidy_dagitty()
- .tdy_dag
A
tidy_dagitty
ordagitty
object- size
A numeric value scaling the size of all elements in the DAG. This allows you to change the scale of the DAG without changing the proportions.
- edge_type
The type of edge, one of "link_arc", "link", "arc", "diagonal".
- node_size
The size of the nodes.
- text_size
The size of the text.
- label_size
The size of the labels.
- text_col
The color of the text.
- label_col
The color of the labels.
- edge_width
The width of the edges.
- edge_cap
The size of edge caps (the distance between the arrowheads and the node borders).
- arrow_length
The length of arrows on edges.
- use_edges
A logical value. Include a
geom_dag_edges*()
function? IfTRUE
, which is determined byedge_type
.- use_nodes
A logical value. Include
geom_dag_point()
?- use_stylized
A logical value. Include
geom_dag_node()
?- use_text
A logical value. Include
geom_dag_text()
?- use_labels
A logical value. Include a label geom? The specific geom used is controlled by
label_geom
.- label_geom
A geom function to use for drawing labels when
use_labels = TRUE
. Default isgeom_dag_label_repel
. Other options includegeom_dag_label
,geom_dag_text_repel
,geom_dag_label_repel2
, andgeom_dag_text_repel2
.- unified_legend
A logical value. When
TRUE
and bothuse_edges
anduse_nodes
areTRUE
, creates a unified legend entry showing both nodes and edges in a single key, and hides the separate edge legend. This creates cleaner, more compact legends. Default isTRUE
.- text
The bare name of a column to use for
geom_dag_text()
. Ifuse_text = TRUE
, the default is to usename
.- label
The bare name of a column to use for labels. If
use_labels = TRUE
, the default is to uselabel
.- node
Deprecated.
- stylized
Deprecated.
Examples
library(dagitty)
node_instrumental(dagitty("dag{ i->x->y; x<->y }"), "x", "y")
#> # DAG:
#> # A `dagitty` DAG with: 3 nodes and 3 edges
#> #
#> # Data:
#> # A tibble: 4 × 9
#> name x y direction to xend yend instrumental_name instrumental
#> <chr> <dbl> <dbl> <fct> <chr> <dbl> <dbl> <chr> <chr>
#> 1 i 1.03 2.99 -> x 1.24 1.85 i instrumental
#> 2 x 1.24 1.85 -> y 1.40 0.972 i NA
#> 3 x 1.24 1.85 <-> y 1.40 0.972 i NA
#> 4 y 1.40 0.972 NA NA NA NA i NA
#> #
#> # ℹ Use `pull_dag() (`?pull_dag`)` to retrieve the DAG object and `pull_dag_data() (`?pull_dag_data`)` for the data frame
ggdag_instrumental(dagitty("dag{ i->x->y; i2->x->y; x<->y }"), "x", "y")