Thanks Simon, that was quite enlightening, as I did somewhat misunderstand how 
gamm works.  

The bs='re' argument to s() is something I had not seen before.  And the idea 
of pooling any random effects over the entire population does seem safer than 
trying to estimate variabilities etc from barely 10 subjects.  I appreciate the 
feedback.  

A couple of followups -- feel free to reply offline only, if at all :)  
although I suspect others might learn some things, 

In your dummy variable trick, I see how subjectwise predictions are obtained.  
But to get the Group mean predictions, isn't the s term with the 0 dummy by 
variable the same as just omitting the s term with Subject altogether?  I would 
think so but want to check.

In the spirit of handling subjectwise variabilities, I could imagine using the 
term

        s(Subject, bs="re", by=X) 

and trying to emulate lme-like behavior and fitting a random effect slope to 
each subject.  First question is, is that indeed what it does?  If so, would 
this term include an intercept? I would assume it doesn't but again want to 
check.  

Thanks again,
John



-----Original Message-----
From: Simon Wood [mailto:s.w...@bath.ac.uk] 
Sent: Friday, 24 June, 2011 11:43 AM
To: Szumiloski, John
Cc: r-help@r-project.org
Subject: Re: mgcv:gamm: predict to reflect random s() effects?

Given that you don't have huge numbers of subjects you could fit the model with 
`gam' rather than `gamm', using

out.gamm <- gam( Y ~ Group + s(X, by=Group) + s(Subject,bs="re"),
                  method="REML")

Then your predictions will differ by subject (see e.g. ?random.effects for a 
bit more information on simple random effects in mgcv:gam).

A further trick allows you to choose whether to predict with the subject 
effects at their predicted values, or zero.

Let dum be a vector of 1's...

out.gamm <- gam( Y ~ Group + s(X, by=Group) +
             s(Subject,bs="re",by=dum), method="REML")

Predicting with dum set to 1 gives the predictions that you want. 
Setting dum to 0 gives predictions with the prediction Subject effects set to 
zero.

The reason that trying to predict with the gamm lme object is tricky relates to 
how gamm works. It takes the GAMM specification, and then sets up a 
corresponding `working mixed model' which is estimated using lme. The working 
mixed model uses working variable names set within gamm. If you try to predict 
using the working model lme object then predict.lme looks for these internal 
working variable names, not the variable names that you supplied....

Basically gamm treats all random effects as 'part of the noise' in the model 
specification, and adjusts the variance estimates for the smooths and fixed 
effects to reflect this. It isn't set up to predict easily at different random 
effect grouping levels, in the way that lme is.

best,
Simon

On 24/06/11 15:59, Szumiloski, John wrote:
> Dear useRs,
> I am using the gamm function in the mgcv package to model a smooth 
> relationship between a covariate and my dependent variable, while 
> allowing for quantification of the subjectwise variability in the 
> smooths. What I would like to do is to make subjectwise predictions 
> for plotting purposes which account for the random smooth components of the 
> fit.
> An example. (sessionInfo() is at bottom of message) My model is 
> analogous to  > out.gamm <- gamm( Y ~ Group + s(X, by=Group), random = 
> list(Subject=~1) ) Y and X are numeric, Group is an unordered factor 
> with 5 levels, and Subject is an unordered factor with ~70 levels Now 
> the output from gamm is a list with an lme component and a gam 
> component. If I make a data frame "newdat" like this:
>  > newdat
> X Group Subject
> 5 g1 s1
> 5 g1 s2
> 5 g1 s3
> 6 g1 s1
> 6 g1 s2
> 6 g1 s3
> I can get the fixed effects prediction of the smooth by  > 
> predict(out.gamm$gam, newdata=newdat) Which gives
> 1 1.1 1.2 2 2.1 2.2
> 3.573210 3.573210 3.573210 3.553694 3.553694 3.553694 But I note that 
> the predictions are identical across different values of Subject. So 
> this accounts for only the fixed effects part of the model, and not 
> any random smooth effects.
> If I try to extract predictions from the lme component:
>  > predict(out.gamm$lme, newdata=newdat) I get the following error 
> message:
> Error in predict.lme(out.gamm$lme, newdata = newdat) :
> Cannot evaluate groups for desired levels on "newdata"
> So, is there a way to get subjectwise predictions which include the 
> random effect contributions of the smooths?
> Thanks, John
> ---------
> ### session info follows
>  > sessionInfo()
> R version 2.13.0 Patched (2011-06-20 r56188)
> Platform: i386-pc-mingw32/i386 (32-bit)
> locale:
> [1] LC_COLLATE=English_United States.1252 LC_CTYPE=English_United
> States.1252
> [3] LC_MONETARY=English_United States.1252 LC_NUMERIC=C [5] 
> LC_TIME=English_United States.1252 attached base packages:
> [1] grDevices datasets splines grid graphics utils stats methods base 
> other attached packages:
> [1] mgcv_1.7-6 gmodels_2.15.1 car_2.0-10 nnet_7.3-1 MASS_7.3-13
> nlme_3.1-101
> [7] rms_3.3-1 Hmisc_3.8-3 survival_2.36-9 lattice_0.19-26 loaded via a 
> namespace (and not attached):
> [1] cluster_1.14.0 gdata_2.8.2 gtools_2.6.2 Matrix_0.999375-50 
> tools_2.13.0 John Szumiloski, Ph.D.
[snip]


--
Simon Wood, Mathematical Science, University of Bath BA2 7AY UK
+44 (0)1225 386603               http://people.bath.ac.uk/sw283
Notice:  This e-mail message, together with any attachme...{{dropped:11}}

______________________________________________
R-help@r-project.org mailing list
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.

Reply via email to