ggplot平滑线glm模型与给定的权重向量

The*_*aya 4 r ggplot2 glm

我有以下数据:

numbers <- structure(list(density = c(1L, 4L, 10L, 22L, 55L, 121L, 210L, 
444L), females = c(1L, 3L, 7L, 18L, 22L, 41L, 52L, 79L), males = c(0L, 
1L, 3L, 4L, 33L, 80L, 158L, 365L), maleProp = c(0, 0.25, 0.3, 
0.181818181818182, 0.6, 0.661157024793388, 0.752380952380952, 
0.822072072072072), total = c(1L, 4L, 10L, 22L, 55L, 121L, 210L, 
444L)), .Names = c("density", "females", "males", "maleProp", 
"total"), row.names = c(NA, -8L), class = "data.frame")
Run Code Online (Sandbox Code Playgroud)

我希望glmtotalas 方法有一个平滑的线weight.我试过了,

ggplot(numbers, aes(density, maleProp)) + geom_point() + 
  stat_smooth(method = "glm", 
              method.args = list(family = "binomial", 
                                 type = "response", 
                                 weights = "total"))
Run Code Online (Sandbox Code Playgroud)

我收到了错误,

Warning message:
Computation failed in `stat_smooth()`:
formal argument "weights" matched by multiple actual arguments 
Run Code Online (Sandbox Code Playgroud)

在这种情况下,如何绘制平滑线?

小智 5

如果要使用glm带有所列参数的a ,可以创建一个包装函数,如下所示:

binomial_smooth <- function(...) {
  geom_smooth(method = "glm", method.args = list(family = "binomial"), ...)
}
Run Code Online (Sandbox Code Playgroud)

你可以直接在你的ggplot2对象上使用它:

ggplot(numbers, aes(density, maleProp)) + geom_point() + binomial_smooth(aes(weight = total))
Run Code Online (Sandbox Code Playgroud)