Добавление простой линии тренда lm в ggplot boxplot

при добавлении линии тренда линейной модели в boxplot с использованием стандартной графики R я использую:

boxplot(iris[,2]~iris[,1],col="LightBlue",main="Quartile1 (Rare)")
modelQ1<-lm(iris[,2]~iris[,1])
abline(modelQ1,lwd=2)

однако при использовании этого в ggplot2:

a <- ggplot(iris,aes(factor(iris[,1]),iris[,2]))
a + geom_boxplot() +
geom_smooth(method = "lm", se=FALSE, color="black", formula=iris[,2]~iris[,1])

Я получаю следующую ошибку:

geom_smooth: Only one unique x value each group.Maybe you want aes(group = 1)?

и линия не появляется на моем участке.

модели, используемые в обоих этих случаях одинаковы. Если бы кто-нибудь мог указать, где я ошибаюсь, это было бы здорово.

EDIT: в качестве примера используется набор данных iris.

2 ответов


сообщение об ошибке в значительной степени понятно: добавить aes(group=1) to geom_smooth:

ggplot(iris, aes(factor(Sepal.Length), Sepal.Width)) +
  geom_boxplot() +
  geom_smooth(method = "lm", se=FALSE, color="black", aes(group=1))

enter image description here


FYI, эта ошибка также может быть обнаружена (и исправлена) с помощью простого qplot интерфейс ggplot2

сообщение об ошибке недостаточно объяснительно для нескольких человек, по крайней мере :-). В этом случае ключ должен включать только содержание предлагаемого эстетического

library(ggplot2)
qplot(factor(Sepal.Length), Sepal.Width, geom = c("smooth"), data= iris)
# error, needs aes(group=1)
qplot(factor(Sepal.Length), Sepal.Width, geom = c("smooth"), group = 1, data= iris)