Python 普通最小二乘法(OLS)进行多项式拟合的方法


Posted in Python onDecember 29, 2018

多元函数拟合。如 电视机和收音机价格多销售额的影响,此时自变量有两个。

python 解法:

import numpy as np
import pandas as pd
#import statsmodels.api as sm #方法一
import statsmodels.formula.api as smf #方法二
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
 
df = pd.read_csv('http://www-bcf.usc.edu/~gareth/ISL/Advertising.csv', index_col=0)
X = df[['TV', 'radio']]
y = df['sales']
 
#est = sm.OLS(y, sm.add_constant(X)).fit() #方法一
est = smf.ols(formula='sales ~ TV + radio', data=df).fit() #方法二
y_pred = est.predict(X)
 
df['sales_pred'] = y_pred
print(df)
print(est.summary()) #回归结果
print(est.params) #系数
 
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d') #ax = Axes3D(fig)
ax.scatter(X['TV'], X['radio'], y, c='b', marker='o')
ax.scatter(X['TV'], X['radio'], y_pred, c='r', marker='+')
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
ax.set_zlabel('Z Label')
plt.show()

Python 普通最小二乘法(OLS)进行多项式拟合的方法

拟合的各项评估结果和参数都打印出来了,其中结果函数为:

f(sales) = β0 + β1*[TV] + β2*[radio]

f(sales) = 2.9211 + 0.0458 * [TV] + 0.188 * [radio]

Python 普通最小二乘法(OLS)进行多项式拟合的方法

图中,sales 方向上,蓝色点为原 sales 实际值,红色点为拟合函数计算出来的值。其实误差并不大,部分数据如下。

Python 普通最小二乘法(OLS)进行多项式拟合的方法

同样可拟合一元函数;

import numpy as np
import pandas as pd
import statsmodels.formula.api as smf
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
 
df = pd.read_csv('http://www-bcf.usc.edu/~gareth/ISL/Advertising.csv', index_col=0)
X = df['TV']
y = df['sales']
 
est = smf.ols(formula='sales ~ TV ', data=df).fit()
y_pred = est.predict(X)
print(est.summary())
fig = plt.figure()
ax = fig.add_subplot(111)
ax.scatter(X, y, c='b')
ax.plot(X, y_pred, c='r')
plt.show()

Python 普通最小二乘法(OLS)进行多项式拟合的方法

Python 普通最小二乘法(OLS)进行多项式拟合的方法

Ridge Regression:(岭回归交叉验证)

岭回归(ridge regression, Tikhonov regularization)是一种专用于共线性数据分析的有偏估计回归方法,实质上是一种改良的最小二乘估计法,通过放弃最小二乘法的无偏性,以损失部分信息、降低精度为代价获得回归系数更为符合实际、更可靠的回归方法,对病态数据的拟合要强于最小二乘法。通常岭回归方程的R平方值会稍低于普通回归分析,但回归系数的显著性往往明显高于普通回归,在存在共线性问题和病态数据偏多的研究中有较大的实用价值。

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from sklearn import linear_model
from mpl_toolkits.mplot3d import Axes3D
 
df = pd.read_csv('http://www-bcf.usc.edu/~gareth/ISL/Advertising.csv', index_col=0)
X = np.asarray(df[['TV', 'radio']])
y = np.asarray(df['sales'])
 
clf = linear_model.RidgeCV(alphas=[i+1 for i in np.arange(200.0)]).fit(X, y)
y_pred = clf.predict(X)
df['sales_pred'] = y_pred
print(df)
print("alpha=%s, 常数=%.2f, 系数=%s" % (clf.alpha_ ,clf.intercept_,clf.coef_))
 
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.scatter(df['TV'], df['radio'], y, c='b', marker='o')
ax.scatter(df['TV'], df['radio'], y_pred, c='r', marker='+')
ax.set_xlabel('TV')
ax.set_ylabel('radio')
ax.set_zlabel('sales')
plt.show()

输出结果:alpha=150.0, 常数=2.94, 系数=[ 0.04575621 0.18735312]

以上这篇Python 普通最小二乘法(OLS)进行多项式拟合的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python自动化测试之从命令行运行测试用例with verbosity
Sep 28 Python
深入理解Python分布式爬虫原理
Nov 23 Python
python 3利用Dlib 19.7实现摄像头人脸检测特征点标定
Feb 26 Python
Python简单定义与使用二叉树示例
May 11 Python
Python将list中的string批量转化成int/float的方法
Jun 26 Python
Python实现的各种常见分布算法示例
Dec 13 Python
Django之模型层多表操作的实现
Jan 08 Python
解决yum对python依赖版本问题
Jul 05 Python
Pycharm+Python+PyQt5使用详解
Sep 25 Python
Python post请求实现代码实例
Feb 28 Python
python FTP编程基础入门
Feb 27 Python
Python 数据可视化之Seaborn详解
Nov 02 Python
Python实现高斯函数的三维显示方法
Dec 29 #Python
Python3 SSH远程连接服务器的方法示例
Dec 29 #Python
使用python绘制3维正态分布图的方法
Dec 29 #Python
在python中利用最小二乘拟合二次抛物线函数的方法
Dec 29 #Python
对python指数、幂数拟合curve_fit详解
Dec 29 #Python
对python实现二维函数高次拟合的示例详解
Dec 29 #Python
pip安装py_zipkin时提示的SSL问题对应
Dec 29 #Python
You might like
全国FM电台频率大全 - 20 广西省
2020/03/11 无线电
基于数据库的在线人数,日访问量等统计
2006/10/09 PHP
PHP基于堆栈实现的高级计算器功能示例
2017/09/15 PHP
解决Extjs上传图片无法预览的解决方法
2012/03/22 Javascript
select标记美化--JS式插件、后期加载
2013/04/01 Javascript
JavaScript限定复选框的选择个数示例代码
2013/08/25 Javascript
jQuery中获取checkbox选中项等操作及注意事项
2013/11/24 Javascript
一个检测表单数据的JavaScript实例
2014/10/31 Javascript
JQuery插件ajaxfileupload.js异步上传文件实例
2015/05/19 Javascript
js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)
2015/11/09 Javascript
简单实现js选项卡切换效果
2016/02/03 Javascript
Angular2.js实现表单验证详解
2017/06/23 Javascript
angularJs中$http获取后台数据的实例讲解
2018/08/08 Javascript
微信小程序自定义可滑动日历界面
2018/12/28 Javascript
解决layui弹出层layer的area过大被遮挡的问题
2019/09/21 Javascript
vuex入门最详细整理
2020/03/04 Javascript
js实现随机点名
2021/01/19 Javascript
简单介绍Python中的JSON使用
2015/04/28 Python
Python的消息队列包SnakeMQ使用初探
2016/06/29 Python
python版本坑:md5例子(python2与python3中md5区别)
2017/06/20 Python
Pycharm设置去除显示的波浪线方法
2018/10/28 Python
Python2和Python3之间的str处理方式导致乱码的讲解
2019/01/03 Python
用python实现刷点击率的示例代码
2019/02/21 Python
Python使用paramiko操作linux的方法讲解
2019/02/25 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
django自带serializers序列化返回指定字段的方法
2019/08/21 Python
Python FtpLib模块应用操作详解
2019/12/12 Python
什么是python的列表推导式
2020/05/26 Python
英国PC组件和在线电脑商店:SCAN
2019/04/18 全球购物
大学本科毕业生求职信范文
2013/12/18 职场文书
2015年元旦活动总结
2014/05/09 职场文书
保护黄河倡议书
2014/05/16 职场文书
2014年质量管理工作总结
2014/12/01 职场文书
英文辞职信范文
2015/05/13 职场文书
react如何快速设置文件路径别名
2021/04/28 Javascript
win server2012 r2服务器共享文件夹如何设置
2022/06/21 Servers