通过 group_id 仅使用特定估计窗口中的观察值进行循环回归并将预测添加回 pandas 数据框

我正在尝试学习如何在 python 3.7 中执行一些我通常在 Stata 中轻松执行的操作。


我正在处理这样的数据框:


estimation_window    group_id         y            x   

0                       1             3.17         23

1                       1             4.76         26

1                       2             4.17         73

1                       2             8.70         72

0                       2             11.45        16

我想要一个 for 循环来估计 group_id 中每个不同组的线性回归(y on x),只使用虚拟 estimation_window 等于 1 的观察值。


然后,我想将三列添加回我的初始数据框:一列包含预测值,一列包含每个回归的 beta(x 系数),一列包含每个回归的截距。应该为所有观察值计算这些值,而不仅仅是虚拟 estimation_window 等于 1 的那些值。


生成的数据集应如下所示:


estimation_window    group_id         y            x        predicted_val    beta_coeff  alpha_coeff

0                       1             3.17         23           3.10            0.32         1.43        

1                       1             4.76         26           4.00            0.32         1.43

1                       2             4.17         73           4.10            0.75         0.95

1                       2             8.70         72           8.50            0.75         0.95

0                       2             11.45        16           10.30           0.75         0.95

我尝试使用 statsmodels 但无法弄清楚。


慕森卡
浏览 92回答 1
1回答

慕容森

假设你有你的数据框:>>> data   estimation_window  group_id      y     x0                  0         1   3.17  23.01                  1         1   4.76  26.02                  1         2   4.17  73.03                  1         2   8.70  72.04                  0         2  11.45  16.0然后你可以分组group_id,一个一个做线性回归,把参数存起来。如果您使用statsmodels的是 ,那么您可以执行以下操作:for groupid, grp in data.groupby('group_id'):    print(groupid)    model = sm.OLS(grp['y'], sm.add_constant(grp['x'])).fit()    data.loc[data['group_id'].eq(groupid), 'alpha'] = model.params['const']    data.loc[data['group_id'].eq(groupid), 'beta'] = model.params['x']然后你可以手动重新计算预测值(只是因为线性模型很简单):data['predicted_val'] = data['x'] * data['beta'] + data['alpha']结果是:   estimation_window  group_id      y     x      alpha      beta  predicted_val0                  0         1   3.17  23.0  -9.020000  0.530000       3.1700001                  1         1   4.76  26.0  -9.020000  0.530000       4.7600002                  1         2   4.17  73.0  12.926162 -0.089804       6.3704513                  1         2   8.70  72.0  12.926162 -0.089804       6.4602554                  0         2  11.45  16.0  12.926162 -0.089804      11.489294
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python