我想创建一个球体的三维散点图,其颜色是第四维.我有一个csv文件中的数据,其中每一行指示一个粒子的x,y,z位置,我有一个列告诉我粒子的值(1,2或3).如果它们的值为1,我想用一种颜色的球着色,否则用另一种颜色.
我创建了以下代码:
library(rgl)
m <- read.csv(file="mem0.csv", sep = ",", head=TRUE)
mcol = m$val
i = 1
mdim = dim(m)
while (i <= mdim[1] ){
if (mcol[i] == 1){
mcol[i] = "red"
}else {
mcol[i] = "blue"
}
i = i +1
}
plot3d(m$x, m$y, m$z, col = mcol, type='s', size=0.1)
Run Code Online (Sandbox Code Playgroud)
我使用rgl.snapshot()导出到svg文件:

数据应该再次显示一层红球,4层蓝色球和一层红球.
jub*_*uba 17
包的plot3d()功能rgl允许很容易地做这样的事情.你甚至可以互动地探索你的情节:
R> library(rgl)
R> df <- data.frame(x=runif(10,0,1),
+ y=runif(10,0,1),
+ z=runif(10,0,1),
+ color=round(runif(10,1,3)))
R> df
x y z color
1 0.73518229 0.1385970 0.69053482 2
2 0.88789302 0.6872121 0.54734176 2
3 0.79402546 0.5771570 0.89613292 1
4 0.19922140 0.2117405 0.25116078 1
5 0.31825325 0.7449661 0.01174593 2
6 0.64614521 0.4704698 0.68905621 1
7 0.15242295 0.6461338 0.77896858 1
8 0.32698024 0.4548752 0.33969754 3
9 0.00793849 0.6557488 0.75901935 2
10 0.20460232 0.9302882 0.23413984 3
Run Code Online (Sandbox Code Playgroud)
你可以这样打电话plot3d():
R> plot3d(df$x, df$y, df$z, col=df$color, size=2, type='s')
Run Code Online (Sandbox Code Playgroud)
哪个会给你这样的东西:
