Как я могу использовать grid для редактирования объекта ggplot2 для добавления математических выражений в метки фасетов?

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

levels(parameters) <- c(expression(alpha), expression(beta))  
p + facet_grid(.~parameters, labeller = label_parsed)

Это прекрасно работает и делает именно то, что я хочу. Однако вместо этого мне нужно использовать facet_wrap() (чтобы получить отдельные оси Y для обоих параметров, а также для отображения еще большего количества параметров в разных столбцах и строках). Я попробовал следующее:

p + facet_wrap(.~parameters, labeller = label_parsed)  ,  or  
p + facet_wrap(.~parameters)

но это не сработало, потому что в facet_wrap нет функции "labeller". Как это можно сделать с помощью сетки?

2 ответа

Решение

Этот пример должен помочь вам начать:

library("ggplot2")
library("grid")

d <- ggplot(iris, aes(Sepal.Length, Sepal.Width)) +
            geom_point() +
            facet_wrap(~Species)
grob <- ggplotGrob(d)
strip_elem <- grid.ls(getGrob(grob, "strip.text.x", grep=TRUE, global=TRUE))$name

grob <- grid::editGrob(grob, strip_elem[1], label=expression(alpha[1]))
grob <- grid::editGrob(grob, strip_elem[2], label=expression(beta^2))
grob <- grid::editGrob(grob, strip_elem[3], label=expression(hat(gamma)))

grid.draw(grob)

модифицированный гроб

Обновление: это работает с ggplot2 версия 0.9.3 (хотя использую grid это хрупкий способ изменить ggplot2 графика)

grob[["grobs"]][["strip_t.1"]][["children"]][[2]][["label"]] <- expression(alpha[1])
grob[["grobs"]][["strip_t.2"]][["children"]][[2]][["label"]] <- expression(beta^2)
grob[["grobs"]][["strip_t.3"]][["children"]][[2]][["label"]] <- expression(hat(gamma))
grid.draw(grob)

Я попробовал это, используя приведенный ниже код, и он работает для меня.

      library("ggplot2")
library("grid")

## 1. Plot d and print d
d <- ggplot(iris, aes(Sepal.Length, Sepal.Width)) + geom_point() + facet_wrap(~Species)
d

## 2. Put Greek letters into facet labels using grid.edit function
grid.force()
grid.ls() #You should find the exact names for facet labels in the printed output!
grid.edit("GRID.text.77",label=expression(alpha[1])) #"GRID.text.77" = name for the first facet label
grid.edit("GRID.text.80",label=expression(beta^2)) #"GRID.text.80" = name for the second facet label
grid.edit("GRID.text.83",label=expression(hat(gamma))) #"GRID.text.83" = name for the third facet label
Другие вопросы по тегам