以GLM的形式在statsmodels中对数据进行开放和建模

2024-04-19 00:35:29 发布

您现在位置:Python中文网/ 问答频道 /正文

在python中,我将数据作为x和y变量存储为一个列表。如何将其导入python以运行statsmodels。在

from __future__ import print_function
import statsmodels.api as sm
import statsmodels.formula.api as smf
import pandas as pd

x = [1,1,2,3]
y=[1,0,0,0]
data  = pd.DataFrame(x,y) #to merge the two side by side

star98 = sm.datasets.star98.load_pandas().data

formula = 'x ~ y'


pd.options.mode.chained_assignment = None  # default='warn'


mod1 = smf.glm(formula=formula, data=data, family=sm.families.Binomial()).fit()

x = mod1.summary()

ValueError:对偏差函数的第一个猜测返回了一个nan。这可能是一个边界问题,应该报告


Tags: 数据importapipandas列表dataasside
1条回答
网友
1楼 · 发布于 2024-04-19 00:35:29

你有几个小问题。首先,您构建数据的方式,y实际上被解释为数据帧的索引:

In [3]:
    x = [1,1,2,3]
    y=[1,0,0,0]
    data  = pd.DataFrame(x,y) #to merge the two side by side
    data
Out[3]:
    0
1   1
0   1
0   2
0   3

相反,您必须将两者作为列传递,并确保它们获得列名;使用字典可能更容易:

^{pr2}$

其次,你的公式是错误的(因为我猜你是想从x中的数据对y进行分类),它应该是

formula = 'y ~ x'

如果你把它和你的代码放在一起,你会得到更好的结果。在

In [21]:
    x
Out[21]:
Generalized Linear Model Regression Results
Dep. Variable:  y   No. Observations:   4
Model:  GLM Df Residuals:   2
Model Family:   Binomial    Df Model:   1
Link Function:  logit   Scale:  1.0
Method: IRLS    Log-Likelihood: -1.3863
Date:   Mon, 28 Mar 2016    Deviance:   2.7726
Time:   15:34:32    Pearson chi2:   2.00
No. Iterations: 22      
coef    std err z   P>|z|   [95.0% Conf. Int.]
Intercept   22.1423 3.9e+04 0.001   1.000   -7.64e+04 7.64e+04
x   -22.1423    3.9e+04 -0.001  1.000   -7.64e+04 7.64e+04

希望有帮助。在

相关问题 更多 >