que tiene un conjunto de datos similar a estaretraso general en el panel de datos de series temporales
User Date Value
A 2012-01-01 4
A 2012-01-02 5
A 2012-01-03 6
A 2012-01-04 7
B 2012-01-01 2
B 2012-01-02 3
B 2012-01-03 4
B 2012-01-04 5
Quiero crear un desfase de Value
, respetando User
.
User Date Value Value.lag
A 2012-01-01 4 NA
A 2012-01-02 5 4
A 2012-01-03 6 5
A 2012-01-04 7 6
B 2012-01-01 2 NA
B 2012-01-02 3 2
B 2012-01-03 4 3
B 2012-01-04 5 4
lo he hecho muy ineficiente en un bucle
df$value.lag1<-NA
levs<-levels(as.factor(df$User))
levs
for (i in 1:length(levs)) {
temper<- subset(df,User==as.numeric(levs[i]))
temper<- rbind(NA,temper[-nrow(temper),])
df$value.lag1[df$User==as.numeric(as.character(levs[i]))]<- temper
}
pero esto es muy lento. Lo he visto usando by
y tapply
, pero no he averiguado cómo hacer que funcionen.
No creo que XTS o TS funcionen debido al elemento Usuario.
¿Alguna sugerencia?
Creo que el paquete 'plm' tiene una implementación para este tipo de datos. – Seb