[R] formula mungeing

Koenker, Roger W rkoenker @end|ng |rom ||||no|@@edu
Fri Oct 23 17:27:25 CEST 2020


Thanks, Gabor!  Very elegant!

> On Oct 23, 2020, at 4:15 PM, Gabor Grothendieck <ggrothendieck using gmail.com> wrote:
> 
> Recursively walk the formula performing the replacement:
> 
> g <- function(e, ...) {
>    if (length(e) > 1) {
>        if (identical(e[[2]], as.name(names(list(...))))) {
>          e <- eval(e, list(...))
>        }
>        if (length(e) > 1) for (i in 1:length(e)) e[[i]] <- Recall(e[[i]], ...)
>    }
>    e
> }
> 
> g(f, lambdas = 2:3)
> ## y ~ qss(x, lambda = 2L) + qss(z, 3L) + s
> 
> On Fri, Oct 23, 2020 at 9:33 AM Koenker, Roger W <rkoenker using illinois.edu> wrote:
>> 
>> Suppose I have a formula like this:
>> 
>>        f <- y ~ qss(x, lambda = lambdas[1]) + qss(z, lambdas[2]) + s
>> 
>> I’d like a function, g(lambdas, f)  that would take g(c(2,3), f) and produce the new
>> formula:
>> 
>>        y ~ qss(x, lambda = 2) + qss(z, 3) + s
>> 
>> For only two qss terms I have been using
>> 
>>        g <- function(lambdas, f){
>>                F <- deparse(f)
>>                F <- gsub("lambdas\\[1\\]",lambdas[1],F)
>>                F <- gsub("lambdas\\[2\\]",lambdas[2],F)
>>                formula(F)
>>        }
>> but this is ugly and doesn’t extend nicely to more qss terms.  Isn’t there some
>> bquote() magic that can be invoked?  Or something else entirely?
>> ______________________________________________
>> R-help using r-project.org mailing list -- To UNSUBSCRIBE and more, see
>> https://stat.ethz.ch/mailman/listinfo/r-help
>> PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
>> and provide commented, minimal, self-contained, reproducible code.
> 
> 
> 
> -- 
> Statistics & Software Consulting
> GKX Group, GKX Associates Inc.
> tel: 1-877-GKX-GROUP
> email: ggrothendieck at gmail.com



More information about the R-help mailing list