[R-sig-ME] allFit fails after removing object with starting values for model parameters from workspace
Ben Bolker
bbo|ker @end|ng |rom gm@||@com
Mon Oct 7 20:13:55 CEST 2019
This works for me in the latest *development* version of lme4
(probably fixed since around the end of August). Does devel version
work for you? Maybe getting to be time for a new release (it's been 6
months: here's what's changed ...
https://github.com/lme4/lme4/blob/master/inst/NEWS.Rd )
On 2019-10-07 1:12 p.m., Gerrit Eichner wrote:
> Dear Ben and other lmer-experts,
>
> if I extend my setting a little bit, a new/similar problem appears.
> For some reasons I would like to change the control structures and
> "hardwire" that as in:
>
> lmerCtrl <- lmerControl(optCtrl = list(xtol_abs = 1e-9,
> ftol_abs = 1e-9))
>
> theta <- c(1, 0.01, 0.2)
> fm <- eval(bquote(
> lmer(Reaction ~ Days + (Days | Subject), data = sleepstudy,
> start = .(theta),
> control = .(lmerCtrl)) # THIS IS NEW.
> ))
>
>
> Then allFit "goes on strike" again, now complaining about unused
> arguments:
>
> allFit(fm, verbose = FALSE)
> Error in (function (optimizer = "nloptwrap", restart_edge = TRUE,
> boundary.tol = 1e-05, :
> unused arguments (checkControl = list("ignore", "stop", "ignore",
> "stop", "stop", "message+drop.cols", "warning", "stop"), checkConv =
> list(list("warning", 0.002, NULL), list("message", 1e-04),
> list("warning", 1e-06)))
>
>
> Any ideas how to circumvent this?
>
> Best regards -- Gerrit
>
> ---------------------------------------------------------------------
> Dr. Gerrit Eichner Mathematical Institute, Room 212
> gerrit.eichner using math.uni-giessen.de Justus-Liebig-University Giessen
> Tel: +49-(0)641-99-32104 Arndtstr. 2, 35392 Giessen, Germany
> http://www.uni-giessen.de/eichner
> ---------------------------------------------------------------------
>
> Am 08.08.2019 um 15:41 schrieb Gerrit Eichner:
>> Thx a lot, Ben, for the fast reply which clearly explains the
>> cause of my problem. I've just found a solution which works for
>> me (and which is not as simple as "don't delete theta" ;-) ):
>> I "hardwire" theta's value into the function call:
>>
>> theta <- c(1, 0.01, 0.2)
>> fm <- eval(bquote(
>> lmer(Reaction ~ Days + (Days | Subject), data = sleepstudy,
>> start = .(theta))
>> ))
>>
>> rm(theta)
>> allFit(fm, verbose = FALSE)
>>
>>
>> Works like a "charm", at least in my current workflow. :-)
>>
>> Thanks once more -- Gerrit
>>
>> ---------------------------------------------------------------------
>> Dr. Gerrit Eichner Mathematical Institute, Room 212
>> gerrit.eichner using math.uni-giessen.de Justus-Liebig-University Giessen
>> Tel: +49-(0)641-99-32104 Arndtstr. 2, 35392 Giessen, Germany
>> http://www.uni-giessen.de/eichner
>> ---------------------------------------------------------------------
>>
>> Am 08.08.2019 um 15:26 schrieb Ben Bolker:
>>>
>>> This is not surprising, as allFit() uses update(), which tries to
>>> re-evaluate the function ... at the very least allFit needs a
>>> documentation update with that hint ... (I also notice at a glance that
>>> the allFit docs seem to be incomplete anyway).
>>>
>>> If you say more about your workflow we might be able to find a way to
>>> help. (If your workflow is this simple then the answer would be "well
>>> then don't delete theta" ...)
>>>
>>> cheers
>>> Ben Bolker
>>>
>>>
>>> On 2019-08-08 9:06 a.m., Gerrit Eichner wrote:
>>>> Dear lmer-experts,
>>>>
>>>> if I refit a fitted model with all available optimizers AFTER
>>>> removing the object which contains the starting values for the
>>>> parameters of the model as in
>>>>
>>>> theta <- c(1, 0.01, 0.2)
>>>> fm <- lmer(Reaction ~ Days + (Days | Subject), data = sleepstudy,
>>>> start = theta)
>>>> rm(theta)
>>>> allFit(fm, verbose = FALSE)
>>>>
>>>> none of the optimizers succeeds:
>>>>
>>>> original model:
>>>> Reaction ~ Days + (Days | Subject)
>>>> optimizers (7): bobyqa, Nelder_Mead, nlminbwrap, nmkbw,
>>>> optimx.L-BFGS-B,
>>>> nloptwrap.NLOPT_LN_N...
>>>> 7 optimizer(s) failed
>>>> differences in negative log-likelihoods:
>>>> max= -Inf ; std dev= NA
>>>> Warning messages:
>>>> 1: In min(nllvec) : no non-missing arguments to min; returning Inf
>>>> 2: In max(nllvec - min(nllvec)) :
>>>> no non-missing arguments to max; returning -Inf
>>>>
>>>>
>>>> If I don't remove theta from my workspace everything works fine.
>>>> Is there a workaround for this - from my perspective - unwanted
>>>> behaviour? (I have situations where allFit is used in a different
>>>> environment from the one wherein the model was fit, e.g., after
>>>> fitting the model the object which contains the fit is saved and
>>>> later loaded in another R-session to be processed by allFit.)
>>>> I could, of course, save theta everytime as well ... Any ideas?
>>>>
>>>> Best regards -- Gerrit
>>>>
>>>> ---------------------------------------------------------------------
>>>> Dr. Gerrit Eichner Mathematical Institute, Room 212
>>>> gerrit.eichner using math.uni-giessen.de Justus-Liebig-University Giessen
>>>> Tel: +49-(0)641-99-32104 Arndtstr. 2, 35392 Giessen, Germany
>>>> http://www.uni-giessen.de/eichner
>>>>
>>>> _______________________________________________
>>>> R-sig-mixed-models using r-project.org mailing list
>>>> https://stat.ethz.ch/mailman/listinfo/r-sig-mixed-models
>>>
>>> _______________________________________________
>>> R-sig-mixed-models using r-project.org mailing list
>>> https://stat.ethz.ch/mailman/listinfo/r-sig-mixed-models
>>>
>>
>> _______________________________________________
>> R-sig-mixed-models using r-project.org mailing list
>> https://stat.ethz.ch/mailman/listinfo/r-sig-mixed-models
>
> _______________________________________________
> R-sig-mixed-models using r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-sig-mixed-models
More information about the R-sig-mixed-models
mailing list