[R] Puzzled in utilising summary.lm() to obtain Var(x)

Prof Brian Ripley ripley at stats.ox.ac.uk
Wed Jun 15 09:18:17 CEST 2005


On Wed, 15 Jun 2005, Ajay Narottam Shah wrote:

>>> I have a program which is doing a few thousand runs of lm(). Suppose
>>> it is a simple model
>>>   y = a + bx1 + cx2 + e
>>>
>>> I have the R object "d" where
>>>   d <- summary(lm(y ~ x1 + x2))
>>>
>>> I would like to obtain Var(x2) out of "d". How might I do it?
>>>
>>> I can, of course, always do sd(x2). But it would be much more
>>> convenient if I could snoop around the contents of summary.lm and
>>> extract Var() out of it. I couldn't readily see how. Would you know
>>> what would click?
>>
>> Is the question how to get the variance of a column of the
>> model matrix for a model that is the sum of terms given only
>> summary output and the column name but not the name of the
>> data frame?  If that is it then try this:
>>
>> d <- summary(lm(Sepal.Length ~ Sepal.Width, iris)) # test data
>> var(model.matrix(eval(d$call))[,"Sepal.Width"])
>
> Yes, this is indeed exactly what I was looking for :-) Thanks,
>
> The eval() pays the full cost of running d$call?

A better way is

> d0 <- lm(Sepal.Length ~ Sepal.Width, iris)
> var(model.matrix(d0)[,"Sepal.Width"])

but if you really only have the summary  (it's wasteful to keep the 
summary here, as it is larger than the fit)

> var(model.matrix(structure(d, class="lm"))[,"Sepal.Width"])


-- 
Brian D. Ripley,                  ripley at stats.ox.ac.uk
Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
University of Oxford,             Tel:  +44 1865 272861 (self)
1 South Parks Road,                     +44 1865 272866 (PA)
Oxford OX1 3TG, UK                Fax:  +44 1865 272595




More information about the R-help mailing list