使用ggplot2进行分面qqplots

mit*_*hus 2 statistics r ggplot2

说我有以下数据:

datapoints1 = data.frame(categ=c(rep(1, n), rep(2, n)), vals1=c(rt(n, 1, 2), rnorm(n, 3, 4)))
datapoints2 = data.frame(categ=c(rep(1, n), rep(2, n)), vals2=c(rt(n, 5, 6), rnorm(n, 7, 8)))
Run Code Online (Sandbox Code Playgroud)

使用ggplot2,如何使用该facet功能在单个命令中创建两个QQ图,即一个带有两个t样本,另一个带有两个高斯样本?

Sve*_*ein 5

首先,组合两个数据框:

dat <- cbind(datapoints1, vals2 = datapoints2[ , 2])
Run Code Online (Sandbox Code Playgroud)

然后,对数据进行排序:

dat_sort <- do.call("rbind", lapply(unique(dat$categ), FUN = function(x) {data.frame(categ = x, vals1 = sort(dat$vals1[dat$categ == x]), vals2 = sort(dat$vals2[dat$categ == x]))}))
Run Code Online (Sandbox Code Playgroud)

如果两个样本向量长度相同,则很简单:

ggplot() + 
 geom_point(data = dat_sort, aes(x = vals1, y = vals2)) +
 facet_wrap( ~ categ, scales = "free")
Run Code Online (Sandbox Code Playgroud)

一个例子n = 1000:

2个QQ情节