文章目录
- graphics::persp
- lattice::wireframe
- rgl::plot3d
- rgl::surface3d
- scatterplot3d::scatterplot3d
graphics::persp
x <- seq(-10, 10, length.out = 30)
y <- x
f <- function(x, y) { r <- sqrt(x^2+y^2); 10 * sin(r)/r }
z <- outer(x, y, f)
z[is.na(z)] <- 1
op <- par(bg = "white")
persp(x, y, z, theta = 30, phi = 30, expand = 0.5, col = "lightblue")
persp(x, y, z, theta = 30, phi = 30, expand = 0.5, col = "lightblue",
ltheta = 120, shade = 0.75, ticktype = "detailed",
xlab = "X", ylab = "Y", zlab = "Sinc( r )"
) -> res
round(res, 3)
data:image/s3,"s3://crabby-images/0b78f/0b78fb0a530d44d3460e70de6d89d0dc62cfc32e" alt="用R语言绘制三维曲面_第1张图片"
data:image/s3,"s3://crabby-images/e5a70/e5a7020c9780841073f9cb4c776a2184408a9743" alt="用R语言绘制三维曲面_第2张图片"
lattice::wireframe
library(lattice)
d <- expand.grid(x =10:60, y = 5:40,g=2:3)
d$z <-log((d$x^d$g+d$y^2)*d$g)
wireframe(z~x*y,
data = d,
shade=T,
groups=g,
drape=T,
colorkey=T,
scales=list(arrows=T),
screen=list(z=45,x=-60)
)
data:image/s3,"s3://crabby-images/976c4/976c412797a5a922cf7995d8a54303d4df68dd74" alt="用R语言绘制三维曲面_第3张图片"
rgl::plot3d
library(rgl)
d <- expand.grid(x =10:60, y = 5:40,g=2:3)
d$z <-log((d$x^d$g+d$y^2)*d$g)
plot3d(d$x,d$y,d$z,
type="s",
size = 0.5,
col=terrain.colors(length(d$z)))
data:image/s3,"s3://crabby-images/0c967/0c9675060ca42ef2f9ed52adcc027dfb2670121a" alt="用R语言绘制三维曲面_第4张图片"
plot3d()所绘制的图形是可以用鼠标调整视角的。
plot3d(lm(mpg ~ wt + I(wt^2) + qsec,
data = mtcars),
plane.col =topo.colors(1))
data:image/s3,"s3://crabby-images/34b62/34b623e17ff74567be84c1cd642cbd1a68293810" alt="用R语言绘制三维曲面_第5张图片"
rgl::surface3d
z <- 4 * volcano
x <- 8 * (1:nrow(z))
y <- 6 * (1:ncol(z))
zlim <- range(z)
zlen <- zlim[2] - zlim[1] + 1
colorlut <- topo.colors(zlen)
col <- colorlut[ z - zlim[1] + 1 ]
open3d()
surface3d(x, y, z, color = col, back = "lines")
data:image/s3,"s3://crabby-images/8a25e/8a25ef34cd422dd87a607dd7c7516a3a737c313d" alt="用R语言绘制三维曲面_第6张图片"
scatterplot3d::scatterplot3d
data:image/s3,"s3://crabby-images/48ad1/48ad1c2a3425f876787283b07b123b67762b8f16" alt="用R语言绘制三维曲面_第7张图片"
data(trees)
s3d <- scatterplot3d(trees,
type="p",
highlight.3d=TRUE,
angle=60,
pch=16,
zlim = c(0,80),
col.grid="lightblue",
main="scatterplot3d")
tree_lm <- lm(Volume ~ Girth + Height,data = trees)
s3d$plane3d(tree_lm, lty.box = "solid")
data:image/s3,"s3://crabby-images/acf5f/acf5f5323dc86b025896675d43e6269dff765db2" alt="用R语言绘制三维曲面_第8张图片"