Python多项式回归的实现方法


Posted in Python onMarch 11, 2019

多项式回归是一种线性回归形式,其中自变量x和因变量y之间的关系被建模为n次多项式。多项式回归拟合x的值与y的相应条件均值之间的非线性关系,表示为E(y | x)

为什么多项式回归:

  • 研究人员假设的某些关系是曲线的。显然,这种类型的案例将包括多项式项。
  • 检查残差。如果我们尝试将线性模型拟合到曲线数据,则预测变量(X轴)上的残差(Y轴)的散点图将在中间具有许多正残差的斑块。因此,在这种情况下,这是不合适的。
  • 通常的多元线性回归分析的假设是所有自变量都是独立的。在多项式回归模型中,不满足该假设。

多项式回归的使用:

这些基本上用于定义或描述非线性现象,例如:

  • 组织生长速度。
  • 疾病流行病的进展
  • 湖泊沉积物中碳同位素的分布

回归分析的基本目标是根据自变量x的值来模拟因变量y的期望值。在简单回归中,我们使用以下等式 y = a + bx + e

这里y是因变量,a是y截距,b是斜率,e是误差率。

在许多情况下,这种线性模型将无法解决。例如,如果我们在这种情况下根据合成温度分析化学合成的产生,我们使用二次模型y = a + b1x + b2 ^ 2 + e

这里y是x的因变量,a是y截距,e是误差率。

通常,我们可以将其建模为第n个值。y = a + b1x + b2x ^ 2 + .... + bnx ^ n

由于回归函数在未知变量方面是线性的,因此这些模型从估计的角度来看是线性的。

因此,通过最小二乘技术,让我们计算y的响应值。

Python中的多项式回归:

要获得用于分析多项式回归的数据集,请单击此处。

步骤1:导入库和数据集

导入重要的库和我们用于执行多项式回归的数据集。

# Importing the libraries 
import numpy as np 
import matplotlib.pyplot as plt 
import pandas as pd 

# Importing the dataset 
datas = pd.read_csv('data.csv') 
datas

Python多项式回归的实现方法

第2步:将数据集分为2个组件

将数据集划分为两个组件,即X和yX将包含1到2之间的列.y将包含2列。

X = datas.iloc[:, 1:2].values 
y = datas.iloc[:, 2].values

第3步:将线性回归拟合到数据集

拟合线性回归模型在两个组件上。

# Fitting Linear Regression to the dataset 
from sklearn.linear_model import LinearRegression 
lin = LinearRegression() 

lin.fit(X, y)

第4步:将多项式回归拟合到数据集

将多项式回归模型拟合到两个分量X和y上。

# Fitting Polynomial Regression to the dataset 
from sklearn.preprocessing import PolynomialFeatures 

poly = PolynomialFeatures(degree = 4) 
X_poly = poly.fit_transform(X) 

poly.fit(X_poly, y) 
lin2 = LinearRegression() 
lin2.fit(X_poly, y)

步骤5:在此步骤中,我们使用散点图可视化线性回归结果。

# Visualising the Linear Regression results 
plt.scatter(X, y, color = 'blue') 

plt.plot(X, lin.predict(X), color = 'red') 
plt.title('Linear Regression') 
plt.xlabel('Temperature') 
plt.ylabel('Pressure') 

plt.show()

Python多项式回归的实现方法

步骤6:使用散点图可视化多项式回归结果。

# Visualising the Polynomial Regression results 
plt.scatter(X, y, color = 'blue') 

plt.plot(X, lin2.predict(poly.fit_transform(X)), color = 'red') 
plt.title('Polynomial Regression') 
plt.xlabel('Temperature') 
plt.ylabel('Pressure') 

plt.show()

Python多项式回归的实现方法

步骤7:使用线性和多项式回归预测新结果。

# Predicting a new result with Linear Regression 
lin.predict(110.0)

Python多项式回归的实现方法

# Predicting a new result with Polynomial Regression 
lin2.predict(poly.fit_transform(110.0))

Python多项式回归的实现方法

使用多项式回归的优点:

  • 广泛的功能可以适应它。
  • 多项式基本上适合宽范围的曲率。
  • 多项式提供了依赖变量和自变量之间关系的最佳近似。

使用多项式回归的缺点

  • 这些对异常值过于敏感。
  • 数据中存在一个或两个异常值会严重影响非线性分析的结果。
  • 此外,遗憾的是,用于检测非线性回归中的异常值的模型验证工具少于线性回归。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
详解python基础之while循环及if判断
Aug 24 Python
python指定写入文件时的编码格式方法
Jun 07 Python
pygame游戏之旅 载入小车图片、更新窗口
Nov 20 Python
对python 读取线的shp文件实例详解
Dec 22 Python
PyQt弹出式对话框的常用方法及标准按钮类型
Feb 27 Python
python使用pyecharts库画地图数据可视化的实现
Mar 25 Python
pandas数据选取:df[] df.loc[] df.iloc[] df.ix[] df.at[] df.iat[]
Apr 24 Python
Python实现查找数据库最接近的数据
Jun 08 Python
解决Tensorflow2.0 tf.keras.Model.load_weights() 报错处理问题
Jun 12 Python
Tensorflow之MNIST CNN实现并保存、加载模型
Jun 17 Python
解决Python 写文件报错TypeError的问题
Oct 23 Python
python爬虫之爬取笔趣阁小说
Apr 22 Python
Python实现定制自动化业务流量报表周报功能【XlsxWriter模块】
Mar 11 #Python
浅谈Python中的可迭代对象、迭代器、For循环工作机制、生成器
Mar 11 #Python
python使用selenium实现批量文件下载
Mar 11 #Python
利用Python实现微信找房机器人实例教程
Mar 10 #Python
谈谈Python中的while循环语句
Mar 10 #Python
15行Python代码实现网易云热门歌单实例教程
Mar 10 #Python
Python如何爬取实时变化的WebSocket数据的方法
Mar 09 #Python
You might like
PHP DataGrid 实现代码
2009/08/12 PHP
PHP中用hash实现的数组
2011/07/17 PHP
php ajax 静态分页过程形式
2011/09/02 PHP
页面乱码问题的根源及其分析
2013/08/09 PHP
详解WordPress开发中过滤属性以及Sql语句的函数使用
2015/12/25 PHP
解决在Laravel 中处理OPTIONS请求的问题
2019/10/11 PHP
用JQUERY增删元素的代码
2012/02/14 Javascript
jQuery弹出层插件Lightbox_me使用指南
2015/04/21 Javascript
JavaScript 定时器 SetTimeout之定时刷新窗口和关闭窗口(代码超简单)
2016/02/26 Javascript
require.js配合插件text.js实现最简单的单页应用程序
2016/07/12 Javascript
js检测离开或刷新页面时表单数据是否更改的方法
2016/08/02 Javascript
jQuery中Find选择器用法示例
2016/09/21 Javascript
angular中的http拦截器Interceptors的实现
2017/02/21 Javascript
node.JS md5加密中文与php结果不一致的解决方法
2017/05/05 Javascript
js页面加载后执行的几种方式小结
2020/01/30 Javascript
详解JavaScript中的this指向问题
2021/02/05 Javascript
[04:09]显微镜下的DOTA2第十二期—NaVi美如画的团战
2014/06/23 DOTA
[02:56]《DAC最前线》之国外战队抵达上海备战亚洲邀请赛
2015/01/28 DOTA
python 示例分享---逻辑推理编程解决八皇后
2014/07/20 Python
详解Python中的文件操作
2016/08/28 Python
Pycharm学习教程(4) Python解释器的相关配置
2017/05/03 Python
Python基于matplotlib实现绘制三维图形功能示例
2018/01/18 Python
python3实现点餐系统
2019/01/24 Python
我能否用void** 指针作为参数, 使函数按引用接受一般指针
2013/02/16 面试题
EJB的角色和三个对象
2015/12/31 面试题
自我鉴定模板
2013/10/29 职场文书
无工作经验者个人求职信范文
2013/12/22 职场文书
社区学习雷锋活动总结
2014/04/25 职场文书
学习张林森心得体会
2014/09/10 职场文书
合伙经营协议书范本
2014/09/13 职场文书
工资证明范本
2015/06/12 职场文书
2015年学校教研室主任工作总结
2015/07/20 职场文书
2015大学党建带团建工作总结
2015/07/23 职场文书
幼儿园2016圣诞节活动总结
2016/03/31 职场文书
导游词之香港-太平山顶
2019/10/18 职场文书
快速学习Oracle触发器和游标
2021/06/30 Oracle