如何理解statsmodels.ols的输出结果?ols计算的线性回归结果以及手动计算的结果的对比

手动计算

def linegress(l_1,l_2):  #求两列数据的线性回归参数
  import numpy as np
  from numpy.linalg import solve
  sumx = np.sum(l_1)  #x列的和
  sumy = np.sum(l_2)  #y列的和
  n = len(l_1)  #数据的个数
  sumxy = np.sum(np.array(l_1)*np.array(l_2))  #xy两列的乘积的和
  sumx2 = np.sum(np.array(l_1)**2)  #x的平方的和
  a = np.mat([[sumx,n],[sumx2,sumx]])  #用np.mat传入第一个矩阵
  b = np.mat([sumy,sumxy]).T  #用np.mat.T传入第二个矩阵
  x = solve(a,b) #求出ab
  return x #输出

这里得到以下输出结果
matrix([[ 0.88632061], [-89.12267277]])

上面的就是我们手动笔算线性回归参数的时候会得到的结果,a=0.886,b=-89.123

我们把我们得到的ab代入Y=ax+b来计算新的y列,并求出r2

"""計算"""
import numpy as np
x = np.array([171,180,169,173,173,163,168,176,173,174,164,171,172,172,175,163,163,162,167,170,173,170,170,175,170]) #x列
y = np.array([62,71,53,78,59,54,62,60,62,60,50,66,69,63,62,65,53,52,60,67,70,67,56,68,56]
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值