Това е основен проблем при анализа на данни, с който Stata се справя в една стъпка.
Създайте широка рамка от данни с непроменливи във времето данни (x0) и променливи във времето данни за години 2000 и 2005 (x1,x2):
d1 <- data.frame(subject = c("id1", "id2"),
x0 = c("male", "female"),
x1_2000 = 1:2,
x1_2005 = 5:6,
x2_2000 = 1:2,
x2_2005 = 5:6
)
s.t.
subject x0 x1_2000 x1_2005 x2_2000 x2_2005
1 id1 male 1 5 1 5
2 id2 female 2 6 2 6
Искам да го оформя като панел, така че данните да изглеждат така:
subject x0 time x1 x2
1 id1 male 2000 1 1
2 id2 female 2000 2 2
3 id1 male 2005 5 5
4 id2 female 2005 6 6
Мога да направя това с reshape
s.t.
d2 <-reshape(d1,
idvar="subject",
varying=list(c("x1_2000","x1_2005"),
c("x2_2000","x2_2005")),
v.names=c("x1","x2"),
times = c(2000,2005),
direction = "long",
sep= "_")
Основната ми грижа е, че когато имате десетки променливи, горната команда става много дълга. В stata
човек просто ще напише:
reshape long x1 x2, i(subject) j(year)
Има ли такова просто решение в R?