繁体   English   中英

R - 着色散点图

[英]R - colouring scatterplot points

在此处输入图像描述

您好,我想知道为什么我下面的代码使图例着色,但点本身不是:

# dataset <- data.frame(IDName, Value, Setpoints)
# dataset <- unique(dataset)

# Paste or type your script code here:
dat <- aggregate(Value ~ Setpoints + IDName, dataset, mean)

x <- dat$Value
y <- dat$Setpoints
z <- dataset$IDName

plot(x,y, main ="Turbidity Frequency Distribution",xlab="% Time < Turbidity level", ylab="Turbidity (NTU)")

lines(spline(x,y))

palette()
legend('topleft', legend = unique(z), col = 1:3, cex = 0.8, pch = 1)

#constant lines
abline(h=c(0.1,0.15,0.3), col=c("red","pink","purple"), lty=2, lwd=3)

确保z是一个factor 然后,在创建 plot 时使用col = z 你会得到彩色点。

在你的legend (出现在图例中的字符值)到你的factor zlevels 此外,根据unique(z)设置 colors - 它们应该与您的点相匹配。

这是完整的示例。 将来,请不要将数据放在评论中,而是使用数据编辑您的问题。 此外,您可能需要考虑ggplot2以供将来绘图。

dat <- aggregate(Value ~ Setpoints + IDName, dataset, mean)

x <- dat$Value
y <- dat$Setpoints
z <- dataset$IDName

z <- factor(z)

plot(x, y, 
     main ="Turbidity Frequency Distribution",
     xlab="% Time < Turbidity level", 
     ylab="Turbidity (NTU)",
     col = z)

lines(spline(x,y))

palette()

legend('topleft', 
       legend = levels(z), 
       col = unique(z), 
       cex = 0.8, 
       pch = 1)

#constant lines
abline(h=c(0.1,0.15,0.3), col=c("red","pink","purple"), lty=2, lwd=3)

Plot

用彩色点绘制

数据

dataset <- structure(list(IDName = c("Filter01", "Filter01", "Filter01", 
"Filter01", "Filter01", "Filter02", "Filter02", "Filter02", "Filter02", 
"Filter02"), Setpoints = c(0.16, 0.2, 0.3, 2, 2.2, 0.16, 0.2, 
0.3, 2, 2.2), Value = c(96.1, 96.2, 96.428, 99.603, 99.6, 98.8, 
98.9, 99.049, 99.194, 99.2)), class = "data.frame", row.names = c(NA, 
-10L))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM