# 安装包
if (!requireNamespace("ggdag", quietly = TRUE)) {
install.packages("ggdag")
}
# 加载包
library(ggdag)有向无环图
注记
Hiplot 网站
本页面为 Hiplot Directed Acyclic Graphs 插件的源码版本教程,您也可以使用 Hiplot 网站实现无代码绘图,更多信息请查看以下链接:
有向无环图可视化。
环境配置
系统: Cross-platform (Linux/MacOS/Windows)
编程语言: R
依赖包:
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
