0

我有一个面板数据,包括个人多年来的收入,我对个人的收入趋势感兴趣,即多年来收入的个人系数,以及每个人每年的残差(根据我的模型,收入的意外变化) . 但是,我有很多观察结果缺少至少一年或多年的收入数据,因此通过线性回归,我失去了大部分观察结果。数据结构是这样的:

caseid<-c(1,1,1,1,1,1,2,2,2,2,2,2,3,3,3,3,3,3,4,4,4,4,4,4)
years<-c(1998,2000,2002,2004,2006,2008,1998,2000,2002,2004,2006,2008,
1998,2000,2002,2004,2006,2008,1998,2000,2002,2004,2006,2008)
income<-c(1100,NA,NA,NA,NA,1300,1500,1900,2000,NA,2200,NA, 
NA,NA,NA,NA,NA,NA, 2300,2500,2000,1800,NA, 1900)
df<-data.frame(caseid, years, income)

我决定使用随机效应模型,我认为仍然可以通过使用最大似然法来预测缺失年份的收入。然而,由于豪斯曼检验给出了显着的结果,我决定使用固定效应模型。我使用 plm 包运行了下面的代码:

inc.fe<-plm(income~years, data=df, model="within", effect="individual")

但是,我只得到多年的系数,而不是个人的系数;我不能得到残差。也许给出一个想法,Stata中的代码应该是

 xtest caseid
 xtest income year
 predict resid, resid

然后我尝试从同一个库中运行 pvcm 函数,这是一个可变系数的函数。

inc.wi<-pvcm(Income~Year, data=ldf, model="within", effect="individual")

但是,我收到以下错误消息:“FUN(X[[i]], ...) 中的错误:观察次数不足”。

如何通过解决此错误或使用其他函数来获得 pvcm 的单个系数和残差?

我的原始长格式数据有 202976 次观察和 15 年。

我也非常感谢对我选择分析的方法提出任何意见或建议。非常感谢。

4

2 回答 2

2

fixef包中的功能是否plm为您提供了您正在寻找的东西?继续你的例子:

fixef(inc.fe)

残差通过以下方式提取:

residuals(inc.fe)
于 2016-05-26T10:15:07.143 回答
0

您有一个具有随机斜率和截距的随机效应模型。这也称为随机系数回归模型。缺失是棘手的部分,(我猜)您必须在选择您希望的方式后编写自定义代码来解决。

但是据我所知,您还没有清楚/正确地指定您的模型(至少在您的问题中)。让我们定义一些术语:

令 Y_it = ind i (i= 1,..., N) 在第 t 年 (t= 1,...,T) 的收入。当我读到您的问题时,您尚未指定您希望拥有以下两个模型中的哪一个:

M1:随机截距、全局斜率、随机斜率

Y_it ~ N(\mu_i + B T + \gamma_i I T, \sigma^2) 
\mu_i ~ N(\phi_0, \tau_0^2) 
\gamma_i ~ N(\phi_1, tau_1^2)

M2:随机截距,随机斜率

Y_it ~ N(\mu_i + \gamma_i I T, \sigma^2) 
\mu_i ~ N(\phi_0, \tau_0^2) 
\gamma_i ~ N(\phi_1, tau_1^2)

此外,您的示例数据是无意义的(见下文)。如您所见,您没有足够的观察值来估计所有参数。我不熟悉,library(plm)但可以lme4轻松估计上述模型(没有缺失)。如果没有实际的示例数据集,我不会费心提供代码。

R> table(df$caseid, is.na(df$income))

    FALSE TRUE
  1     2    4
  2     4    2
  3     0    6
  4     5    1

鉴于您确实存在缺失,您应该能够通过典型方法(例如 EM)为任一层次模型生成估计值。但我确实认为您必须自己编写代码来进行估算。

于 2016-05-26T04:30:57.470 回答