将Cook的距离水平添加到ggplot2

时间:2018-02-24 11:36:59

标签: r ggplot2 ggfortify

如何在this first plot中添加显示库克距离的红色虚线轮廓线 使用ggplotggfortify?{/ p> this first plotsecond plot

second plot

使用的代码:

library(ggfortify)
model <- glm(mpg ~ wt, data = mtcars, family = gaussian())
plot(model, which = 5) # first plot
autoplot(model, which = 5) # second plot

我认为可以添加geom_contour,但我不知道用于计算库克距离线的公式。

1 个答案:

答案 0 :(得分:3)

经过一些研究,我设法使用公式level绘制了sqrt(level * length(coef(model)) * (1 - leverage)/leverage)的轮廓,这是R用来绘制plot.lm轮廓的方法。我使用的方法肯定可以改进。

library(ggplot2)
library(ggfortify)
model <- glm(mpg ~ wt, data = mtcars, family = gaussian())

cd_cont_pos <- function(leverage, level, model) {sqrt(level*length(coef(model))*(1-leverage)/leverage)}
cd_cont_neg <- function(leverage, level, model) {-cd_cont_pos(leverage, level, model)}

autoplot(model, which = 5) +
    stat_function(fun = cd_cont_pos, args = list(level = 0.5, model = model), xlim = c(0, 0.25), lty = 2, colour = "red") +
    stat_function(fun = cd_cont_neg, args = list(level = 0.5, model = model), xlim = c(0, 0.25), lty = 2, colour = "red") +
    scale_y_continuous(limits = c(-2, 2.5))

residuals vs leverage plot with cook's distance contours