我想填充plot(X, type='s')
我尝试polygon
使用但未成功绘制的阶跃函数线下的区域。
set.seed(1);y = abs(rnorm(10))
plot(y,ylim=c(0,max(y)), type="p",pch=24)
lines(y, type='s')
abline(h=0)
假设我想在曲线下方和上方绘制灰色y=0
x <- seq_along(y)
y2 <- rep(y, each=2)
y2 <- y2[-length(y2)]
x2 <- rep(x, each=2)[-1]
x3 <- c(min(x2), x2, max(x2))
y3 <- c(0, y2, 0)
# because polygon() is dumb and wants a pre-existing plot
plot(x, y, ylim=c(0, max(y)), type="n")
polygon(x3, y3, border=NA, col="grey")
lines(x2, y2)
一个Lattice
解决方案,它是对优秀 HongOoi 解决方案的基本改编。
set.seed(1)
xx <- c(1:10)
yy <- abs(rnorm(10))
library(lattice)
xyplot(yy~xx,type='s',
panel=function(x,y,...){
panel.xyplot(x,y,...)
y2 <- rep(y, each=2)
y2 <- y2[-length(y2)]
x2 <- rep(x, each=2)[-1]
x3 <- c(min(x2), x2, max(x2))
y3 <- c(0, y2, 0)
panel.polygon(x3, y3,col=rgb(1, 0, 0,0.5), border=NA)
})