Я новичок в R, и любая помощь очень ценится.У меня есть следующие (только для примера) данные о перемещениях робота между точками (вывод dt2).Ось X - это отметка времени каждого перемещения, а ось Y - индекс пятна, на который она перемещена.Проблема в том, что я не могу назначить фиксированные цвета каждому роботу и ограничить график только роботами в данных (3 в данном случае).От 1 до 5 роботов (от G до K) могут быть представлены в наборе данных.Я хочу, чтобы один скрипт обрабатывал все наборы данных, независимо от того, сколько роботов записано.
moveID robot stepStartTime spotIndex chartCategory line_color
1 1 G 2018-05-31 23:13:00 2 Robot G NA white
2 2 G 2018-05-31 23:13:00 4 Robot G NA white
3 3 G 2018-05-31 23:13:00 8 Robot G NA white
....
29 29 G 2018-05-31 23:17:10 26 Robot G Efficient green4
30 30 G 2018-05-31 23:20:10 26 Robot G Efficient green4
31 31 G 2018-05-31 23:21:10 26 Robot G Efficient green4
32 32 G 2018-05-31 23:23:10 26 Robot G Efficient green4
....
115 115 G 2018-06-01 02:23:10 30 Robot G Efficient green4
116 116 G 2018-06-01 02:25:10 18 Robot G Inefficient red
117 117 G 2018-06-01 02:26:10 18 Robot G Efficient green4
118 118 G 2018-06-01 02:27:10 18 Robot G Efficient green4
119 119 G 2018-06-01 02:29:10 14 Robot G Efficient green4
....
164 164 H 2018-05-31 23:12:00 2 Robot H NA white
165 165 H 2018-05-31 23:12:00 4 Robot H NA white
166 166 H 2018-05-31 23:12:00 8 Robot H NA white
....
193 193 H 2018-05-31 23:12:00 6 Robot H Efficient dodgerblue1
194 194 H 2018-05-31 23:14:12 6 Robot H Efficient dodgerblue1
195 195 H 2018-05-31 23:21:12 10 Robot H Efficient dodgerblue1
Я использую следующий код:
dataset = read.csv("C:/Users/User/R Chart/Data_1.csv", header = TRUE, sep = ",", quote = "", dec = ".", fill = TRUE, comment.char = "")
library("ggplot2")
library("dplyr")
options(max.print = 2000)
dataset$stepStartTime <- as.POSIXct(dataset$stepStartTime, format="%Y/%m/%dT%H:%M:%S")
dt2 <- dataset %>%
mutate(line_color = case_when(
chartCategory == "Robot G NA" ~ "white",
chartCategory == "Robot H NA" ~ "white",
chartCategory == "Robot I NA" ~ "white",
chartCategory == "Robot J NA" ~ "white",
chartCategory == "Robot K NA" ~ "white",
chartCategory == "Robot G Inefficient" ~ "red",
chartCategory == "Robot H Inefficient" ~ "red",
chartCategory == "Robot I Inefficient" ~ "red",
chartCategory == "Robot J Inefficient" ~ "red",
chartCategory == "Robot K Inefficient" ~ "red",
chartCategory == "Robot G Efficient" ~ "green4", # green #229954 (ends bay 30)
chartCategory == "Robot H Efficient" ~ "dodgerblue1", #blue #5dade2 (ends bay 18)
chartCategory == "Robot I Efficient" ~ "grey62", # violet #9b59b6 (ends bay 38)
chartCategory == "Robot J Efficient" ~ "chocolate2", # red #EC7063 (ends bay 14)
chartCategory == "Robot K Efficient" ~ "orange1", # orange #f5b041 (ends bay 22)
))
dt2
p = ggplot(data=dt2, aes(stepStartTime, spotIndex, group=robot, color=line_color))+
geom_step(size = 1)+
geom_point( size = 6, shape = 'I') +
theme(
legend.position='none',
axis.line = element_line(colour = "#000000", size = 0.3, linetype = "solid"),
axis.ticks.x = element_line(size = 1),
axis.ticks.y = element_line(size = 1),
axis.text.x = element_text(face="plain", color="#808080", size=9, angle=0),
axis.text.y = element_text(face="plain", color="#808080", size=9, angle=0),
axis.title.x = element_blank(),
axis.title.y = element_blank(),
panel.border = element_rect(linetype = "solid", colour = "#808080", size = 1, fill = NA),
panel.background = element_rect(fill = "transparent", colour = NA),
plot.background = element_rect(fill = "transparent", colour = NA)
)
p +
scale_y_reverse(breaks=c(66,64,62,60,58,56,54,52,50,48,46,44,42,40,38,36,34,32,30, 28,26,24,22,20,18,16,14,12,10,8,6,4,2),lim=c(66,2))
В настоящее время диаграмма выглядит какследующий.Есть 5 участков, но данные есть только у 3 роботов.