[R] Construct a function with argments specified by an R expression
Gabor Grothendieck
ggrothend|eck @end|ng |rom gm@||@com
Sun Oct 26 19:13:51 CET 2025
Here is an approach using as.function.formula from gsubfn:
library (gsubfn)
# inputs
arg_names <- head(letters)
f <- function() {}
formals(f) <- formals(as.function(reformulate(arg_names)))
f
On Sun, Oct 26, 2025 at 10:47 AM Gabor Grothendieck
<ggrothendieck using gmail.com> wrote:
>
> This can be simplified slightly to
>
> # inputs
> arg_names <- c("x", "y", paste0("a", 1:3), paste0("b", 1:3))
> f <- function() {}
>
> arg <- alist(x = )
> formals(f) <- setNames(rep(arg, length(arg_names)), arg_names)
> f
>
> ## function (x, y, a1, a2, a3, b1, b2, b3)
> ## {
> ## }
>
> On Sun, Oct 26, 2025 at 10:41 AM Gabor Grothendieck
> <ggrothendieck using gmail.com> wrote:
> >
> > Define the names and a prototype and then use formals(f) <- ... as shown.
> >
> > # inputs
> > arg_names <- c("x", "y", paste0("a", 1:3), paste0("b", 1:3))
> > f <- function() {}
> >
> > arg <- alist(x = )
> > formals(f) <- setNames(c(arg, rep(arg, length(arg_names)-1)), arg_names)
> > f
> >
> > giving
> >
> > function (x, y, a1, a2, a3, b1, b2, b3)
> > {
> > }
> >
> > On Fri, Oct 24, 2025 at 10:23 PM Rolf Turner <rolfturner using posteo.net> wrote:
> > >
> > >
> > > I want to build a function (say "buildFn") to *return* a function of the
> > > form
> > >
> > > foo(x,y,a1, ... an, b1, ..., bn)
> > >
> > > where the arguments ai and bi are given in the form of a list created
> > > in R. E.g. I'd like to be able to say
> > >
> > > argnms <- c(paste0("a",1:3),paste0("b",1:3"))
> > > foo <- buildFn(argnms)
> > >
> > > with the resulting "foo" having arguments x, y, a1, a2, a3, b1, b2, b3.
> > >
> > > I thought I might be able to do this using "formals<-" but I cannot get
> > > this to work. i could provide more detail of what I've tried, but it's
> > > probably not worth it.
> > >
> > > Can anyone steer me in the right direction? Thanks.
> > >
> > > cheers,
> > >
> > > Rolf Turner
> > >
> > > --
> > > Honorary Research Fellow
> > > Department of Statistics
> > > University of Auckland
> > > Stats. Dep't. (secretaries) phone:
> > > +64-9-373-7599 ext. 89622
> > > Home phone: +64-9-480-4619
> > >
> > > ______________________________________________
> > > 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 https://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
>
>
>
> --
> Statistics & Software Consulting
> GKX Group, GKX Associates Inc.
> tel: 1-877-GKX-GROUP
> email: ggrothendieck at gmail.com
--
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