Understanding glm$residuals and resid(glm)

后端 未结 2 1024
清歌不尽
清歌不尽 2020-12-23 08:27

Can you tell me what is returned by glm$residuals and resid(glm) where glm is a quasipoisson object. e.g. How would I create them using gl

2条回答
  •  一向
    一向 (楼主)
    2020-12-23 08:55

    Calling resid(model) will default to the deviance residuals, whereas model$resid will give you the working residuals. Because of the link function, there is no single definition of what a model residual is. There are the deviance, working, partial, Pearson, and response residuals. Because these only rely on the mean structure (not the variance), the residuals for the quasipoisson and poisson have the same form. You can take a look at the residuals.glm function for details, but here is an example:

    counts <- c(18,17,15,20,10,20,25,13,12)
    outcome <- gl(3,1,9)
    treatment <- gl(3,3)
    glm.D93 <- glm(counts ~ outcome + treatment, family=quasipoisson())
    glm.D93$resid
    
    
    #working
    resid(glm.D93,type="working")
    (counts - glm.D93$fitted.values)/exp(glm.D93$linear)
    
    #deviance
    resid(glm.D93,type="dev")
    fit <- exp(glm.D93$linear)
    poisson.dev <- function (y, mu) 
        sqrt(2 * (y * log(ifelse(y == 0, 1, y/mu)) - (y - mu)))
    poisson.dev(counts,fit) * ifelse(counts > fit,1,-1)
    
    #response
    resid(glm.D93,type="resp")
    counts - fit
    
    #pearson
    resid(glm.D93,type="pear")
    (counts - fit)/sqrt(fit)
    

提交回复
热议问题