R - 补丁中的3d图

Mul*_*one 4 3d matlab r wireframe lattice

我在数据框中有以下数据:

**x** in (0,1)
**y** in [0,1]
**z** in [0,1]
Run Code Online (Sandbox Code Playgroud)

例如:

X,Y,Z
0.1, 0.2, 0.56
0.1, 0.3, 0.57
...
Run Code Online (Sandbox Code Playgroud)

我想在这种类型的图表上绘制它们: 一个3d图

我试过R,但我能得到的只是一个不那么花哨的3D散点图.我还读到了格子3D线框,但我无法理解它.

我应该怎样做才能在R中获得类似线框的Matlab?涉及哪些数据转换?

这是文档中的示例代码:

x <- seq(-pi, pi, len = 20)
y <- seq(-pi, pi, len = 20)
g <- expand.grid(x = x, y = y)
g$z <- sin(sqrt(g$x^2 + g$y^2))
wireframe(z ~ x * y, g, drape = TRUE,
aspect = c(3,1), colorkey = TRUE)
Run Code Online (Sandbox Code Playgroud)

我不觉得特别清楚.

编辑:该persp3d功能工作正常,我能够生成一种颜色的三维图.如何设置相对于z值的色阶?

感谢任何提示,Mulone

Jam*_*mes 12

使用outer创建z值,然后使用persp到的情节:

z <- outer(x,y, function(x,y) sin(sqrt(x^2+y^2)))
persp(x,y,z)
Run Code Online (Sandbox Code Playgroud)

persp

有着色和设置视角的选项,请参阅?persp.请参阅Matlab样式着色的第四个示例.

对于交互式绘图,请考虑persp3drgl包中使用:

require(rgl)
persp3d(x,y,z,col="blue")
Run Code Online (Sandbox Code Playgroud)

编辑

要添加颜色,与方法略有不同persp,因为颜色与顶点而不是刻面的中心有关,但它更容易.

jet.colors <- colorRampPalette( c("blue", "green") ) 
pal <- jet.colors(100)
col.ind <- cut(z,100) # colour indices of each point
persp3d(x,y,z,col=pal[col.ind])
Run Code Online (Sandbox Code Playgroud)

persp3d

帮助文件建议添加参数smooth=FALSE,但这取决于个人偏好.