5

我正在寻找用索引标记数据点 - 通过目视检查轻松识别索引号。

例如,

x<-ts.plot(rnorm(10,0,1)) # would like to visually identify the data point indices easily through arrow labelling

当然,如果有更好的方法来实现这一点,请提出建议

4

4 回答 4

5

您可以使用arrows功能:

set.seed(1); ts.plot(x <-rnorm(10,0,1), ylim=c(-1.6,1.6))  # some random data
arrows(x0=1:length(x), y0=0, y1=x, code=2, col=2, length=.1) # adding arrows
text(x=1:10, y=x+.1, 0, labels=round(x,2), cex=0.65) # adding text
abline(h=0) # adding a horizontal line at y=0

在此处输入图像描述

于 2013-02-15T12:15:52.087 回答
3

使用my.symbolsfrom packageTeachingDemos获取指向所需位置的箭头:

require(TeachingDemos)
d <- rnorm(10,0,1)
plot(d, type="l", ylim=c(min(d)-1, max(d)+1))
my.symbols(x=1:10, y=d, ms.arrows, angle=pi/2, add=T, symb.plots=TRUE, adj=1.5)

在此处输入图像描述

于 2013-02-15T11:57:12.940 回答
2

你可以用text()这个

n <- 10
d <- rnorm(n)
plot(d, type="l", ylim=c(min(d)-1, max(d)+1))
text(1:n, d+par("cxy")[2]/2,col=2) # Upside
text(1:n, d-par("cxy")[2]/2,col=3) # Downside
于 2013-02-15T12:08:27.183 回答
1

这里有一个lattice版本,可以看到一些基本功能的类比。

set.seed(1234)
dat = data.frame(x=1:10, y = rnorm(10,0,1))
xyplot(y~x,data=dat, type =c('l','p'),
       panel = function(x,y,...){
         panel.fill(col=rgb(1,1,0,0.5))
         panel.xyplot(x,y,...)
         panel.arrows(x, y0=0,x1=x, y1=y, code=2, col=2, length=.1)
         panel.text(x,y,label=round(y,2),adj=1.2,cex=1.5)
         panel.abline(a=0)

       })

在此处输入图像描述

于 2013-02-15T14:48:23.313 回答