有向无环图

作者

[编辑] 郑虎;

[审核] .

注记

Hiplot 网站

本页面为 Hiplot Directed Acyclic Graphs 插件的源码版本教程,您也可以使用 Hiplot 网站实现无代码绘图,更多信息请查看以下链接:

https://hiplot.cn/basic/ggdag?lang=zh_cn

有向无环图可视化。

环境配置

  • 系统: 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.50  -0.0307 ->        z1     0.494 -1.01  FALSE   
 2 v      1.50  -0.0307 ->        z2     0.524  0.988 FALSE   
 3 w1    -0.325 -0.434  ->        x     -0.934 -0.594 FALSE   
 4 w1    -0.325 -0.434  ->        y     -0.324  0.498 FALSE   
 5 w1    -0.325 -0.434  ->        z1     0.494 -1.01  FALSE   
 6 w1    -0.325 -0.434  <->       w2    -0.939  0.587 FALSE   
 7 w2    -0.939  0.587  ->        x     -0.934 -0.594 FALSE   
 8 w2    -0.939  0.587  ->        y     -0.324  0.498 FALSE   
 9 w2    -0.939  0.587  ->        z2     0.524  0.988 FALSE   
10 x     -0.934 -0.594  ->        y     -0.324  0.498 FALSE   
11 y     -0.324  0.498  <NA>      <NA>  NA     NA     FALSE   
12 z1     0.494 -1.01   ->        x     -0.934 -0.594 FALSE   
13 z2     0.524  0.988  ->        y     -0.324  0.498 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: 有向无环图