在图上添加回归直线方程和R2

我想知道如何在ggplot上添加回归直线方程和R ^ 2。 我的代码是

library(ggplot2)
df <- data.frame(x = c(1:100))
df$y <- 2 + 3 * df$x + rnorm(100, sd = 40)
p <- ggplot(data = df, aes(x = x, y = y)) +
            geom_smooth(method = "lm", se=FALSE, color="black", formula = y ~ x) +
            geom_point()
p

任何帮助将不胜感激。


这是一个解决方案

# GET EQUATION AND R-SQUARED AS STRING
# SOURCE: http://goo.gl/K4yh

lm_eqn <- function(df){
    m <- lm(y ~ x, df);
    eq <- substitute(italic(y) == a + b %.% italic(x)*","~~italic(r)^2~"="~r2, 
         list(a = format(coef(m)[1], digits = 2), 
              b = format(coef(m)[2], digits = 2), 
             r2 = format(summary(m)$r.squared, digits = 3)))
    as.character(as.expression(eq));                 
}

p1 <- p + geom_text(x = 25, y = 300, label = lm_eqn(df), parse = TRUE)

编辑。 我想出了我选择这个代码的来源。 以下是ggplot2谷歌组中原始帖子的链接

产量


我改变了stat_smooth和相关函数源的几行来创建一个新的函数,它将拟合方程和R平方值相加。 这也将在小平面图上起作用!

library(devtools)
source_gist("524eade46135f6348140")
df = data.frame(x = c(1:100))
df$y = 2 + 5 * df$x + rnorm(100, sd = 40)
df$class = rep(1:2,50)
ggplot(data = df, aes(x = x, y = y, label=y)) +
  stat_smooth_func(geom="text",method="lm",hjust=0,parse=TRUE) +
  geom_smooth(method="lm",se=FALSE) +
  geom_point() + facet_wrap(~class)

在这里输入图像描述

我使用@ Ramnath的答案中的代码来格式化公式。 stat_smooth_func函数不是很健壮,但不应该很难玩弄它。

https://gist.github.com/kdauria/524eade46135f6348140。 如果出现错误,请尝试更新ggplot2


我已经修改Ramnath的帖子到a)使其更通用,因此它接受线性模型作为参数而不是数据框,并且b)更适当地显示底片。

lm_eqn = function(m) {

  l <- list(a = format(coef(m)[1], digits = 2),
      b = format(abs(coef(m)[2]), digits = 2),
      r2 = format(summary(m)$r.squared, digits = 3));

  if (coef(m)[2] >= 0)  {
    eq <- substitute(italic(y) == a + b %.% italic(x)*","~~italic(r)^2~"="~r2,l)
  } else {
    eq <- substitute(italic(y) == a - b %.% italic(x)*","~~italic(r)^2~"="~r2,l)    
  }

  as.character(as.expression(eq));                 
}

用法将更改为:

p1 = p + geom_text(aes(x = 25, y = 300, label = lm_eqn(lm(y ~ x, df))), parse = TRUE)
链接地址: http://www.djcxy.com/p/25027.html

上一篇: Adding Regression Line Equation and R2 on graph

下一篇: Order Bars in ggplot2 bar graph