# NOT RUN {
## Binomial response --------------
data(carrots)
Cfit1 <- glm(cbind(success, total-success) ~ logdose + block,
data = carrots, family = binomial)
summary(Cfit1)
Rfit1 <- glmrob(cbind(success, total-success) ~ logdose + block,
family = binomial, data = carrots, method= "Mqle",
control= glmrobMqle.control(tcc=1.2))
summary(Rfit1)
Rfit2 <- glmrob(success/total ~ logdose + block, weights = total,
family = binomial, data = carrots, method= "Mqle",
control= glmrobMqle.control(tcc=1.2))
coef(Rfit2) ## The same as Rfit1
## Binary response --------------
data(vaso)
Vfit1 <- glm(Y ~ log(Volume) + log(Rate), family=binomial, data=vaso)
coef(Vfit1)
Vfit2 <- glmrob(Y ~ log(Volume) + log(Rate), family=binomial, data=vaso,
method="Mqle", control = glmrobMqle.control(tcc=3.5))
coef(Vfit2) # c = 3.5 ==> not much different from classical
## Note the problems with tcc <= 3 %% FIXME algorithm ???
Vfit3 <- glmrob(Y ~ log(Volume) + log(Rate), family=binomial, data=vaso,
method= "BY")
coef(Vfit3)## note that results differ much.
## That's not unreasonable however, see Kuensch et al.(1989), p.465
## Poisson response --------------
data(epilepsy)
Efit1 <- glm(Ysum ~ Age10 + Base4*Trt, family=poisson, data=epilepsy)
summary(Efit1)
Efit2 <- glmrob(Ysum ~ Age10 + Base4*Trt, family = poisson,
data = epilepsy, method= "Mqle",
control = glmrobMqle.control(tcc= 1.2))
summary(Efit2)
## 'x' weighting:
(Efit3 <- glmrob(Ysum ~ Age10 + Base4*Trt, family = poisson,
data = epilepsy, method= "Mqle", weights.on.x = "hat",
control = glmrobMqle.control(tcc= 1.2)))
try( # gives singular cov matrix: 'Trt' is binary factor -->
# affine equivariance and subsampling are problematic
Efit4 <- glmrob(Ysum ~ Age10 + Base4*Trt, family = poisson,
data = epilepsy, method= "Mqle", weights.on.x = "covMcd",
control = glmrobMqle.control(tcc=1.2, maxit=100))
)
##--> See example(possumDiv) for another Poisson-regression
### -------- Gamma family -- data from example(glm) ---
clotting <- data.frame(
u = c(5,10,15,20,30,40,60,80,100),
lot1 = c(118,58,42,35,27,25,21,19,18),
lot2 = c(69,35,26,21,18,16,13,12,12))
summary(cl <- glm (lot1 ~ log(u), data=clotting, family=Gamma))
summary(ro <- glmrob(lot1 ~ log(u), data=clotting, family=Gamma))
clotM5.high <- within(clotting, { lot1[5] <- 60 })
op <- par(mfrow=2:1, mgp = c(1.6, 0.8, 0), mar = c(3,3:1))
plot( lot1 ~ log(u), data=clotM5.high)
plot(1/lot1 ~ log(u), data=clotM5.high)
par(op)
## Obviously, there the first observation is an outlier with respect to both
## representations!
cl5.high <- glm (lot1 ~ log(u), data=clotM5.high, family=Gamma)
ro5.high <- glmrob(lot1 ~ log(u), data=clotM5.high, family=Gamma)
with(ro5.high, cbind(w.x, w.r))## the 5th obs. is downweighted heavily!
plot(1/lot1 ~ log(u), data=clotM5.high)
abline(cl5.high, lty=2, col="red")
abline(ro5.high, lwd=2, col="blue") ## result is ok (but not "perfect")
# }
# NOT RUN {
<!-- %% FIXME: Need work -- option of *starting* from -->
# }
# NOT RUN {
<!-- %% ----- see Andreas' ~/R/MM/Pkg-ex/robustbase/glmrob-gamma-ARu.R -->
# }
# NOT RUN {
# }
# NOT RUN {
<!-- % ## a "regular outlier" in the middle : -->
# }
# NOT RUN {
<!-- % clotM4.3 <- within(clotting, { lot1[4] <- 1000 }) -->
# }
# NOT RUN {
<!-- % ## .. not even this one works : ... need *robust* start ?! -->
# }
# NOT RUN {
<!-- % try(cl4.3 <- glm (lot1 ~ log(u), data=clotM4.3, family=Gamma)) -->
# }
# NOT RUN {
<!-- % try(ro4.3 <- glmrob(lot1 ~ log(u), data=clotM4.3, family=Gamma)) -->
# }
# NOT RUN {
# }
# NOT RUN {
<!-- % ## The new option to start from "lmrobMM" --- not yet ok either -->
# }
# NOT RUN {
<!-- % try( -->
# }
# NOT RUN {
<!-- % ro4.3 <- glmrob(lot1 ~ log(u), data=clotM4.3, family=Gamma, -->
# }
# NOT RUN {
<!-- % start = "lmrobMM") -->
# }
# NOT RUN {
<!-- % ) -->
# }
# NOT RUN {
<!-- % ## summary(ro4.3) -->
# }
# NOT RUN {
# }
# NOT RUN {
<!-- %% TODO the "same" with lot2 : -->
# }
# NOT RUN {
<!-- %% summary(glm(lot2 ~ log(u), data=clotting, family=Gamma)) -->
# }
Run the code above in your browser using DataLab