[Rd] substitute and expression
Peter Dalgaard
p.dalgaard at biostat.ku.dk
Tue Jul 17 00:24:05 CEST 2007
Deepayan Sarkar wrote:
> Hi,
>
> I'm trying to understand whether the use of substitute() is
> appropriate/documented for plotmath annotation. The following two
> calls give the same results:
>
>
>> plot(1:10, main = expression(alpha == 1))
>> do.call(plot, list(1:10, main = expression(alpha == 1)))
>>
>
> But not these two:
>
>
>> plot(1:10, main = substitute(alpha == a, list(a = 2)))
>> do.call(plot, list(1:10, main = substitute(alpha == a, list(a = 2))))
>>
> Error in as.graphicsAnnot(main) : object "alpha" not found
>
> (as a consequence, xyplot(..., main = substitute(alpha)) doesn't
> currently work.)
>
> On the other hand, this works:
>
>
>> foo <- function(x) plot(1, main = x)
>> foo(substitute(alpha))
>>
>
> I'm not sure how to interpret ?plotmath; it says
>
> If the 'text' argument to one of the text-drawing functions
> ('text', 'mtext', 'axis', 'legend') in R is an expression, the
> argument is interpreted as a mathematical expression...
>
> and uses substitute() in its examples, but
>
>
>> is.expression(substitute(alpha == a, list(a = 1)))
>>
> [1] FALSE
>
I think you need to take plotmath out of the equation and study the
difference between objects of mode "call" and those of mode
"expression". Consider this:
> f <- function(...)match.call()
> do.call(f, list(1:10, main = substitute(alpha == a, list(a = 2))))
function(...)match.call()
(1:10, main = alpha == 2)
> do.call(list, list(1:10, main = substitute(alpha == a, list(a = 2))))
Error in do.call(list, list(1:10, main = substitute(alpha == a, list(a =
2)))) :
object "alpha" not found
The issue is that function ends up with an argument alpha == 2 which it
proceeds to evaluate (lazily), where a direct call sees
substitute(.....). It is a general problem with the do.call mechanism
that it effectively pre-evaluates the argument list, which can confuse
functions that rely on accessing the original argument expression. Try,
e.g., do.call(plot, list(airquality$Wind, airquality$Ozone)) and watch
the axis labels.
Does it work if you use something like
main = substitute(quote(alpha == a), list(a = 2))?
More information about the R-devel
mailing list