[Rd] help with eval()

Duncan Murdoch murdoch.duncan at gmail.com
Tue Apr 19 02:00:41 CEST 2011


On 11-04-18 5:51 PM, Terry Therneau 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.


The reason is that when a formula is created, the variables in it are 
assumed to have meaning in that context.  Where you work with the 
formula after that should not be relevant:  that's why formulas carry 
environments with them.  When you create the formula before the 
variables, things go wrong.

There's probably a way to associate the lung dataframe with the formula, 
or create the formula in such a way that things work, but I can't spot it.

Duncan Murdoch

> Terry Therneau
>
>> sessionInfo()
> R version 2.13.0 RC (2011-04-12 r55424)
> Platform: x86_64-unknown-linux-gnu (64-bit)
>
> locale:
>   [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C
>   [3] LC_TIME=en_US.UTF-8        LC_COLLATE=C
>   [5] LC_MONETARY=C              LC_MESSAGES=en_US.UTF-8
>   [7] LC_PAPER=en_US.UTF-8       LC_NAME=C
>   [9] LC_ADDRESS=C               LC_TELEPHONE=C
> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
>
> attached base packages:
> [1] stats     graphics  grDevices utils     datasets  methods
> base
>
> PS. This also fails
> dfun3<- function(dcall) {
>      fit<- lm(dcall, data=lung)
>      model.frame(fit, subset=1:10)
> }
> You just need to force model.frame.lm to recreate data.
>
> ______________________________________________
> R-devel at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel



More information about the R-devel mailing list