r - 基础 R 中缺失值的面积图

标签 r plot time-series missing-data

我想绘制一个面积图,其中多边形的底边为零,数据线在每个数据中断处(即开始、结束和可能的 NA/NaN)通过垂直线段连接到底边。

我画的是这个:

time serie

我必须强制垂直向下的部分,其中系列被 NA 打断,并且我在 0 秒内完成了对 NA 的转换。但这不会产生垂直线段,而是产生到达后续 0 的多边形线。我解决了系列开头和结尾的问题,在系列两侧添加了一个 (y = 0, x = 0) 点。

但是如果 NA 位于系列赛中,这并不能解决问题。

有什么想法吗?

这是一个示例代码(不同的图像):

pollen <- c(45, 257.4, 24.67, 54.6, 89.4, 297, 471.25, 1256.5, 312.25, 969.2, 787.5, 425, NaN, 76.6, 42.67, 38.5, 20.2, 5.67, 15.8, 13.2, 11, 6.25, 6.67, 2.3, 0.5, 30.8, 3.75, 3, 2, 2.2, 3.25, 4.5, 9.6, 15.8, 200.2, NaN)

weeks.vec <- c(5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40)

plot.ts(y = pollen, x = weeks.vec, col = 'red', ylab = 'Pollen',  xlab = 'Weeks', lwd = 3, xy.labels = F, xy.lines = T)
pollen[is.na(pollen)] <- 0

poly.y <- c(0,pollen,0)
poly.x <- c(weeks.vec[1], weeks.vec, weeks.vec[length(weeks.vec)])

polygon(y = poly.y, x = poly.x, density = NA,border = NA, col = rgb(1,0,0, .3))

最佳答案

我会使用ggplot2:

pollen <- c(45, 257.4, 24.67, 54.6, 89.4, 297, 471.25, 1256.5, 312.25, 969.2, 787.5, 425, NaN, 76.6, 42.67, 38.5, 20.2, 5.67, 15.8, 13.2, 11, 6.25, 6.67, 2.3, 0.5, 30.8, 3.75, 3, 2, 2.2, 3.25, 4.5, 9.6, 15.8, 200.2, NaN)

weeks.vec <- c(5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40)


DF <- data.frame(pollen, weeks.vec)

library(ggplot2)
ggplot(DF, aes(x = weeks.vec, y = pollen)) +
  geom_ribbon(aes(ymin = 0, ymax = pollen), 
              colour = NA, fill = "red", alpha = 0.3) +
  geom_line(colour = "red") + 
  geom_point(colour = "red", size = 3) +
  xlab("Week") + ylab("Pollen") +
  theme_bw()

resulting plot

但是如果您必须使用基本图:

plot.ts(y = pollen, x = weeks.vec, col = 'red', 
        ylab = 'Pollen',  xlab = 'Weeks', lwd = 3, 
        xy.labels = F, xy.lines = T)

g <- cumsum(!is.finite(pollen))
for (i in unique(g)) {
  y <- pollen[g == i]
  x <- weeks.vec[g == i]
  x <- x[is.finite(y)]
  y <- y[is.finite(y)]
  x <- c(x, rev(x))
  y <- c(y, y * 0)
  polygon(y = y, x = x, density = NA,border = NA, col = rgb(1,0,0, .3))
}

resulting plot

关于r - 基础 R 中缺失值的面积图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29651598/

相关文章:

function - 创建函数以在 Mathematica 中灵活定义图表选项列表

r - 在运行时制作 R 函数 "listen"用于控制台输入?

R:选择包含给定数量 NA 的行

python - Altair:当类别多于可用颜色时如何着色

image - matplotlib imshow() 具有不规则间隔的数据点

machine-learning - 仅使用新到达的数据重新训练时间序列(Keras)(不是从头开始进行新训练)

python - Pandas 中的日期格式顺序

python - 查找一天中事件的开始时间和结束时间 - Pandas 时间序列 - 这样结束时间不会落入第二天

r - 在 R 的 read.table() 中指定多字符注释标记

r - 如何在R中的geom_segment/ggplot2中绘制定向蜘蛛网络?