-
Notifications
You must be signed in to change notification settings - Fork 21
/
ellipse3d.R
58 lines (49 loc) · 2.31 KB
/
ellipse3d.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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
ellipse3d <- function(x, ...)
UseMethod("ellipse3d")
ellipse3d.default <-
function(x, scale = c(1, 1, 1), centre = c(0, 0, 0), level = 0.95,
t = sqrt(qchisq(level, 3)), which = 1:3, subdivide = 3, smooth = TRUE, ...) {
stopifnot(is.matrix(x))
cov <- x[which, which]
chol <- chol(cov)
sphere <- subdivision3d(cube3d(...), subdivide)
norm <- sqrt( sphere$vb[1,]^2 sphere$vb[2,]^2 sphere$vb[3,]^2 )
for (i in 1:3) sphere$vb[i,] <- sphere$vb[i,]/norm
sphere$vb[4,] <- 1
if (smooth)
sphere$normals <- sphere$vb
result <-scale3d(transform3d( sphere, chol), t,t,t)
if (!missing(scale))
result <- scale3d(result, scale[1], scale[2], scale[3])
if (!missing(centre))
result <- translate3d(result, centre[1], centre[2], centre[3])
return(result)
}
ellipse3d.lm <-
function(x, which = 1:3, level = 0.95, t = sqrt(3 * qf(level,
3, x$df.residual)), ...) {
s <- summary(x)
names <- names(x$coefficients[which])
structure(c(ellipse3d.default(s$sigma^2 * s$cov.unscaled[which, which],
centre = x$coefficients[which], t = t, ...),
xlab=names[1], ylab=names[2], zlab=names[3]), class="mesh3d")
}
ellipse3d.glm <- function(x, which = 1:3, level = 0.95, t, dispersion, ...) {
s <- summary(x)
est.disp <- missing(dispersion) & !(x$family$family %in% c('poisson','binomial'))
if (missing(dispersion)) dispersion <- s$dispersion
if (missing(t)) t <- ifelse(est.disp,sqrt(3 * qf(level, 3, s$df[2])),
sqrt(qchisq(level, 3)))
names <- names(x$coefficients[which])
structure(c(ellipse3d.default(dispersion * s$cov.unscaled[which, which],
centre = x$coefficients[which], t = t, ...),
xlab=names[1], ylab=names[2], zlab=names[3]), class="mesh3d")
}
ellipse3d.nls <- function(x, which = 1:3, level = 0.95, t = sqrt(3 * qf(level,
3, s$df[2])), ...) {
s <- summary(x)
names <- names(x$m$getPars()[which])
structure(c(ellipse3d.default(s$sigma^2 * s$cov.unscaled[which, which],
centre = x$m$getPars()[which], t = t, ...),
xlab=names[1], ylab=names[2], zlab=names[3]), class="mesh3d")
}