2025-01-12 04:36:52 +08:00

58 lines
1.8 KiB
R

library(nlme)
if (requireNamespace("MASS")) {
## Example 1 --- was ./update.R ---
data(petrol, package = 'MASS')
Petrol <- petrol
Petrol[, 2:5] <- scale(Petrol[, 2:5], scale = FALSE)
pet3.lme <- lme(Y ~ SG + VP + V10 + EP,
random = ~ 1 | No, data = Petrol, method="ML")
upet3 <- update(pet3.lme, Y ~ SG + VP + V10)
upet3
vc3 <- VarCorr(upet3)
upet2 <- lme(Y ~ SG + VP + V10, random = ~ 1 | No, data = Petrol, method = "ML")
stopifnot(
all.equal(upet3, upet2, tol = 1e-15)
,
all.equal(fixef(upet3),
c("(Intercept)" = 19.659375, SG = 0.125045632,
VP = 2.27818601, V10 = 0.0672413592), tol = 1e-8)# 1e-9
,
all.equal(as.numeric(vc3[,"StdDev"]),
c(0.00029397, 9.69657845), tol=1e-6)
)
}
## Example 2 ---
data(Assay)
as1 <- lme(logDens~sample*dilut, data=Assay,
random=pdBlocked(list(
pdIdent(~1),
pdIdent(~sample-1),
pdIdent(~dilut-1))))
as1s <- update(as1, random=pdCompSymm(~sample-1))
(an.1s <- anova(as1, as1s)) # non significant
stopifnot(
all.equal(drop(data.matrix(an.1s[2,-1])),
c(Model = 2, df = 33, AIC = -10.958851, BIC = 35.280663,
logLik = 38.479425, Test = 2,
L.Ratio = 0.11370211, `p-value` = 0.73596807), tol=8e-8))
as1S <- update(as1, . ~ sample+dilut) # dropping FE interaction
tools::assertWarning(anova(as1, as1S))# REML not ok for different FE.
as1M <- update(as1, method = "ML")
as1SM <- update(as1S, method = "ML")
(anM <- anova(as1M, as1SM)) # anova() OK: comparing MLE fits
## ==> significant: P ~= 0.0054
stopifnot(
all.equal(drop(data.matrix(anM[2,])[,-(1:2)]),
c(df = 14, AIC = -169.588248, BIC = -140.267424, logLik = 98.7941241,
Test = 2, L.Ratio = 39.7345188, `p-value` = 0.0053958561),
tol = 8e-8)
)