用ggplot2模拟Google表格平滑的折线图 [英] Emulating Google Sheets smoothed line chart with ggplot2

查看:570
本文介绍了用ggplot2模拟Google表格平滑的折线图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用ggplot2模拟Google表格平滑折线图.它将在所有数据点上绘制一条平滑的线.

I'm trying to emulate a Google Sheets smoothed line chart with ggplot2. It draws a smoothed line through all data points.

在Google表格中绘制: 上下两行是我的硬编码置信区间.

plot in Google Sheets: The lines above and below is my hardcoded confidence intervals.

数据:

library(tidyverse)
data <- tibble(
    date = seq.Date(as.Date("2018-12-01"), as.Date("2018-12-20"), by = "days"),
    var = c(0.329,0.348,0.349,0.355,0.382,0.363,0.340,0.359,0.336,0.358,0.398,0.389,0.389,0.390,0.383,0.343,0.352,0.415,0.397,0.430),
    lower = c(0.311,0.330,0.330,0.336,0.364,0.345,0.321,0.342,0.319,0.341,0.384,0.375,0.375,0.374,0.369,0.329,0.337,0.400,0.382,0.417),
    upper = c(0.347,0.366,0.368,0.374,0.400,0.381,0.358,0.377,0.354,0.375,0.413,0.404,0.403,0.405,0.397,0.357,0.368,0.430,0.412,0.444))

我几乎得到了与黄土相同的曲线.但这给了我一个警告,并在某些时候给出了一个奇怪且锐利的区域.

I almost get the same curve with loess. But it gives me a warning and a strange sharp-looked areas at some points.

代码:

ggplot(data, aes(x = seq_along(date), y = var)) + 
    geom_point(size = 2, color = "blue", alpha = 0.2) +
    # geom_smooth(method = "lm", formula = y ~ splines::bs(x, 20), se = F) +
    # stat_smooth(method = "gam", formula = y ~ s(x, k = 19), se = F) +
    stat_smooth(method = "loess", span = 0.2, se = F) +
    theme_classic() + theme(axis.line = element_line(size = 0.5, colour = "grey80"))

警告:

Warning messages:
1: In simpleLoess(y, x, w, span, degree = degree, parametric = parametric,  :
    Chernobyl! trL>n 20
2: In simpleLoess(y, x, w, span, degree = degree, parametric = parametric,  :
    Chernobyl! trL>n 20
3: In sqrt(sum.squares/one.delta) : NaNs produced

R图:

推荐答案

仅为了可视化,您可以尝试很棒的 ggalt 包,通过 @hrbrmstr .

Just for the visualisation you can try awesome ggalt package by @hrbrmstr.

ggalt::geom_xspline绘制x样条.

library(ggalt)
library(tidyverse)

data <- tibble(
    date = seq.Date(as.Date("2018-12-01"), as.Date("2018-12-20"), by = "days"),
    var = c(0.329,0.348,0.349,0.355,0.382,0.363,0.340,0.359,0.336,0.358,0.398,0.389,0.389,0.390,0.383,0.343,0.352,0.415,0.397,0.430),
    lower = c(0.311,0.330,0.330,0.336,0.364,0.345,0.321,0.342,0.319,0.341,0.384,0.375,0.375,0.374,0.369,0.329,0.337,0.400,0.382,0.417),
    upper = c(0.347,0.366,0.368,0.374,0.400,0.381,0.358,0.377,0.354,0.375,0.413,0.404,0.403,0.405,0.397,0.357,0.368,0.430,0.412,0.444))

ggplot(data, aes(seq_along(date), var)) + 
    geom_point(size = 2, color = "blue", alpha = 0.2) +
    geom_xspline() +
    theme_classic() + 
    theme(axis.line = element_line(size = 0.5, colour = "grey80"))

这篇关于用ggplot2模拟Google表格平滑的折线图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆