我想创建一个球体的三维散点图,其颜色为第四维。 我有一个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)
我使用rgl.snapshot()导出到svg文件:
数据应该再次显示一层红色球,4层蓝色球和一层红色球。
答案 0 :(得分:16)
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
您可以像这样致电plot3d()
:
R> plot3d(df$x, df$y, df$z, col=df$color, size=2, type='s')
这会给你类似的东西: