Я изучаю ggplot за последние несколько недель. В общем, я делаю вещи (хотя и медленно), но сейчас я застрял. Я создал следующий фасеточный график: http://dl.dropbox.com/u/7752237/example_bad_y_scales.pdf
Огранка выполняется
pl <- pl + facet_wrap(~sci_name,ncol=1,scale="free")
Проблема: числа на шкале Y выглядят не очень хорошо, особенно шкалы от 0 до 70 (числа перекрываются). Я хотел бы как-то изменить количество перерывов по шкале Y (скажем, только 1 или 2 перерыва). Может быть, у кого-нибудь есть идея, как это сделать? Любая помощь будет очень высоко ценится. :)
PS: я не включил минимальный пример, потому что думаю, что это не сильно поможет решить эту конкретную проблему.
Изменить после ответа Kohskes:
Привет Kohske, Вау, это был очень быстрый ответ, спасибо! Однако я думаю, что это не очень хорошо работает с гранеными сюжетами. смотреть на
p <- ggplot(mtcars, aes(wt, mpg))
p <- p + geom_point()
p <- p + facet_wrap(~gear,ncol=1,scale="free")
По шкале Y это дает 3 разрыва на среднем графике и 8 разрывов на нижнем графике… не очень последовательно (но, по крайней мере, не перекрывая друг друга, как в моем примере).
p2 <- p + scale_y_continuous(breaks=c(15,30),minor_breaks=c(10,20,25))
тоже не очень хорошо: две основные галочки на нижних графиках, только по одной на среднем и верхнем графиках. При наличии масштабов с большей разницей, чем в mtcars, результат будет еще менее удовлетворительным. Любые другие идеи? ;)
Редактировать после редактирования Kohskes:
Привет, я не вижу, как это реализовать. Поиск ggplot и input_break в гугле дал всего 10 результатов, ни один из них не помог. Я старался
p <- ggplot(mtcars, aes(wt, mpg))
p <- p + geom_point()
p <- p + facet_wrap(~gear,ncol=1,scale="free")
p$input_breaks<-function(., range) {
pretty(range, n=3)
}
print(p)
Однако я не вижу никаких эффектов на графике (пробовал для n=1, 3, 15). Не могли бы вы описать, как это реализовать на примере mtcars? Спасибо!