4

我想将 3D abline 添加到 R 的 lattice 包中的云散点图中。这是我的数据的一个子集(3 个变量都在 0,1 之间):

dat <- structure(c(0.413, 0.879, 0.016, 0.631, 0.669, 0.048, 1, 0.004, 0.523, 0.001, 
0.271, 0.306, 0.014, 0.008, 0.001, 0.023, 0.670, 0.027, 0.291, 0.709, 
0.002, 0.003, 0.611, 0.024, 0.580, 0.755, 1, 0.003, 0.038, 0.143, 0.214, 
0.161, 0.008, 0.027, 0.109, 0.026, 0.229, 0.006, 0.377, 0.191, 0.724, 
0.119, 0.203, 0.002, 0.309, 0.011, 0.141, 0.009, 0.340, 0.152, 0.545, 
0.001, 0.217, 0.132, 0.839, 0.052, 0.745, 0.001, 1, 0.273), .Dim = c(20L, 3L))

这是云图:

# cloud plot
trellis.par.set("axis.line", list(col="transparent")) 
cloud(dat[, 1] ~ dat[, 2] + dat[, 3], pch=16, col="darkorange", groups=NULL, cex=0.8, 
    screen=list(z = 30, x = -70, y = 0),
    scales=list(arrows=FALSE, cex=0.6, col="black", font=3, tck=0.6, distance=1) ) 

我想在 0,0,0 和 1,1,1 之间添加一条灰色虚线(即,对角线穿过绘图)。我知道我可以使用“type="l", panel.3d.cloud=panel.3dscatter" 将点更改为线,但我看不到使用此方法向绘图添加额外点/线的方法。

这是我想使用 scatterplot3d 实现的示例:

# scatterplot3d
s3d <- scatterplot3d(dat, type="p", color="darkorange", angle=55, scale.y=0.7,
    pch=16, col.axis="blue", col.grid="lightblue") 

# add line 
s3d$points3d(c(0,1), c(0,1), c(0,1), col="grey", type="l", lty=2)

我想用云图来控制我查看图的角度(scatterplot3d 不允许我将图的 0,0,0 角朝向)。感谢您的任何建议。

4

1 回答 1

2

不优雅而且可能很脆弱,但这似乎有效......

cloud(dat[, 1] ~ dat[, 2] + dat[, 3], pch=16, col="darkorange", 
        groups=NULL, cex=0.8, 
    screen=list(z = 30, x = -70, y = 0),
    scales=list(arrows=FALSE, cex=0.6, col="black", font=3, 
                tck=0.6, distance=1) ,
      panel=function(...) {
        L <- list(...)
        L$x <- L$y <- L$z <- c(0,1)
        L$type <- "l"
        L$col <- "gray"
        L$lty <- 2
        do.call(panel.cloud,L)
        p <- panel.cloud(...)
      })

要记住的一件事是,这不会删除隐藏的点/线,因此线要么在所有点的前面,要么在所有点的后面;在这个(编辑的)版本中,do.call(panel.cloud,L)首先是点会遮住线条,而不是相反。如果您想要删除隐藏线,那么我相信这rgl是您唯一的选择......非常强大但不那么漂亮并且具有更原始的界面。

于 2011-10-08T21:34:44.240 回答