On 9/17/2008 9:40 AM, Michael Friendly wrote:
Yihui Xie wrote:
Hi Michael,

You need to specify both 'box' and 'axes' to FALSE to avoid the box
lines (if you don't specify the latter one, there will still be axes
lines).


Hi Yihui
I tried several variations, none of which would simply add the ellipse and nothing else to the original
plot of points:

plot3d(trees, type="s", size=0.5, col="blue", cex=2)

# how to avoid the extra box?

As Yihui said, use axes=FALSE, box=FALSE in the call above. However, there's another possibility: remove the box after adding it. For example, if you save the result of the plot3d call, you'll see the ids of the various bits and pieces:

> myplot <- plot3d(trees, type="s", size=0.5, col="blue", cex=2)
> myplot
     data      axes box.lines      xlab      ylab      zlab
       28         1        29        30        31        32

Now you can remove the ones you don't like:

> rgl.pop(id=1)
> rgl.pop(id=29)

You can also use rgl.ids() to print the list of currently removable shapes, but it doesn't know the purpose of each, so is less informative:

> myplot <- plot3d(trees, type="s", size=0.5, col="blue", cex=2)
> myplot
     data      axes box.lines      xlab      ylab      zlab
       33         1        34        35        36        37
> rgl.ids()
  id    type
1 33 spheres
2 34   lines
3 35    text
4 36    text
5 37    text

(It also misses the axes, because of the strange way rgl handles them.)

Duncan Murdoch

# -- this doesn't remove the extra box, but keeps the points & axis labels
plot3d( ellipse3d(cov, centre=mu, level=0.68, box=FALSE), col="pink", alpha=0.2, add = TRUE, axes=FALSE)

# -- this removes the original axes, the points & labels axes x, y, z
plot3d( ellipse3d(cov, centre=mu, level=0.68, box=FALSE, col="pink", alpha=0.2, add = TRUE, axes=FALSE))

-Michael

On Wed, Sep 17, 2008 at 8:34 PM, Michael Friendly <[EMAIL PROTECTED]> wrote:
Hi
I'm trying to make a 3d plot showing a point cloud, the corresponding data
ellipse
and the principal axes of the ellipse as vectors.

library(rgl)
data(trees)
cov <- cov(trees)
mu <- mean(trees)

plot3d(trees, type="s", size=0.5, col="blue", cex=2)

In this step, an extra box is added.  I've tried using box=FALSE, but it has
no effect.
# how to avoid the extra box?
plot3d( ellipse3d(cov, centre=mu, level=0.68), col="pink", alpha=0.2,  add =
TRUE)

Here's what I've tried to plot the principal axes in variable space, using
the result of prcomp().
But I've got something wrong, because, although they are at right angles,
they don't
align with the ellipse.

PC <- princomp(trees)
sdev <- PC$sdev         # component standard deviations
sd <- sqrt(diag(cov))   # variable standard deviations

# vectors in variable space of principal components
vec <- matrix(mu,3,3, byrow=TRUE) + diag(sd) %*% PC$loadings

for (j in 1:3) {
 mat <- rbind(mu, vec[j,])
 segments3d(mat, col="red")
}

Can someone help?


______________________________________________
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