[R] Help using mapply to run multiple models

William Dunlap wdunlap at tibco.com
Thu Dec 19 22:51:36 CET 2013


> I do get this error:
> Error in glm.control(modelType = "glm") :
>   unused argument(s) (modelType = "glm")

Add the line
   call$modelType <- NULL # omit modelType argument
to your function.  Otherwise
   f("glm", ...)
makes the call
   glm(modelType="glm", ...)
where you want it to make the call
   glm(...)

Bill Dunlap
Spotfire, TIBCO Software
wdunlap tibco.com


> -----Original Message-----
> From: Simon Kiss [mailto:sjkiss at gmail.com]
> Sent: Thursday, December 19, 2013 1:49 PM
> To: William Dunlap
> Cc: Dennis Murphy; r-help at r-project.org
> Subject: Re: [R] Help using mapply to run multiple models
> 
> Hi there: Just to tie this altogether.
> 
> Here is the final function
> 
> f<- function (modelType, responseName, predictorNames, data, ..., envir =
> parent.frame())
> {
>   call <- match.call()
>   call$formula <- formula(envir = envir, paste(responseName, sep = " ~ ",
>                                                paste0("`", predictorNames, "`", collapse = " + ")))
>   call[[1]] <- as.name(modelType)
>   call$responseName <- NULL # omit responseName=
>   call$predictorNames <- NULL # omit 'predictorNames='
>   eval(call, envir = envir)
> }
> 
> Here I call the function to a list of predictor variables and one dependent variable. Note
> "glm" and not glm.
> z <- lapply(list(c("hp","drat"), c("cyl"), c("am","gear")), FUN=function(preds)f("glm",
> "carb", preds, data=mtcars, family='binomial'))
> 
> I do get this error:
> Error in glm.control(modelType = "glm") :
>   unused argument(s) (modelType = "glm")
> 
> But
> lapply(z, summary)
> 
> does seem to return a list of model summaries. It looks like it worked.
> 
> I also tried.
> z <- lapply(list(c("hp","drat"), c("cyl"), c("am","gear")), FUN=function(preds)f("lm", "mpg",
> preds, data=mtcars))
> 
> Here, I get:
> 1: In lm.fit(x, y, offset = offset, singular.ok = singular.ok, ...) :
>   extra argument 'modelType' is disregarded.
> 2: In lm.fit(x, y, offset = offset, singular.ok = singular.ok, ...) :
>   extra argument 'modelType' is disregarded.
> 3: In lm.fit(x, y, offset = offset, singular.ok = singular.ok, ...) :
>   extra argument 'modelType' is disregarded.
> 
> But again, it actually looks like it worked.
> So, thank you very much!
> Yours, Simon Kiss
> 
> On 2013-12-19, at 1:55 PM, Simon Kiss <sjkiss at gmail.com> wrote:
> 
> > Hello Bill, that is fantastic and it's quite a bit above what I could write. Is there a way to
> make the model type an argument to the function so that you can specify whether one is
> running glm, lm and such?
> > I tried to modify it by inserting an argument modelType below, but that doesn't work.
> > Yours, simon Kiss
> >> f <- function (modelType, responseName, predictorNames, data, ..., envir =
> parent.frame())
> >>   {
> >>       call <- match.call()
> >>       call$formula <- formula(envir = envir, paste(responseName, sep = " ~ ",
> >>           paste0("`", predictorNames, "`", collapse = " + ")))
> >>               call[[1]] <- quote(modelType) # '
> >>       call$responseName <- NULL # omit responseName=
> >>       call$predictorNames <- NULL # omit 'predictorNames='
> >>               eval(call, envir = envir)
> >>   }
> > On 2013-12-18, at 3:07 PM, William Dunlap <wdunlap at tibco.com> wrote:
> >
> >> f <- function (responseName, predictorNames, data, ..., envir = parent.frame())
> >>   {
> >>       call <- match.call()
> >>       call$formula <- formula(envir = envir, paste(responseName, sep = " ~ ",
> >>           paste0("`", predictorNames, "`", collapse = " + ")))
> >>               call[[1]] <- quote(glm) # 'f' -> 'glm'
> >>       call$responseName <- NULL # omit responseName=
> >>       call$predictorNames <- NULL # omit 'predictorNames='
> >>               eval(call, envir = envir)
> >>   }
> >> as in
> >>   z <- lapply(list(c("hp","drat"), c("cyl"), c("am","gear")), FUN=function(preds)f("carb",
> preds, data=mtcars, family=poisson))
> >>   lapply(z, summary)
> >
> > *********************************
> > Simon J. Kiss, PhD
> > Assistant Professor, Wilfrid Laurier University
> > 73 George Street
> > Brantford, Ontario, Canada
> > N3T 2C9
> > Cell: +1 905 746 7606
> >
> >
> >
> 
> *********************************
> Simon J. Kiss, PhD
> Assistant Professor, Wilfrid Laurier University
> 73 George Street
> Brantford, Ontario, Canada
> N3T 2C9
> Cell: +1 905 746 7606
> 
> 



More information about the R-help mailing list