Различные осевые границы на грань в ggplot2 - программирование
Подтвердить что ты не робот

Различные осевые границы на грань в ggplot2

Я пытаюсь сделать граненный график в ggplot2, где ось y показывает метки, а ось x должна показывать линейные графики со значением для каждой метки в двух разных измерениях (которые находятся в разных масштабах). Пока у меня есть это:

Data <- structure(list(label = structure(
  c(1L, 1L, 2L, 2L, 3L, 3L, 4L, 
  4L, 5L, 5L, 6L, 6L), .Label = c("A", "B", "C", "D", "E", "F"), class = "factor"), 
  facet = structure(c(1L, 2L, 1L, 2L, 1L, 2L, 1L, 2L, 1L, 2L, 
  1L, 2L), .Label = c("A", "B"), class = "factor"), value = c(0.0108889081049711, 
  0.37984336540103, 0.0232500876998529, 0.777756493305787, 
  0.0552913920022547, 0.920194681268185, 0.0370863009011373, 
  0.114463779143989, 0.00536034172400832, 0.469208759721369, 
  0.0412159096915275, 0.587875489378348), group = c(1, 1, 1, 
  1, 1, 1, 1, 1, 1, 1, 1, 1)), .Names = c("label", "facet", 
  "value", "group"), row.names = c(NA, -12L), class = "data.frame")

ggplot(Data, aes(x = label, y = value, group = group)) + geom_line() + 
     facet_grid(~ facet, scales = "free") + coord_flip()

Что создает следующий график: enter image description here

Проблема в том, что меры находятся в разных масштабах, и я предпочел бы, чтобы график A имел пределы x от 0 до 0,1, а график B имел пределы x от 0 до 1. Я думал, что scales = "free" должен исправить это, но он не меняет сюжет.

4b9b3361

Ответ 1

Я придумал нечто похожее на df239:

ggplot(Data, aes(y = label, x = value, group=group)) + geom_path() + 
  facet_wrap( ~ facet, scales = "free")

Обратите внимание, что вы должны использовать geom_path и следить за порядком ваших точек, потому что просто переключение x и y не совпадает с coord_flip (что, как указано в другом ответе, не поддерживается facet_wrap).

enter image description here

Ответ 2

Измените ориентацию осей вручную, проблема в том, что: ggplot2 в настоящее время не поддерживает свободные шкалы с помощью некартезной координаты или координаты. *

ggplot(Data, aes(y = label, x = value, group = group)) + geom_line() + 
 facet_grid(~ facet, scales = "free")