Another R [Non-]Standard Evaluation Idea
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.
Jonathan Carroll had a an interesting R
language idea: to use @
-notation to request value substitution in a non-standard evaluation environment (inspired by msyql User-Defined Variables).
He even picked the right image:
The idea is kind of reverse from some Lisp ideas (“evaled unless ticked”), but an interesting possibility. We can play along with it a bit in R
as follows. The disadvantages of our simulation include:
- The user must both call
wrapr::ateval
and place their code in quotes. - The effect is still achieved through string substitution.
But here it is for what it is worth:
# devtools::install_github("WinVector/wrapr") library("wrapr") library("dplyr")
The original example function from the Tweet:
f <- function(col1, col2, new_col_name) { ateval('mtcars %>% mutate(@new_col_name = @col1 + @col2)') }
And the requested effect actually realized:
d <- f('gear', 'carb', 'nonsense') head(d)
## mpg cyl disp hp drat wt qsec vs am gear carb nonsense ## 1 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4 8 ## 2 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4 8 ## 3 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1 5 ## 4 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1 4 ## 5 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2 5 ## 6 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1 4
The point is a standard function (f()
) can accept user column names and then itself use convenient non-standard evaluation notation (in this case dplyr
) to perform operations. This package-based simulation is not as good as actual language support, but simulations like this are how we collect experience with possible new language features.
The real point is a user wants a flexible language with macros and functions (R
uses an intermediate form called "an Fexpr" for just about everything) that they can both use interactively and program over. This means they eventually want an execution environment where they can both pass in parametric values (what R
calls standard evaluation) and the ability to have code elements treated directly as values (a convenience and related to what R
calls non-standard evaluation).
The classic Lisp solution organizes things a bit differently, and uses various "back-tick" notations to specify control of the interpretation of symbols. I think R
has picked a different set of defaults as to how symbols, values, expressions, and execution interact- so any notation is going to be a bit different.
The development version of wrapr
can be found here (atexpr
is not yet in the CRAN version, which supplies the let
alternative). The example shown in this article can be found in markdown form here.
R-bloggers.com offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.