Extract Residual Deviance from anova (glm) in R

2019-07-06 03:01发布

I fitted a glm model in R and took the anova table. I need to extract the "Residual Deviance" column. But it generates an error. Here are the codes:

Creating data:

counts <- c(18,17,15,20,10,20,25,13,12)
outcome <- gl(3,1,9)
treatment <- gl(3,3)

Fitting GLM:

glm.D93 <- glm(counts ~ outcome + treatment, family = quasipoisson(link = "log"))

Anova table:

av.1=anova(glm.D93)
av.1
Analysis of Deviance Table

Model: quasipoisson, link: log

Response: counts

Terms added sequentially (first to last)


          Df Deviance Resid. Df Resid. Dev
NULL                          8    10.5814
outcome    2   5.4523         6     5.1291
treatment  2   0.0000         4     5.1291

Now I need to extract "Resid. Dev" column. So I tried str

> str(av.1)
Classes ‘anova’ and 'data.frame':       3 obs. of  4 variables:
 $ Df        : int  NA 2 2
 $ Deviance  : num  NA 5.45 0
 $ Resid. Df : int  8 6 4
 $ Resid. Dev: num  10.58 5.13 5.13
 - attr(*, "heading")= chr "Analysis of Deviance Table\n\nModel: quasipoisson, link: log\n\nResponse: counts\n\nTerms added sequentially (first to last)\n\"| __truncated__

Finally I extracted Resid. Dev but it gives me an error:

> av.1$Resid. Dev
Error: unexpected symbol in "av.1$Resid. Dev"

3条回答
在下西门庆
2楼-- · 2019-07-06 03:41

Use the [ operator to access the forth column:

av.1[,4]

Or if you want to use $ qoute the column name:

av.1$`Resid. Dev`
av.1$"Resid. Dev"
查看更多
你好瞎i
3楼-- · 2019-07-06 03:48

You can't use unquoted spaces with the $, so use [ instead:

>av.1["Resid. Dev"]
          Resid. Dev
NULL      10.5814459
outcome    5.1291411
treatment  5.1291411
查看更多
兄弟一词,经得起流年.
4楼-- · 2019-07-06 03:49

Use quotation marks

> av.1$"Resid. Dev"
[1] 10.581446  5.129141  5.129141

Equivalently

av.1[["Resid. Dev"]]
查看更多
登录 后发表回答