forked from strengejacke/mixed-models-snippets
-
Notifications
You must be signed in to change notification settings - Fork 0
/
time-varying-covariates.R
44 lines (36 loc) · 1.61 KB
/
time-varying-covariates.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# Time-varying covariates ----
# Time-varying covariates are most flexibly modelled with splines.
# Here are some examples, from simple longitudinal models to models
# with time-varying covariates.
#
# y = outcome (continuous / Gaussian)
# t = time-points
# tv = time-varying covariate
# tc = time-constant covariate
# id = subject-ID
# Model 1 - constant change in time ----
lmer(y ~ t + tv + tc + (1 + t | id), data)
# Model 2 - constant change in time, different slopes depending on covariate ----
# (interaction)
lmer(y ~ t * tv + tc + (1 + t | id), data)
# Model 3 - non-linear change in time ----
lmer(y ~ t + I(t^2) + tv + tc + (1 + t | id), data)
# Model 4 - non-linear change in time, different slopes depending on covariate ----
# (interaction)
lmer(y ~ t * tv + I(t^2) * tv + tc + (1 + t | id), data)
# Model 5 - non-linear change in time, time-varying covariate ----
# (interaction with non-linear covariate)
lmer(y ~ y ~ t * tv + I(t^2) * tv + t * I(tv^2) + I(t^2) * I(tv^2) + tc + (1 + t | id), data)
# Model 6 - non-linear change in time, time-varying covariate ---
# (cubic instead of quadratic interaction)
model6 <- lmer(
y ~ t * tv + I(t^2) * tv + I(t^3) * tv + t * I(tv^2) + t * I(tv^3) +
I(t^2) * I(tv^2) + I(t^2) * I(tv^3) + I(t^3) * I(tv^2) +
I(t^3) * I(tv^3) + tc + (1 + t | id),
data
)
# This final model with splines is almost identical to model 6,
# when comparing marginal effects. The time-varying covariate
# needs to be specified in the "by"-argument from the spline-term.
# Time "t" is non-linear (spline), "tv" varies over time.
model7 <- lmer(y ~ s(t) + s(t, by = tv) + tc + (1 + t | id), data)