
我尝试在R中使用代码,但它们不起作用:
try_tori_1 = function(){
library(rgl)
xvec= yvec = seq(-pi,pi,by=0.1);
z <- outer(xvec,yvec,function(x,y) {sin(x)+.5*sin(x)*cos(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue")
z <- outer(xvec,yvec,function(x,y) {cos(x)+.5*cos(x)*cos(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue", add=T)
z <- outer(xvec,yvec,function(x,y) {.5*sin(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue", add=T)
z <- outer(xvec,yvec,function(x,y) {1+cos(x)+.5*cos(x)*cos(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue", add=T)
z <- outer(xvec,yvec,function(x,y) {.5*sin(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue", add=T)
z <- outer(xvec,yvec,function(x,y) {sin(x)+.5*sin(x)*cos(y)} )
persp3d(z, theta = 30, phi = 30, expand = 0.5, col = "lightblue", add=T)
}
try_tori_2 = function(){
library(rgl)
u= v = seq(-pi,pi,by=0.1);
plot3d(cos(u)+.5*cos(u)*cos(v),sin(u)+.5*sin(u)*cos(v),.5*sin(v))
plot3d(1+cos(u)+.5*cos(u)*cos(v),.5*sin(v),sin(u)+.5*sin(u)*cos(v))
}
Run Code Online (Sandbox Code Playgroud)
我的回答是基于这两个网站的例子:
这是你如何做到的:
library(plot3D)
x <- seq(-pi,pi,by=0.1)
y <- seq(-pi,pi,by=0.1)
R = 1.0
r = 0.5
M <- mesh(x, y)
alpha <- M$x
beta <- M$y
surf3D(x = (R + r*cos(alpha)) * cos(beta),
y = (R + r*cos(alpha)) * sin(beta),
z = r * sin(alpha),
col="blue", colkey=FALSE, alpha = 0.3, border="black",
xlim=c(-0.5*pi,0.5*pi), ylim=c(-0.5*pi,0.5*pi), zlim=c(-0.5*pi,0.5*pi))
surf3D(x = R + cos(alpha) + r*cos(alpha) * cos(beta),
y = r*sin(beta),
z = sin(alpha)+ r * sin(alpha) * cos(beta),
col="red", colkey=FALSE, alpha = 0.3, border="black", add=T)
Run Code Online (Sandbox Code Playgroud)
这产生了这个情节:

需要注意的重要事项是:
surf3D功能meshxlim使用第一个图表指定范围(等)