[Rd] help with eval()

Gabor Grothendieck ggrothendieck at gmail.com
Tue Apr 19 02:17:57 CEST 2011


On Mon, Apr 18, 2011 at 5:51 PM, Terry Therneau <therneau at mayo.edu> wrote:
> I've narrowed my scope problems with predict.coxph further.
> Here is a condensed example:
>
> fcall3 <- as.formula("time ~ age")
> dfun3 <- function(dcall) {
>    fit <- lm(dcall, data=lung, model=FALSE)
>    model.frame(fit)
> }
> dfun3(fcall3)
>
> The final call fails: it can't find 'dcall'.
>
> The relevant code in model.frame.lm is:
>       env <- environment(formula$terms)
>       if (is.null(env))
>            env <- parent.frame()
>        eval(fcall, env, parent.frame())
>
> If the environment of the formula is .Globalenv, as it is here, the
> contents of parent.frame() are ignored.  Adding a
>           print(ls(parent.frame()))
> statement just above the  final call shows that it isn't a scope issue:
> the variables we want are there.
>
>  I don't understand the logic behind looking for variables in the place
> the formula was first typed (this is not a complaint).  The inability to
> look elsewhere however has stymied my efforts to fix the scoping problem
> in predict.coxph, unless I drop the env(formula) argument alltogether.
> But I assume there must be good reasons for it's inclusion and am
> reluctant to do so.
>

Try using do.call.  Using the built in BOD to illustrate, we first try
the posted code to view the error:

> fcall3 <- as.formula("demand ~ Time")
> dfun3 <- function(dcall) {
+     fit <- lm(dcall, data=BOD, model=FALSE)
+     model.frame(fit)
+ }
> dfun3(fcall3)
Error in model.frame(formula = dcall, data = BOD, drop.unused.levels = TRUE) :
  object 'dcall' not found
>
> # now replace the lm call with a do.call("lm" ...)
> # so that dcall gets substituted before the call to lm:
>
> fcall3 <- as.formula("demand ~ Time")
> dfun3 <- function(dcall) {
+     fit <- do.call("lm", list(dcall, data = BOD, model = FALSE))
+     model.frame(fit)
+ }
> dfun3(fcall3)
  demand Time
1    8.3    1
2   10.3    2
3   19.0    3
4   16.0    4
5   15.6    5
6   19.8    7



-- 
Statistics & Software Consulting
GKX Group, GKX Associates Inc.
tel: 1-877-GKX-GROUP
email: ggrothendieck at gmail.com



More information about the R-devel mailing list