有向无环图

作者

[编辑] 郑虎;

[审核] .

有向无环图可视化。

环境配置

  • 系统: Cross-platform (Linux/MacOS/Windows)

  • 编程语言: R

  • 依赖包: ggdag

# 安装包
if (!requireNamespace("ggdag", quietly = TRUE)) {
  install.packages("ggdag")
}

# 加载包
library(ggdag)

数据准备

# 加载数据
tidy_ggdag <- dagify(
  y ~ x + z2 + w2 + w1,
  x ~ z1 + w1 + w2,
  z1 ~ w1 + v,
  z2 ~ w2 + v,
  w1 ~ ~w2, # bidirected path
  exposure = "x",
  outcome = "y") %>%
  tidy_dagitty()

# 查看数据
head(tidy_ggdag)
$data
# A tibble: 13 × 8
   name       x       y direction to      xend    yend circular
   <chr>  <dbl>   <dbl> <fct>     <chr>  <dbl>   <dbl> <lgl>   
 1 v     -1.27  -2.26   ->        z1    -0.913 -0.906  FALSE   
 2 v     -1.27  -2.26   ->        z2    -2.65  -1.92   FALSE   
 3 w1    -1.86  -0.535  ->        x     -1.99   0.0935 FALSE   
 4 w1    -1.86  -0.535  ->        y     -3.01  -0.421  FALSE   
 5 w1    -1.86  -0.535  ->        z1    -0.913 -0.906  FALSE   
 6 w1    -1.86  -0.535  <->       w2    -2.73  -0.964  FALSE   
 7 w2    -2.73  -0.964  ->        x     -1.99   0.0935 FALSE   
 8 w2    -2.73  -0.964  ->        y     -3.01  -0.421  FALSE   
 9 w2    -2.73  -0.964  ->        z2    -2.65  -1.92   FALSE   
10 x     -1.99   0.0935 ->        y     -3.01  -0.421  FALSE   
11 y     -3.01  -0.421  <NA>      <NA>  NA     NA      FALSE   
12 z1    -0.913 -0.906  ->        x     -1.99   0.0935 FALSE   
13 z2    -2.65  -1.92   ->        y     -3.01  -0.421  FALSE   

$dag
dag {
v
w1
w2
x [exposure]
y [outcome]
z1
z2
v -> z1
v -> z2
w1 -> x
w1 -> y
w1 -> z1
w1 <-> w2
w2 -> x
w2 -> y
w2 -> z2
x -> y
z1 -> x
z2 -> y
}

可视化

# 有向无环图
p <- ggdag(tidy_ggdag) +
  theme_dag() 

p
图 1: 有向无环图